婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Go語言 如何實現RSA加密解密

Go語言 如何實現RSA加密解密

熱門標簽:excel地圖標注分布數據 電話機器人軟件免費 外呼系統顯本地手機號 涿州代理外呼系統 壽光微信地圖標注 百度地圖標注后傳給手機 外呼系統用什么卡 評價高的400電話辦理 阿克蘇地圖標注

RSA是一種非對稱加密算法,它的名字是由它的三位開發者,即RonRivest、AdiShamir和LeonardAdleman 的姓氏的首字母組成的(Rivest-Shamir-Adleman ),可用于數據加密和數字簽名。

用于數據加密時,消息發送方利用對方的公鑰進行加密,消息接受方收到密文時使用自己的私鑰進行解密。

實現代碼如下:

import (
	"crypto/rsa"
	"crypto/rand"
	"crypto/x509"
	"os"
	"encoding/pem"
	"fmt"
)
//生成RSA私鑰和公鑰,保存到文件中
func GenerateRSAKey(bits int){
	//GenerateKey函數使用隨機數據生成器random生成一對具有指定字位數的RSA密鑰
	//Reader是一個全局、共享的密碼用強隨機數生成器
	privateKey, err := rsa.GenerateKey(rand.Reader, bits)
	if err!=nil{
		panic(err)
	}
	//保存私鑰
	//通過x509標準將得到的ras私鑰序列化為ASN.1 的 DER編碼字符串
	X509PrivateKey := x509.MarshalPKCS1PrivateKey(privateKey)
	//使用pem格式對x509輸出的內容進行編碼
	//創建文件保存私鑰
	privateFile, err := os.Create("private.pem")
	if err!=nil{
		panic(err)
	}
	defer privateFile.Close()
	//構建一個pem.Block結構體對象
	privateBlock:= pem.Block{Type: "RSA Private Key",Bytes:X509PrivateKey}
	//將數據保存到文件
	pem.Encode(privateFile,privateBlock)
	//保存公鑰
	//獲取公鑰的數據
	publicKey:=privateKey.PublicKey
	//X509對公鑰編碼
	X509PublicKey,err:=x509.MarshalPKIXPublicKey(publicKey)
	if err!=nil{
		panic(err)
	}
	//pem格式編碼
	//創建用于保存公鑰的文件
	publicFile, err := os.Create("public.pem")
	if err!=nil{
		panic(err)
	}
	defer publicFile.Close()
	//創建一個pem.Block結構體對象
	publicBlock:= pem.Block{Type: "RSA Public Key",Bytes:X509PublicKey}
	//保存到文件
	pem.Encode(publicFile,publicBlock)
}
//RSA加密
func RSA_Encrypt(plainText []byte,path string)[]byte{
	//打開文件
	file,err:=os.Open(path)
	if err!=nil{
		panic(err)
	}
	defer file.Close()
	//讀取文件的內容
	info, _ := file.Stat()
	buf:=make([]byte,info.Size())
	file.Read(buf)
	//pem解碼
	block, _ := pem.Decode(buf)
	//x509解碼
	publicKeyInterface, err := x509.ParsePKIXPublicKey(block.Bytes)
	if err!=nil{
		panic(err)
	}
	//類型斷言
	publicKey:=publicKeyInterface.(*rsa.PublicKey)
	//對明文進行加密
	cipherText, err := rsa.EncryptPKCS1v15(rand.Reader, publicKey, plainText)
	if err!=nil{
		panic(err)
	}
	//返回密文
	return cipherText
}
//RSA解密
func RSA_Decrypt(cipherText []byte,path string) []byte{
	//打開文件
	file,err:=os.Open(path)
	if err!=nil{
		panic(err)
	}
	defer file.Close()
	//獲取文件內容
	info, _ := file.Stat()
	buf:=make([]byte,info.Size())
	file.Read(buf)
	//pem解碼
	block, _ := pem.Decode(buf)
	//X509解碼
	privateKey, err := x509.ParsePKCS1PrivateKey(block.Bytes)
	if err!=nil{
		panic(err)
	}
	//對密文進行解密
	plainText,_:=rsa.DecryptPKCS1v15(rand.Reader,privateKey,cipherText)
	//返回明文
	return plainText
}

測試代碼如下:

