DES加密解密 與php後端加密解密互通

測試工具 apiPost 可以百度下載使用

DES加密解密
前端加密使用CryptoJS插件

function encrypt(str, key, iv) {
    var encode_str = '';
    var key = CryptoJS.MD5(key).toString();
    var iv = CryptoJS.MD5(iv).toString();
    var crypto_key = CryptoJS.enc.Utf8.parse(key);
    var crypto_iv = CryptoJS.enc.Utf8.parse(iv.substr(0, 8));
    if (typeof (word) == 'string') {
        encode_str = CryptoJS.TripleDES.encrypt(str, crypto_key, {
            iv: crypto_iv,
            mode: CryptoJS.mode.CBC,
            padding: CryptoJS.pad.Pkcs7
        });
    } else {
        encode_str = CryptoJS.TripleDES.encrypt(JSON.stringify(str), crypto_key, {
            iv: crypto_iv,
            mode: CryptoJS.mode.CBC,
            padding: CryptoJS.pad.Pkcs7
        });
    }
    return encode_str.toString();
}

function decrypt(str, key, iv) {
    var key = CryptoJS.MD5(key).toString();
    var iv = CryptoJS.MD5(iv).toString();
    var crypto_key = CryptoJS.enc.Utf8.parse(key);
    var crypto_iv = CryptoJS.enc.Utf8.parse(iv.substr(0, 8));
    var decrypt_str = CryptoJS.TripleDES.decrypt(str, crypto_key, {
        iv: crypto_iv,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7
    });
    return decrypt_str.toString(CryptoJS.enc.Utf8);
}

前端加密解密示例

console.log(encrypt({data: 1,dasd:5}, '1234567887654321', '1234567887654321'))
console.log(decrypt('4IN6uvgqsIIgcjW0pZg2J8Ir3LLz1lBF','1234567887654321', '1234567887654321'))

密碼與iv都是16位數的

後端php DES加密解密

<?php


namespace Des;


class Des
{

    public static function decrypt($data, $key, $iv)
    {
        $data = base64_decode($data);
        $key = md5($key);        
        $iv = substr(md5($iv), 0, 8);        //取前8位

        $decrypted = openssl_decrypt($data, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA, $iv);
        return $decrypted;
    }

    public static function encrypt($str, $key, $iv)
    {
        $key = md5($key);        
        $iv = substr(md5($iv), 0, 8);        //取前8位

        $data = base64_encode(openssl_encrypt($str, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA, $iv));
        return $data;
    }
    
}

後端調用加密解密

在這裏插入圖片描述

接口測試

我們先用後端php加密字符串1,把加密的密文複製到js中看看是否可以解密?

在這裏插入圖片描述

結果是p0U/1VSUkLs=

我們將其複製粘貼到des加密解密的js中,看看

在這裏插入圖片描述

已複製好,注意密匙要與後端一致

在這裏插入圖片描述

成功解密 出來1

DES加密解密php 與js前端相同已經OK

AES加密解密
前端aes加密解密代碼

function encrypt(data, key, iv) {
      let encrypted = '';
      let text = data;
      text = CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(text)).toString();
      key = CryptoJS.enc.Utf8.parse(key); /*爲了避免補位,直接用16位的祕鑰*/
      iv = CryptoJS.enc.Utf8.parse(iv); /*16位初始向量*/
      if (typeof (word) == 'string') {
          encrypted = CryptoJS.AES.encrypt(text, key, {
              iv: iv,
              mode: CryptoJS.mode.CBC,
              padding: CryptoJS.pad.ZeroPadding
          }).toString();
      } else {
          encrypted = CryptoJS.AES.encrypt(JSON.stringify(text), key, {
              iv: iv,
              mode: CryptoJS.mode.CBC,
              padding: CryptoJS.pad.ZeroPadding
          }).toString();
      }
      return CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(encrypted)).toString();
  }

  function decrypt(data, key, iv) {
      let encrypted = CryptoJS.enc.Utf8.stringify(CryptoJS.enc.Base64.parse(data)).toString();
      key = CryptoJS.enc.Utf8.parse(key); /*爲了避免補位,直接用16位的祕鑰*/
      iv = CryptoJS.enc.Utf8.parse(iv); /*16位初始向量*/
      let decrypted = CryptoJS.AES.decrypt(encrypted, key, {
          iv: iv,
          mode: CryptoJS.mode.CBC,
          padding: CryptoJS.pad.ZeroPadding
      }).toString(CryptoJS.enc.Utf8);
      return CryptoJS.enc.Utf8.stringify(CryptoJS.enc.Base64.parse(decrypted)).toString();
  }

前端aes加密解密示例

console.log(encrypt({data: 2,json: 1},'1234567887654321','1234567887654321'))
console.log(decrypt('SlNnR0diZkxuUml1Uk5oQ0EwQUVYbVNTQmVSZ2dUUkhlTUd0VVlGWGlCeGE5SmxRdm5zblJDUkRiNVJYNkl4Mg==','1234567887654321','1234567887654321'))

結果

在這裏插入圖片描述

後端aes加密解密代碼

<?php

namespace Aes;

class Aes
{

    public function encrypt($data, $key, $iv)
    {
        $base64_str = base64_encode(json_encode($data));
        $encrypted = openssl_encrypt($base64_str, "aes-128-cbc", $key, OPENSSL_ZERO_PADDING, $iv);
        return base64_encode($encrypted);
    }


    public function decrypt($data, $key, $iv)
    {
        $encrypted = base64_decode($data);
        $decrypted = openssl_decrypt($encrypted, 'aes-128-cbc', $key, OPENSSL_ZERO_PADDING, $iv);
        return json_decode(base64_decode($decrypted), true);
    }

}

調用示例

public function decryptAes(Request $request)
    {
        $aes = new Aes();
        $post = $request->post();
        $data = $aes->decrypt($post['data'], '1234567887654321', '1234567887654321');
        return callJson::back(200, 'aes解密結果', $data);
    }

    public function encryptAes(Request $request)
    {
        $aes = new Aes();
        $post = $request->post();
        $str = $aes->encrypt(['username' => 'admin', 'pwd' => 'admin'], '1234567887654321', '1234567887654321');
        return callJson::back(200, 'aes加密結果', $str);
    }

結果

在這裏插入圖片描述
在這裏插入圖片描述

同des一樣,我們將後端接口加密的密文複製到js中看看是否可以解密?

console.log(decrypt(‘SlNnR0diZkxuUml1Uk5oQ0EwQUVYbVNTQmVSZ2dUUkhlTUd0VVlGWGlCeGE5SmxRdm5zblJDUkRiNVJYNkl4Mg==’,‘1234567887654321’,‘1234567887654321’))
查看結果

在這裏插入圖片描述

解密是相通的至此,des與aes加密解密前端後端的統一就都OK了,本篇文章中所有的密匙都是一樣的,位數是做過處理的,比如des加密,會將密匙 md5,然後截取前8位,這樣aes與des可以用同一對密碼和iv,如果項目中有需要用到aes和des加密的,可以看看這篇文章參考參考。

文章原文地址:DES加密解密 與php後端加密解密互通

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章