golang中crypto/dsa包

栏目: Go · 发布时间: 7年前

内容简介:DSA是用于数字签名的一种算法,私钥进行签名,公钥进行验证。关于更多dsa内容以及dsa实现移步那么go语言中怎么进行数字签名呢?go语言中怎么进行数字验证呢?下面给出这两个操作的案例代码:

DSA是用于数字签名的一种算法,私钥进行签名,公钥进行验证。关于更多dsa内容以及dsa实现移步 www.baidu.com

那么 go 语言中怎么进行数字签名呢?go语言中怎么进行数字验证呢?下面给出这两个操作的案例代码:

package main

import (
    "crypto/dsa"
    "crypto/rand"
    "fmt"
)

func main() {
    // parameters 是私钥的参数
    var param dsa.Parameters
    // L1024N160是一个枚举,根据L1024N160来决定私钥的长度(L N)
    dsa.GenerateParameters(&param, rand.Reader, dsa.L1024N160)
    // 定义私钥的变量
    var privateKey dsa.PrivateKey
    // 设置私钥的参数
    privateKey.Parameters = param
    // 生成密钥对
    dsa.GenerateKey(&privateKey, rand.Reader)
    // 公钥是存在在私钥中的,从私钥中读取公钥
    publicKey := privateKey.PublicKey
    message := []byte("hello,dsa签名")

    // 进入签名操作
    r, s, _ := dsa.Sign(rand.Reader, &privateKey, message)

    // 进入验证
    flag := dsa.Verify(&publicKey, message, r, s)
    if flag {
        fmt.Println("数据未被修改")
    } else {
        fmt.Println("数据被修改")
    }
    flag = dsa.Verify(&publicKey, []byte("hello"), r, s)
    if flag {
        fmt.Println("数据未被修改")
    } else {
        fmt.Println("数据被修改")
    }
}
输出:
数据未被修改
数据被修改

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法概论

算法概论

Sanjoy Dasgupta、Christos Papadimitriou、Umesh Vazirani / 钱枫 注、邹恒明 注 / 机械工业出版社 / 2009-1 / 55.00元

《算法概论(注释版)》源自加州大学伯克利分校和加州大学圣迭戈分校本科生的算法课讲义,以独特的视角展现了算法设计的精巧技术及魅力。在表达每一种技术时,强调每个算法背后的简洁数学思想,分析其时间和空间效率,运用与其他技术类比的方法来说明特征,并提供了大量实例。《算法概论(注释版)》以人类最古老的算法(算术运算)为起点,将各种算法中优美而有代表性的内容囊括书中,并以最前沿的理论(量子算法)结束,构成了较......一起来看看 《算法概论》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具