func main(){
 //生成密鑰對,保存到文件
 GenerateRSAKey(2048)
 message:=[]byte("hello world")
 //加密
 cipherText:=RSA_Encrypt(message,"public.pem")
 fmt.Println("加密后為:",string(cipherText))
 //解密
 plainText := RSA_Decrypt(cipherText, "private.pem")
 fmt.Println("解密后為:",string(plainText))
}

測試結果如下:

補充:golang中關于RSA加密、解密、簽名、驗簽的總結

golang中關于RSA的加密、解密、簽名、驗簽的使用主要在于使用x509及rsa package下相關的方法。

gocrypt是本人對一般常用的加/解密、簽名/驗簽、hash的封裝庫,歡迎大家使用。

以下總結相關的各種變化類型:

1.秘鑰、加密/簽名字符串加密的格式

目前主要見到有hex及base64

(1)hex

針對hex的加解密

hex.DecodeString(s string)//解密
hex.EncodeToString(src []byte) string//加密

(2)base64

base64.StdEncoding.DecodeString(s string) ([]byte, error)//解密
base64.StdEncoding.EncodeToString(src []byte) string//加密

2.私鑰的格式

解析私鑰的方式如下:

(1)PKCS1

x509.ParsePKCS1PrivateKey(der []byte) (key interface{}, err error)

(2)PKCS8

x509.ParsePKCS8PrivateKey(der []byte) (key interface{}, err error)

3.采用的數字簽名算法SHA

以下為RSA sign的不同說明:

(1)SHA1

    hash := sha1.New()
 hash.Write([]byte(originalData))
 encryptedData, err := rsa.SignPKCS1v15(rand.Reader, prvKey, crypto.SHA1, hash.Sum(nil))

(2)SHA256

    hash := sha256.New()
 hash.Write([]byte(originalData))
 encryptedData, err := rsa.SignPKCS1v15(rand.Reader, prvKey, crypto.SHA256, hash.Sum(nil))

4.RSA使用類型

主要有加密/解密、簽名/驗簽4種方式,且加密/解密與簽名/驗簽均是一個相反的過程。兩對是根據對公鑰及私鑰的使用劃分的。

加密/解密是采用公鑰加密,私鑰解密。

簽名/驗簽是采用私鑰簽名,公鑰驗簽。

(1)加密

rsa.EncryptPKCS1v15(rand io.Reader, pub *PublicKey, msg []byte) ([]byte, error)

(2)解密

rsa.DecryptPKCS1v15(rand io.Reader, priv *PrivateKey, ciphertext []byte) ([]byte, error)

(3)簽名

rsa.SignPKCS1v15(rand io.Reader, priv *PrivateKey, hash crypto.Hash, hashed []byte) ([]byte, error)

(4)驗簽

rsa.VerifyPKCS1v15(pub *PublicKey, hash crypto.Hash, hashed []byte, sig []byte) error

5.具體的使用示例

