CryptoJS與C#AES加解密互轉
轉載連線:https://www.cnblogs.com/wz122889488/p/6899615.html
頁面js引用:
<script type="text/javascript" src="/content/plugin/CryptoJSv3.1.2/components/core-min.js"></script>
<script type="text/javascript" src="/content/plugin/CryptoJSv3.1.2/rollups/aes.js"></script>
JS端AES加密解密:
/**************************************************************
*字串加密
* str:需要加密的字串
****************************************************************/
function Encrypt(str) {
var KEY = "12345678900000001234567890000000";//32位
var IV = "1234567890000000";//16位
var key = CryptoJS.enc.Utf8.parse(KEY);
var iv = CryptoJS.enc.Utf8.parse(IV);
var encrypted = '';
var srcs = CryptoJS.enc.Utf8.parse(str);
encrypted = CryptoJS.AES.encrypt(srcs, key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7
});
return encrypted.ciphertext.toString();
}
/**************************************************************
*字串解密
* str:需要解密的字串
****************************************************************/
function Decrypt(str) {
var KEY = "12345678900000001234567890000000";//32位
var IV = "1234567890000000";//16位
var key = CryptoJS.enc.Utf8.parse(KEY);
var iv = CryptoJS.enc.Utf8.parse(IV);
var encryptedHexStr = CryptoJS.enc.Hex.parse(str);
var srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
var decrypt = CryptoJS.AES.decrypt(srcs, key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7
});
var decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
return decryptedStr.toString();
}
C# AES加密解密:
const string AES_IV = "1234567890000000";//16位
/// <summary>
/// AES加密演算法
/// </summary>
/// <param name="input">明文字串</param>
/// <param name="key">金鑰(32位)</param>
/// <returns>字串</returns>
public static string EncryptByAES(string input, string key)
{
byte[] keyBytes = Encoding.UTF8.GetBytes(key.Substring(0, 32));
using (AesCryptoServiceProvider aesAlg = new AesCryptoServiceProvider())
{
aesAlg.Key = keyBytes;
aesAlg.IV = Encoding.UTF8.GetBytes(AES_IV.Substring(0, 16));
ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);
using (MemoryStream msEncrypt = new MemoryStream())
{
using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
{
using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
{
swEncrypt.Write(input);
}
byte[] bytes = msEncrypt.ToArray();
return ByteArrayToHexString(bytes);
}
}
}
}
/// <summary>
/// AES解密
/// </summary>
/// <param name="input">密文位元組陣列</param>
/// <param name="key">金鑰(32位)</param>
/// <returns>返回解密後的字串</returns>
public static string DecryptByAES(string input, string key)
{
byte[] inputBytes = HexStringToByteArray(input);
byte[] keyBytes = Encoding.UTF8.GetBytes(key.Substring(0, 32));
using (AesCryptoServiceProvider aesAlg = new AesCryptoServiceProvider())
{
aesAlg.Key = keyBytes;
aesAlg.IV = Encoding.UTF8.GetBytes(AES_IV.Substring(0, 16));
ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);
using (MemoryStream msEncrypt = new MemoryStream(inputBytes))
{
using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, decryptor, CryptoStreamMode.Read))
{
using (StreamReader srEncrypt = new StreamReader(csEncrypt))
{
return srEncrypt.ReadToEnd();
}
}
}
}
}
/// <summary>
/// 將指定的16進位制字串轉換為byte陣列
/// </summary>
/// <param name="s">16進位制字串(如:“7F 2C 4A”或“7F2C4A”都可以)</param>
/// <returns>16進位制字串對應的byte陣列</returns>
public static byte[] HexStringToByteArray(string s)
{
s = s.Replace(" ", "");
byte[] buffer = new byte[s.Length / 2];
for (int i = 0; i < s.Length; i += 2)
buffer[i / 2] = (byte)Convert.ToByte(s.Substring(i, 2), 16);
return buffer;
}
/// <summary>
/// 將一個byte陣列轉換成一個格式化的16進位制字串
/// </summary>
/// <param name="data">byte陣列</param>
/// <returns>格式化的16進位制字串</returns>
public static string ByteArrayToHexString(byte[] data)
{
StringBuilder sb = new StringBuilder(data.Length * 3);
foreach (byte b in data)
{
//16進位制數字
sb.Append(Convert.ToString(b, 16).PadLeft(2, '0'));
//16進位制數字之間以空格隔開
//sb.Append(Convert.ToString(b, 16).PadLeft(2, '0').PadRight(3, ' '));
}
return sb.ToString().ToUpper();
}
用法:
Encrypt("2017-05")//結果:68f4a7903a9fe6085d2301ac68cc039c Decrypt("68f4a7903a9fe6085d2301ac68cc039c")//結果:2017-05
//加密 string str1 = Encrypt.EncryptByAES("2017-05", "12345678900000001234567890000000"); //解密 string str2 = Encrypt.DecryptByAES("68f4a7903a9fe6085d2301ac68cc039c", "12345678900000001234567890000000");
相關文章
- CryptoJs 使用 AES CBC 加解密資料JS解密
- Buffer 與 Mat 互轉
- QImage 與 Mat 互轉
- Json物件與Json字串互轉JSON物件字串
- Java中List與陣列互轉Java陣列
- Linux軟體包轉換-deb與rpm互轉Linux
- Python/Java AES 加解密方法互相轉換PythonJava解密
- C++ string互轉wstring/Unicode互轉ANSI/Unicode互轉UTF8C++Unicode
- 記一次前端CryptoJS AES解密前端JS解密
- SpringBootDateString互轉Spring Boot
- JavaScript 字串與json物件互轉的幾種方法JavaScript字串JSON物件
- RN與原生互動(一)——基本頁面跳轉
- C++中UNIX時間戳與日期互轉C++時間戳
- HarmonyOS Next 金鑰轉換技巧:提升加解密靈活性解密
- 【Java加解密系列】- SM2加解密Java解密
- 前端加解密前端解密
- 凱撒密碼加解密過程與破解原理密碼解密
- String 和Inputstreem互轉
- Egg.js+MongoDB開發小程式介面 (三) 與微信伺服器互動及使用者資訊加解密JSMongoDB伺服器解密
- PHP 和 Web 端對稱加密傳輸|JSEncrypt|CryptoJSPHPWeb加密JS
- PDF 和圖片互轉
- oracle和sqlserver互訪(轉)OracleSQLServer
- Linux下域名IP互轉Linux
- chrome語音文字互轉Chrome
- Java與WCF互動(一):Java客戶端呼叫WCF服務 (轉)Java客戶端
- 客戶端加解密客戶端解密
- NodeJS加解密之CryptoNodeJS解密
- 加解密演算法解密演算法
- Java中List陣列互轉Java陣列
- gps wgs4座標與高德gcj02座標互轉GC
- js 與WKWebView 互動JSWebView
- Java之DES加解密解析Java解密
- Java之RSA加解密解析Java解密
- 加解密演算法分析解密演算法
- 遊戲異或加解密遊戲解密
- 對稱EDS加解密方法解密
- python各種加解密方法Python解密
- C++ UTF8 互轉 UnicodeC++Unicode