日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

密码技术应用--AES文件加解密

發布時間:2025/3/21 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 密码技术应用--AES文件加解密 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

記錄一下對一些稍大文件進行AES加解密的實現,這里只列出了核心代碼,其他不涉及的代碼或者有任何疑問可以查看我之前寫的密碼技術專題博客

var key = []byte("1234567812345678") var iv = []byte("1111111122222222")/* 函數名: paddingLastGroup對 CBC 加密模式的加密算法提供最后一個分塊的明文數據填充 參 數:plainText , 明文數據blockSize , CBC 分塊大小 返回值:填充后的明文數據 創建時間及創建者:2021-06-15 Yuan_sr */ func paddingLastGroup(plainText []byte, blockSize int) []byte{padNum := blockSize - len(plainText) % blockSizechar := []byte{byte(padNum)}newPlain := bytes.Repeat(char, padNum)newText := append(plainText, newPlain...)return newText }/* 函數名: unpaddingLastGroup對 CBC 加密模式的加密算法提供最后一個分塊的明文數據去填充 參 數:plainText , 明文數據 返回值:去填充后的明文數據 創建時間及創建者:2021-06-15 Yuan_sr */ func unpaddingLastGroup(plainText []byte) []byte{length := len(plainText)lastChar := plainText[length - 1]number := int(lastChar)return plainText[:length - number] }/* 函數名: aesEnctrptaes 加密算法實現對文件的加密 參 數:filePathIn , 待加密文件key , 加密密鑰 返回值:加密后密文文件名錯誤信息 創建時間及創建者:2021-06-15 Yuan_sr */ func aesEnctrpt(filePathIn string, key []byte) (string, error){inFile, err := os.Open(filePathIn)if err != nil {return "", err}defer inFile.Close()fileInfo, err := inFile.Stat()if err != nil {return "", err}blockNum := fileInfo.Size() / bufferSizevar num int64outFile, err := os.Create(encryptFileName)if err != nil {return "", err}defer outFile.Close()buf := make([]byte, bufferSize)//初始化一個底層加密算法block, err := aes.NewCipher(key)if err != nil {return "", err}//選擇加密模式//stream := cipher.NewCTR(block, iv)blockMode := cipher.NewCBCEncrypter(block, iv)for {num += 1n, err := inFile.Read(buf)if err == io.EOF{break}if err != nil && err != io.EOF {return "", err}//判斷時最后一段數據則進行數據填充if num == blockNum + 1{groupData := paddingLastGroup(buf[:n], block.BlockSize())n = len(groupData)buf = make([]byte, n)buf = groupData}cipherText := make([]byte, n)//stream.XORKeyStream(cipherText, buf[:n])blockMode.CryptBlocks(cipherText, buf[:n])_, err = outFile.Write(cipherText)if err != nil {return "", err}}//outFile.Write(iv)return encryptFileName, nil }/* 函數名: aesDecryptaes 解密算法實現對文件的解密 參 數:cipherFile , 密文文件key , 解密密鑰 返回值:解密后文件名錯誤信息 創建時間及創建者:2021-06-15 Yuan_sr */ func aesDecrypt(cipherFile string, key []byte) (string, error){plainFileName = "plainText.file"//1.創建一個aes底層密碼接口block, err := aes.NewCipher(key)if err != nil {return "", err}//2.選擇解密模式blockMode := cipher.NewCBCDecrypter(block, iv)//3.解密fr, err := os.Open(dvOutPath + cipherFile)if err != nil {return "", err}defer fr.Close()fileInfo, err := fr.Stat()if err != nil {return "", err}blockNum := fileInfo.Size() / bufferSizevar num int64fw, err := os.Create(plainFileName)if err != nil {return "", err}defer fw.Close()buf := make([]byte, bufferSize)for {num += 1n, err := fr.Read(buf)if err == io.EOF{break}if err != nil && err != io.EOF {return "", err}plainText := make([]byte, n)blockMode.CryptBlocks(plainText, buf[:n])//判斷時最后一段數據則進行數據去填充if num == blockNum + 1{plainText = unpaddingLastGroup(plainText)n = len(plainText)}_, err = fw.Write(plainText[:n])if err != nil {return "", err}}return plainFileName, nil }

總結

以上是生活随笔為你收集整理的密码技术应用--AES文件加解密的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。