(1)加密:采用sha1算法加密后轉base64格式
func RsaEncryptWithSha1Base64(originalData,publicKey string)(string,error){
   key, _ := base64.StdEncoding.DecodeString(publicKey)
   pubKey, _ := x509.ParsePKIXPublicKey(key)
   encryptedData,err:=rsa.EncryptPKCS1v15(rand.Reader, pubKey.(*rsa.PublicKey), []byte(originalData))
   return base64.StdEncoding.EncodeToString(encryptedData),err
}
(2)解密:對采用sha1算法加密后轉base64格式的數據進行解密(私鑰PKCS1格式)
func RsaDecryptWithSha1Base64(encryptedData,privateKey string)(string,error){
   encryptedDecodeBytes,err:=base64.StdEncoding.DecodeString(encryptedData)
   if err!=nil {
      return "",err
   }
   key,_:=base64.StdEncoding.DecodeString(privateKey)
   prvKey,_:=x509.ParsePKCS1PrivateKey(key)
   originalData,err:=rsa.DecryptPKCS1v15(rand.Reader,prvKey,encryptedDecodeBytes)
   return string(originalData),err
}
(3)簽名:采用sha1算法進行簽名并輸出為hex格式(私鑰PKCS8格式)
func RsaSignWithSha1Hex(data string, prvKey string) (string, error) {
   keyByts, err := hex.DecodeString(prvKey)
   if err != nil {
      fmt.Println(err)
      return "", err
   }
   privateKey, err := x509.ParsePKCS8PrivateKey(keyByts)
   if err != nil {
      fmt.Println("ParsePKCS8PrivateKey err", err)
      return "", err
   }
   h := sha1.New()
   h.Write([]byte([]byte(data)))
   hash := h.Sum(nil)
   signature, err := rsa.SignPKCS1v15(rand.Reader, privateKey.(*rsa.PrivateKey), crypto.SHA1, hash[:])
   if err != nil {
      fmt.Printf("Error from signing: %s\n", err)
      return "", err
   }
   out := hex.EncodeToString(signature)
   return out, nil
}
(4)驗簽:對采用sha1算法進行簽名后轉base64格式的數據進行驗簽
func RsaVerySignWithSha1Base64(originalData, signData, pubKey string) error{
   sign, err := base64.StdEncoding.DecodeString(signData)
   if err != nil {
      return err
   }
   public, _ := base64.StdEncoding.DecodeString(pubKey)
   pub, err := x509.ParsePKIXPublicKey(public)
   if err != nil {
      return err
   }
   hash := sha1.New()
   hash.Write([]byte(originalData))
   return rsa.VerifyPKCS1v15(pub.(*rsa.PublicKey), crypto.SHA1, hash.Sum(nil), sign)
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • go 實現簡易端口掃描的示例
  • go xorm框架的使用
  • 解析Go的Waitgroup和鎖的問題
  • Go語言快速入門圖文教程
  • go語言基礎 seek光標位置os包的使用
  • Go語言獲取文件的名稱、前綴、后綴
  • Go 自定義package包設置與導入操作
  • 詳解Gotorch多機定時任務管理系統

標簽:雞西 重慶 梅河口 銅川 吐魯番 欽州 蘭州 汕頭

巨人網絡通訊聲明:本文標題《Go語言 如何實現RSA加密解密》,本文關鍵詞  語言,如何,實現,RSA,加密解密,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Go語言 如何實現RSA加密解密》相關的同類信息!
  • 本頁收集關于Go語言 如何實現RSA加密解密的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人av网站在线| 亚洲国产毛片aaaaa无费看| 久久av中文字幕片| 国产精品理伦片| 欧美一级在线观看| 99久久精品国产毛片| 日韩av在线免费观看不卡| 日韩码欧中文字| 久久网这里都是精品| 欧美日韩视频在线一区二区 | 日本女人一区二区三区| 亚洲伦理在线免费看| 亚洲欧洲av色图| 国产精品色呦呦| 亚洲国产精华液网站w | 一区二区三区丝袜| 最新国产成人在线观看| 国产精品国产三级国产有无不卡| 国产女人18水真多18精品一级做| 2023国产精品| 日韩三级中文字幕| 欧美午夜免费电影| 欧美日韩国产乱码电影| 欧美美女喷水视频| 日韩视频一区二区三区| 久久女同性恋中文字幕| 国产视频一区在线观看| 国产精品青草综合久久久久99| 欧美国产精品v| 国产精品美女久久久久av爽李琼 | 成人av网站在线观看免费| av影院午夜一区| 在线免费精品视频| 精品视频在线视频| 欧美精品乱人伦久久久久久| 日韩三级视频在线观看| 国产精品久久久久久久第一福利| 国产精品三级av| 亚洲成人av中文| 精品一区二区三区视频在线观看| 国产九九视频一区二区三区| fc2成人免费人成在线观看播放| 色综合久久中文综合久久97| 欧美日韩视频专区在线播放| 久久亚洲精华国产精华液| 日本一区二区三级电影在线观看| 亚洲精品日日夜夜| 久久精品国产亚洲aⅴ| 成人动漫在线一区| 欧美日韩国产欧美日美国产精品| 欧美xxxxxxxxx| 中文字幕色av一区二区三区| 婷婷综合五月天| 国产乱色国产精品免费视频| 欧美亚洲综合另类| 久久久久久久av麻豆果冻| 亚洲日本中文字幕区| 久久精品国产一区二区三 | 精品久久久久久最新网址| 国产精品剧情在线亚洲| 午夜国产精品一区| 丁香婷婷综合网| 欧美一级xxx| 亚洲欧美日韩国产成人精品影院| 日韩av一二三| 色综合久久中文字幕| 久久久亚洲精华液精华液精华液 | 国产成人av影院| 欧美色中文字幕| 国产精品美女久久久久久久| 国产美女视频一区| 欧美一区二区美女| 亚洲电影视频在线| 91在线视频网址| 欧美—级在线免费片| 麻豆极品一区二区三区| 欧美蜜桃一区二区三区| 亚洲激情在线播放| 成人av中文字幕| 久久亚洲精品国产精品紫薇| 蜜臀av国产精品久久久久| 欧美日韩中文国产| 亚洲一二三四区| 色哦色哦哦色天天综合| 欧美国产一区二区| 国产精品亚洲а∨天堂免在线| 精品少妇一区二区三区视频免付费| 婷婷久久综合九色综合伊人色| 91黄色免费观看| 亚洲视频一区二区在线观看| 成人激情开心网| 中文字幕av免费专区久久| 国产一区高清在线| 久久久精品免费免费| 国产成+人+日韩+欧美+亚洲| 国产清纯白嫩初高生在线观看91 | 日韩美女久久久| 成人精品一区二区三区四区 | 日本电影亚洲天堂一区| 亚洲最大色网站| 欧美色图免费看| 婷婷综合另类小说色区| 日韩久久久久久| 九九九久久久精品| 久久亚洲一区二区三区明星换脸| 国产精品影视在线| 中文字幕va一区二区三区| 99国产精品久| 亚洲一区二区三区四区五区黄| 在线观看亚洲专区| 奇米888四色在线精品| 精品一区二区在线视频| 欧美一级夜夜爽| 国产麻豆一精品一av一免费| k8久久久一区二区三区| 色一情一伦一子一伦一区| 亚洲综合一二区| 日本强好片久久久久久aaa| 日韩午夜av电影| 久久狠狠亚洲综合| 国产午夜精品一区二区| 色婷婷激情久久| 久久精品国产一区二区三| 中文字幕一区二区三区精华液| 欧美日韩亚洲丝袜制服| 国产超碰在线一区| 水蜜桃久久夜色精品一区的特点| 欧美成人一区二区三区| 91蜜桃视频在线| 蜜臀av性久久久久av蜜臀妖精| 中文字幕+乱码+中文字幕一区| 欧美网站一区二区| 国产精品自拍毛片| 亚洲综合在线观看视频| 欧美成人一级视频| 在线免费观看不卡av| 黑人巨大精品欧美一区| 亚洲精品成a人| 亚洲国产精品精华液ab| 欧美一区二区在线观看| 成人av免费在线| 精品一区二区在线视频| 亚洲国产精品麻豆| ...av二区三区久久精品| 日韩免费高清电影| 91浏览器在线视频| 国产在线播放一区| 香蕉av福利精品导航| 自拍偷在线精品自拍偷无码专区 | 日韩欧美一二三| 99久久精品免费| 国产日本欧洲亚洲| 欧美日韩亚洲综合一区二区三区| 亚洲男人电影天堂| 久久精品这里都是精品| 欧美在线观看视频一区二区| 日韩成人伦理电影在线观看| 国产精品全国免费观看高清 | 欧美午夜电影一区| 成人免费看黄yyy456| 成人免费av在线| 在线视频欧美精品| 欧美一级精品大片| 粗大黑人巨茎大战欧美成人| 夜夜揉揉日日人人青青一国产精品 | 色av综合在线| 国产自产2019最新不卡| 麻豆精品久久久| 老司机免费视频一区二区| 亚洲成人在线观看视频| 一区二区三区免费在线观看| 亚洲精品国产a| 亚洲精品国产第一综合99久久| 日本一区二区三区在线观看| 337p日本欧洲亚洲大胆色噜噜| 在线成人av影院| 欧洲一区二区三区在线| 色拍拍在线精品视频8848| 99久久久国产精品| 色天天综合久久久久综合片| 色综合久久99| 在线精品视频小说1| 欧美亚洲国产一区二区三区va| 91网页版在线| 91在线观看美女| 国产一区在线精品| 精品在线免费视频| 看国产成人h片视频| 日韩一区二区三区免费看 | 91福利国产成人精品照片| 色综合久久九月婷婷色综合| 色老综合老女人久久久| 欧美视频在线不卡| 欧美一区二区三区小说| 欧美一区二区三区婷婷月色| 欧美一区午夜精品| 久久欧美中文字幕| 亚洲欧美一区二区在线观看| 亚洲一区中文日韩| 蜜臀av亚洲一区中文字幕|