当前位置: 首页 > news >正文

杭州企业如何建网站wordpress加导航栏视频

杭州企业如何建网站,wordpress加导航栏视频,免费做的网站怎么设置域名,网站如何实现微文章目录 1.RSA2.Golang 实现 RSA生成密钥加密解密签名验签 3.dablelv/cyan参考文献 1.RSA RSA 是最常用的非对称加密算法#xff0c;由 Ron Rivest、Adi Shamir、Leonard Adleman 于1977 年在麻省理工学院工作时提出#xff0c;RSA 是三者姓氏首字母的拼接。 它的基本原理… 文章目录 1.RSA2.Golang 实现 RSA生成密钥加密解密签名验签 3.dablelv/cyan参考文献 1.RSA RSA 是最常用的非对称加密算法由 Ron Rivest、Adi Shamir、Leonard Adleman 于1977 年在麻省理工学院工作时提出RSA 是三者姓氏首字母的拼接。 它的基本原理涉及到数学中的大整数因数分解问题即将一个大的合数通常是一个极大数字分解为其素数因子。RSA 算法的安全性基于这个问题的难解性目前还没有高效的方法可以在合理的时间内分解大整数。 RSA 支持变长密钥非对称加密需要加密的文件块的长度也是可变的。 2.Golang 实现 RSA Golang 标准库在 crypto/rsa 包实现了 RSA。 下面将利用 Golang 标准库相演示 RSA 生成密钥、加密、解密、签名与验签等操作。 生成密钥 // GenRsaKey generates an PKCS#1 RSA keypair of the given bit size in PEM format. func GenRsaKey(bits int) (prvkey, pubkey []byte, err error) {// Generates private key.privateKey, err : rsa.GenerateKey(rand.Reader, bits)if err ! nil {return}derStream : x509.MarshalPKCS1PrivateKey(privateKey)block : pem.Block{Type: RSA PRIVATE KEY,Bytes: derStream,}prvkey pem.EncodeToMemory(block)// Generates public key from private key.publicKey : privateKey.PublicKeyderPkix, err : x509.MarshalPKIXPublicKey(publicKey)if err ! nil {return}block pem.Block{Type: RSA PUBLIC KEY,Bytes: derPkix,}pubkey pem.EncodeToMemory(block)return }加密 RSA 是一个非对称加密算法虽然私钥也可以用于加密数据但因为公钥是对外的所以加密数据的意义不大因为知道公钥的所有人都能解密。 所以常见的做法是是用公钥加密数据私钥解密数据。而私钥则用户签名公钥用于验签。 // RsaEncrypt encrypts data using rsa public key. func RsaEncrypt(pubkey, data []byte) ([]byte, error) {block, _ : pem.Decode(pubkey)if block nil {return nil, errors.New(decode public key error)}pub, err : x509.ParsePKIXPublicKey(block.Bytes)if err ! nil {return nil, err}return rsa.EncryptPKCS1v15(rand.Reader, pub.(*rsa.PublicKey), data) }解密 // RsaDecrypt decrypts data using rsa private key. func RsaDecrypt(prvkey, cipher []byte) ([]byte, error) {block, _ : pem.Decode(prvkey)if block nil {return nil, errors.New(decode private key error)}prv, err : x509.ParsePKCS1PrivateKey(block.Bytes)if err ! nil {return nil, err}return rsa.DecryptPKCS1v15(rand.Reader, prv, cipher) }签名 // RsaSign signs using private key in PEM format. func RsaSign(prvkey []byte, hash crypto.Hash, data []byte) ([]byte, error) {block, _ : pem.Decode(prvkey)if block nil {return nil, errors.New(decode private key error)}privateKey, err : x509.ParsePKCS1PrivateKey(block.Bytes)if err ! nil {return nil, err}// MD5 and SHA1 are not supported as they are not secure.var hashed []byteswitch hash {case crypto.SHA224:h : sha256.Sum224(data)hashed h[:]case crypto.SHA256:h : sha256.Sum256(data)hashed h[:]case crypto.SHA384:h : sha512.Sum384(data)hashed h[:]case crypto.SHA512:h : sha512.Sum512(data)hashed h[:]}return rsa.SignPKCS1v15(rand.Reader, privateKey, hash, hashed) }验签 // RsaVerifySign verifies signature using public key in PEM format. // A valid signature is indicated by returning a nil error. func RsaVerifySign(pubkey []byte, hash crypto.Hash, data, sig []byte) error {block, _ : pem.Decode(pubkey)if block nil {return errors.New(decode public key error)}pub, err : x509.ParsePKIXPublicKey(block.Bytes)if err ! nil {return err}// SHA1 and MD5 are not supported as they are not secure.var hashed []byteswitch hash {case crypto.SHA224:h : sha256.Sum224(data)hashed h[:]case crypto.SHA256:h : sha256.Sum256(data)hashed h[:]case crypto.SHA384:h : sha512.Sum384(data)hashed h[:]case crypto.SHA512:h : sha512.Sum512(data)hashed h[:]}return rsa.VerifyPKCS1v15(pub.(*rsa.PublicKey), hash, hashed, sig) }3.dablelv/cyan 以上函数已放置 Golang 实用函数库 dablelv/cyan欢迎大家 import 使用。 package mainimport (stdcrypto cryptofmtgithub.com/dablelv/cyan/crypto )func main() {prvkey, pubkey, err : crypto.GenRsaKey(2048)if err ! nil {panic(err)}data : []byte(foo)// Encrypt data.cipher, err : crypto.RsaEncrypt(pubkey, data)if err ! nil {panic(err)}if len(cipher) ! 2048/8 {panic(cipher len not equal to key length)}// Decrypt data.plain, err : crypto.RsaDecrypt(prvkey, cipher)if err ! nil {panic(err)}if string(data) string(plain) {fmt.Printf(rsa encrypt and decrypt succeeded, data:%v plain:%v\n, string(data), string(plain))}// Using SHA256 to hash msg and then use rsa private key to sign.sig, err : crypto.RsaSign(prvkey, stdcrypto.SHA256, data)if err ! nil {panic(err)}if len(sig) ! 2048/8 {panic(signature len not equal to key length)}// Using public key to verify signature.err crypto.RsaVerifySign(pubkey, stdcrypto.SHA256, data, sig)if err ! nil {panic(err)}fmt.Println(verify signature succeeded) }运行输出 rsa encrypt and decrypt succeeded, data:foo plain:foo verify signature succeeded参考文献 rsa.com 一文读懂 HTTPS 背后的加密知识
http://www.yutouwan.com/news/408759/

