JAVA里DES加密代碼改成Python代碼

最近公司產(chǎn)品需要重構(gòu),之前的2.0版本全部重新推到重做,產(chǎn)生了現(xiàn)今全新的3.0版本。所以我之前寫的自動化腳本也全部需要重寫。3.0版本與服務(wù)端的交互全部使用了全新的加密方式(DES加密+BSAE64加密+MD5加密),公司后臺是用java編寫,我的腳本使用Python編寫,故需要用Python對加密方式封裝一下,具體如下:

Java的DES加密(java)

//DES加密
public static String des_encrypt(String data, String key) {
    try {
        if (StringUtils.isBlank(key)) key = CONSTANTS._DES_PWD; 
        byte[] bt = encrypt(data.getBytes(CONSTANTS.UTF8), key.getBytes(CONSTANTS.UTF8));
        String strs = Base64.encodeBase64String(bt);
        return strs;
    }catch (Exception e){
        e.printStackTrace();
        return "";
    }
}

這里的邏輯是,如果傳入的key為空,則使用默認(rèn)的key,然后調(diào)用encrypt方法進(jìn)行des加密,后再用Base64加密,就算加密成功。

encrypt方法代碼(java):

private static byte[] encrypt(byte[] data, byte[] key) throws Exception {
    SecureRandom sr = new SecureRandom();
    DESKeySpec dks = new DESKeySpec(key);
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
    SecretKey securekey = keyFactory.generateSecret(dks);
    Cipher cipher = Cipher.getInstance("DES");
    cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
    return cipher.doFinal(data);
}

這里要注意的是 DESKeySpec() 類,看了下代碼,其規(guī)定了秘鑰的長度只能是8個字節(jié),大于8字節(jié)則只取前8個字節(jié)

這里java里DES加密采用的是默認(rèn)模式:ECB模式,采用 PKCS5Padding 的填充模式。故沒有初始化向量(如果是其他模式,需要加上初始化向量)

知曉了Java的代碼,則把他轉(zhuǎn)成Python。

Python代碼實現(xiàn):

# -*- coding:utf-8 -*-
import base64
import hashlib
from pyDes import des, ECB, PAD_PKCS5


class Encryption:
    def __init__(self, key):
        if key == '':
            self.key = "12345678"
        else:
            self.key = key
        self.key = self.key[0:8]  # 只取前8位

    def des_encrypt(self, data):
        """
        DES加密后再base64加密
        :param data: 原始數(shù)據(jù)
        :return: 返回des+base64加密后的字串
        """
        bt = self.encrypt(data)
        strs = bytes.decode(base64.b64encode(bt))
        return strs

    def encrypt(self, data):
        """
        DES 加密
        :param data: 原始字符串
        :return: 返回加密后的字符(byte)
        """
        k = des(self.key, ECB, padmode=PAD_PKCS5)
        en = k.encrypt(data, padmode=PAD_PKCS5)
        return en

這里使用了PyDes包,我直接取key的前8位(這里直接截取不知道是否有問題,但實際運行來看暫時沒碰到問題)。加密模式也是ECB模式,填充模式為PAD_PKCS5,測試一下兩邊一對比,能對上,OK!

注:兩邊的編碼需一致,這都是UTF8的編碼。另外,加密都是byte類型,需注意轉(zhuǎn)換

參考文章(感謝作者):http://blog.csdn.net/lihao21/article/details/78557461

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 概述 之前一直對加密相關(guān)的算法知之甚少,只知道類似DES、RSA等加密算法能對數(shù)據(jù)傳輸進(jìn)行加密,且各種加密算法各有...
    Henryzhu閱讀 3,208評論 0 14
  • 本文主要介紹移動端的加解密算法的分類、其優(yōu)缺點特性及應(yīng)用,幫助讀者由淺入深地了解和選擇加解密算法。文中會包含算法的...
    蘋果粉閱讀 11,673評論 5 29
  • 霜冽生寒,熏風(fēng)冷丶日暮霧靄云聚。滴滴春霖簌簌。一宿光陰難度。煩人心緒。更落寞丶靜思無語。泠侵衾被,孤枕獨眠,沉寂樓...
    SYD山藥蛋閱讀 217評論 0 0
  • 英國脫歐過去將近一個月了,全球金融市場翻云覆雨,最慘的莫過于英鎊,創(chuàng)下歷史最大跌幅,英鎊兌人民幣首次跌破9,為30...
    雙棒fengtaisb閱讀 353評論 1 2
  • 1.《我的寶貝》 也堪斬馬談方略,還是做陶看野花。 一個大雨將至的黃昏,我躺在湖邊的長椅上,手捧三毛的《我的寶貝》...
    唐紈閱讀 4,001評論 13 157

友情鏈接更多精彩內(nèi)容