溫馨提示×

溫馨提示×

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

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

怎么使用sm4js進(jìn)行加密和國密sm4

發(fā)布時間:2023-04-28 10:27:52 來源:億速云 閱讀:110 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“怎么使用sm4js進(jìn)行加密和國密sm4”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“怎么使用sm4js進(jìn)行加密和國密sm4”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

1、先安裝sm4js

npm i sm4js

在package.json中顯示sm4js的版本如下:

"dependencies": {
   "axios": "^1.3.2",
   "sm4js": "^0.0.6"
},

2、安裝完成之后在項目中怎么使用

<script>
  import Sm4js from 'sm4js';
  export default {
    name: 'color',
    ...
    methods:{
      getKey(){
        let sm4Config = {
          key: this.key, // 密鑰  前后端一致即可,后端提供,一般通過接口請求獲取到
          iv: this.iv, // iv是initialization vector的意思,就是加密的初始話矢量,初始化加密函數(shù)的變量,也叫初始向量。一般通過接口請求獲取到
          mode: 'cbc', // 加密的方式有兩種,ecb和cbc兩種
          cipherType: 'base64'
        }
        let sm4 = new Sm4js(sm4Config)
        // 對數(shù)據(jù)進(jìn)行加密   encrypt - 加密方法
        this.encrypted = sm4.encrypt(this.cardId)
        // 對數(shù)據(jù)進(jìn)行解密   decrypt - 解密方法
        this.decrypted = sm4.decrypt(this.idCardNumber)
      }
    }
  }
</script>

3、國密sm4的總結(jié)

3.1 、SM算法

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

SM1 為對稱加密。其加密強(qiáng)度與AES相當(dāng)。該算法不公開,調(diào)用該算法時,需要通過加密芯片的接口進(jìn)行調(diào)用。

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

SM3 消息摘要??梢杂肕D5作為對比理解。該算法已公開。校驗結(jié)果為256位。

SM4 無線局域網(wǎng)標(biāo)準(zhǔn)的分組數(shù)據(jù)算法。對稱加密,密鑰長度和分組長度均為128位。

3.2 、SM4加密有兩種模式:ecb和cbc

兩種模式的區(qū)別如下

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

CBC:是一種循環(huán)模式(鏈?zhǔn)剑耙粋€分組的密文和當(dāng)前分組的明文操作后再加密,這樣做的目的是增強(qiáng)破解難度。(不容易主動攻擊,安全性好于ECB,是SSL、IPSec的標(biāo)準(zhǔn))

兩種模式的概念不同

1、ECB模式又稱電子密碼本模式:Electronic codebook,是最簡單的塊密碼加密模式,加密前根據(jù)加密塊大?。ㄈ鏏ES為128位)分成若干塊,之后將每塊使用相同的密鑰單獨加密,解密同理。

2、密碼分組鏈接(CBC,Cipher-block chaining)模式,由IBM于1976年發(fā)明,每個明文塊先與前一個密文塊進(jìn)行異或后,再進(jìn)行加密。在這種方法中,每個密文塊都依賴于它前面的所有明文塊。同時,為了保證每條消息的唯一性,在第一個塊中需要使用初始化向量IV。

兩種模式的優(yōu)點

ECB模式:1、簡單;2、有利于并行計算;3、誤差不會bai被傳送;

CBC模式:1、不容易主動攻擊,安全性好于baiECB,適合傳輸長度長的報文,是SSL、IPSec的標(biāo)準(zhǔn)。

兩種模式的缺點

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

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

讀到這里,這篇“怎么使用sm4js進(jìn)行加密和國密sm4”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

sm4
AI