91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

前端vue+element使用SM4國密加密解密的方法是什么

發布時間:2023-03-02 10:03:13 來源:億速云 閱讀:171 作者:iii 欄目:開發技術

這篇文章主要講解了“前端vue+element使用SM4國密加密解密的方法是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“前端vue+element使用SM4國密加密解密的方法是什么”吧!

    項目環境:

    vue2+element進行開發,看懂了下文,其他框架使用該功能,也是同理了。

    國密擴展了解概述

    1.SM算法

    國密即國家密碼局認定的國產密碼算法。主要有SM1,SM2,SM3,SM4。密鑰長度和分組長度均為128位。

    SM1 為對稱加密。其加密強度與AES相當。該算法不公開,調用該算法時,需要通過加密芯片的接口進行調用。

    SM2為非對稱加密,基于ECC。該算法已公開。由于該算法基于ECC,故其簽名速度與秘鑰生成速度都快于RSA。ECC 256位(SM2采用的就是ECC 256位的一種)安全強度比RSA 2048位高,但運算速度快于RSA。

    SM3 消息摘要。可以用MD5作為對比理解。該算法已公開。校驗結果為256位。

    SM4 無線局域網標準的分組數據算法。對稱加密,密鑰長度和分組長度均為128位。

    2.sm4加密有兩種模式:ecb和cbc。兩種模式的區別如下(下面文字來自百度):

    ECB:是一種基礎的加密方式,密文被分割成分組長度相等的塊(不足補齊),然后單獨一個個加密,一個個輸出組成密文。

    CBC:是一種循環模式(鏈式),前一個分組的密文和當前分組的明文操作后再加密,這樣做的目的是增強破解難度。(不容易主動攻擊,安全性好于ECB,是SSL、IPSec的標準)

    一、優bai點不同:

    ECB模式:1、簡單;2、有利于并行計算;3、誤差不會bai被傳送;
    CBC模式:1、不容易主動攻擊,安全性好于baiECB,適合傳輸長度長的報文,是SSL、IPSec的標準。

    二、缺點不同:

    ECB模式:1、不能隱藏明文的模式;2、可能對明文進行主動攻擊;

    CBC模式:1、不利于并行計算;2、誤差傳遞;3、需要初始化向量IV

    方案一,代碼直接使用

    1、安裝加密gm-crypt依賴

    npm install gm-crypt

    2、在表單提交方法內,直接添加下面提供的代碼,適合使用次數頻率少的情況下使用。
    代碼例子:

    checkPassword() {
      this.$refs.formPass.validate(valid => {
          if (valid) {
              // 引用sm4包進行加密
              const SM4 = require("gm-crypt").sm4;
              let sm4Config = {
                  //配置sm4參數
                  key: "GJwsXX_BzW=gJWJW", //這里這個key值要與后端的一致,后端解密是根據這個key
                  mode: "cbc", // 加密的方式有兩種,ecb和cbc兩種,這里使用的是cbc,cbc模式還要加一個iv的參數,ecb不用
                  iv: "ZkR_SiNoSOFT=568", //iv是cbc模式的第二個參數,也需要跟后端配置的一致
                  cipherType: "base64" //
              };
              let sm4 = new SM4(sm4Config); //new一個sm4函數,將上面的sm4Config作為參數傳遞進去。
              accountCenterService.checkVerificationCode({
                  newPassword: sm4.encrypt(this.formPass.newPassword) //加密處理明文密碼
              }).then(res => {
                  if (res.code === STATUSCODE.code01) {
                      this.dialogVisible = false;
                  }else{
                      this.$message.error(res.msg)
                  }
              });
          }
      });
    },

    方案二,封裝版,作為公共方法調用

    將處理的函數代碼封裝,然后把加密和解密的方法導出去,作為公共方法調用,方便多處使用,然后在代碼中引入調用即可。便于維護后后期使用。
    1、同樣也是先安裝加密gm-crypt依賴

    npm install gm-crypt

    2、在項目的utils目錄下,新建一個sm4Util.js作為公共文件使用,

    const SM4 = require("gm-crypt").sm4;
    const pwdKey = "GJstSK_YBD=gSOFT"; //"GJstSK_YBD=gSOFT"; 密鑰  前后端一致即可,后端提供
    let sm4Config = {
          key: pwdKey, //這里這個key值要與后端的一致,后端解密是根據這個key
          mode: "ecb",  // 加密的方式有兩種,ecb和cbc兩種,也是看后端如何定義的,不過要是cbc的話下面還要加一個iv的參數,ecb不用
          iv: '1234567891011121', //iv是cbc模式的第二個參數,也需要跟后端配置的一致 iv是initialization vector的意思,就是加密的初始話矢量,初始化加密函數的變量,也叫初始向量。(本來應該動態生成的,由于項目沒有嚴格的加密要求,直接寫死一個)
          cipherType: "base64"
        };
    
    const sm4Util = new SM4(sm4Config); // new一個sm4函數,將上面的sm4Config作為參數傳遞進去。
        
    /* 
     * 加密工具函數
     * @param {String} text 待加密文本
     */
    export function encrypt(text) {
      return sm4Util.encrypt(text, pwdKey);
    }
    
    /*
     * 解密工具函數
     * @param {String} text 待解密密文
     */
     export function decrypt(text) {
      return sm4Util.decrypt(text, pwdKey);
    }

    3、引入sm4Util.js

    import {encrypt,decrypt} from "./sm4Util.js" //引入sm4.js  相對路徑

    4、在組件中調用對應的方法,將需要進行加密的數據,放入加密方法處理,
    例子:

    // SM4加密傳輸開始-----------------------
    const user = 'admin'; // 用戶名
    const pass = '123456'; // 密碼
    // 開始加密  用戶名密碼
    const usernameSM4 = encrypt(user); //加密后的用戶名
    const passwordSM4 = encrypt(pass); //加密后的密碼

    感謝各位的閱讀,以上就是“前端vue+element使用SM4國密加密解密的方法是什么”的內容了,經過本文的學習后,相信大家對前端vue+element使用SM4國密加密解密的方法是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    疏附县| 沂源县| 称多县| 新津县| 勐海县| 灌云县| 界首市| 新余市| 东光县| 竹山县| 同心县| 中牟县| 台江县| 喀什市| 安平县| 竹山县| 陇川县| 湖州市| 伊吾县| 大厂| 环江| 马关县| 岳池县| 河西区| 灵武市| 罗定市| 南丹县| 连江县| 屏东县| 安仁县| 扶余县| 巴青县| 巴彦淖尔市| 临邑县| 镇宁| 即墨市| 阿克陶县| 广德县| 泰和县| 灌阳县| 秦安县|