日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

記一次Python與C#的AES加密對(duì)接

系統(tǒng) 1921 0

前言

這幾天做自動(dòng)化測(cè)試的同事找到我,說(shuō)是幫她看看有個(gè)AES加密的問(wèn)題要怎么處理。

大概就是文檔中貼了一段C#的AES加密代碼,然后她要翻譯成python的版本,去做一些測(cè)試相關(guān)的工作。

在我印象中,AES加密在不同語(yǔ)言中對(duì)接或多或少都有一點(diǎn)點(diǎn)不一樣,并不會(huì)像同一種一言那么流暢,總是要踩踩坑才能解決。

文檔中C#版本的實(shí)現(xiàn)

          
            public static string AesEncrypt(string toEncrypt, string key)
{
    byte[] keyArray = SHA256(key);
    byte[] toEncryptArray = Encoding.UTF8.GetBytes(toEncrypt);
    byte[] iv = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, };

    RijndaelManaged rDel = new RijndaelManaged
    {
        Key = keyArray,
        IV = iv,
        Mode = CipherMode.CBC,
        Padding = PaddingMode.PKCS7,
        BlockSize = 128
    };

    ICryptoTransform cTransform = rDel.CreateEncryptor();

    byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);

    return Convert.ToBase64String(resultArray, 0, resultArray.Length);
}

public static byte[] SHA256(string str)
{
    byte[] SHA256Data = Encoding.UTF8.GetBytes(str);
    SHA256Managed Sha256 = new SHA256Managed();
    byte[] by = Sha256.ComputeHash(SHA256Data);
    return by;
}
          
        

實(shí)現(xiàn)上都很常見,網(wǎng)上一搜也是一堆,重點(diǎn)在于 CBC 和 PKCS7。

對(duì)應(yīng)的Python版本

          
            from Crypto.Cipher import AES
import base64
import hashlib

def jm_sha256(data):
    sha256 = hashlib.sha256()
    sha256.update(data.encode("utf-8"))    
    res = sha256.digest()
    # print("sha256加密結(jié)果:", res)
    return res

def pkcs7padding(text):

    bs = AES.block_size 
    length = len(text)
    bytes_length = len(bytes(text, encoding='utf-8'))

    # tips:utf-8編碼時(shí),英文占1個(gè)byte,而中文占3個(gè)byte
    padding_size = length if(bytes_length == length) else bytes_length
    padding = bs - padding_size % bs

    # tips:chr(padding)看與其它語(yǔ)言的約定,有的會(huì)使用'\0'
    padding_text = chr(padding) * padding
    return text + padding_text

def aes_encrypt_v2(content, key):

    key_bytes = jm_sha256(key)
    iv = "\0".encode("utf-8") * 16

    aes = AES.new(key_bytes, AES.MODE_CBC, iv)

    content_padding = pkcs7padding(content)

    encrypt_bytes = aes.encrypt(bytes(content_padding, encoding='utf-8'))

    result = str(base64.b64encode(encrypt_bytes), encoding='utf-8')
    return result


mystr1 = "123"
mykey1 = "12345678"

# 3gVLeGnili1JBTYLHAk8pQ==
print(aes_encrypt_v2(mystr1, mykey1))

mystr2 = "你好abcd1234"
mykey2 = "1234567812345678"

# Qkz+MXCIESJZVgHJffouTQ==
print(aes_encrypt_v2(mystr2, mykey2))
          
        

參考文章

  • python3 AES 加密

更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 襄城县| 德保县| 敦化市| 武隆县| 吐鲁番市| 调兵山市| 晋州市| 香格里拉县| 灵山县| 贡嘎县| 宁波市| 林口县| 昭苏县| 金阳县| 交城县| 保靖县| 如东县| 遂宁市| 新宾| 衡南县| 玛纳斯县| 阿坝县| 海兴县| 穆棱市| 明水县| 鄱阳县| 嘉祥县| 宜兰市| 林甸县| 邯郸市| 福鼎市| 凤阳县| 平舆县| 保靖县| 柳河县| 邯郸市| 怀化市| 西华县| 南召县| 牙克石市| 北票市|