相关文章:

  • 肥西县住房和城乡建设局网站jsp做的网站难吗
  • 张家港网站制作营销策略ppt
  • 公司建网站的详细步骤网站公司怎么做推广方案
  • 厦门知名网站建设网站建设工作安排方案
  • 老外做的汉语网站logo图案大全
  • 重庆网站建设挑夹夹虫快速搭建网站视频教程
  • 门户网站建设关键点网站建设涉及的法律
  • 微信支付网站开发网站开发课程设计说明书
  • 哪家微信网站建设好做it题的网站
  • 织梦网站模板如何安装教程视频资质做网站需要用到什么
  • 高端的佛山网站建设价格如何建立外贸网站
  • 怎么把凡科网里做的网站保存成文件富锦网站制作
  • 中山最好的网站建设公司哪家好烟台做外贸网站
  • 酒店网站策划书商城版网站制作
  • 网站设计所用到的技术合肥专业网站优化费用
  • 衡水做网站技术怎么在高德地图上添加自己的店铺
  • 用网站源码做网站旅游类网站建设方案
  • 做暖暖XO网站昆明网站做
  • 武安市网站建设费用开发一款游戏能赚多少钱
  • 大连网站开发公司shepiguophp免费企业网站模板
  • 海南省旅游专业网站发展电子商务缺乏强大的专业产业资源做后盾男女做那个网站
  • pc下载网站模板深圳市西特塔网站建设工作室
  • 如何有效的进行网站策划门户网站集约化建设
  • 公司网站如何做seo如何做律所网站
  • 免费ppt课件下载网站网站开发用什么简单
  • 网站建设分项报价表做网站页面对PS切图
  • 无锡网站建设网站转化率的网站设计
  • 帮别人做网站必须要开公司建筑工程网格化区域划片管理制度
  • 西安市做网站义乌做网站多少钱
  • 杭州制作网站哪家好深网站建设