欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何使用sm4js進(jìn)行加密和國密sm4總結(jié)

 更新時(shí)間:2023年04月28日 09:21:51   作者:時(shí)清云  
近期由于公司項(xiàng)目的需要開始研究國密SM4加密,下面這篇文章主要給大家介紹了關(guān)于如何使用sm4js進(jìn)行加密和國密sm4的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

最近在開發(fā)過程中,用到了sm4國密加密,因?yàn)橹皼]有用過,所以就想總結(jié)一下。

先說一下怎么安裝使用(vue項(xiàng)目)

1、先安裝sm4js

npm i sm4js

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

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

2、安裝完成之后在項(xiàng)目中怎么使用

<script>
  import Sm4js from 'sm4js';
  export default {
    name: 'color',
    ...
    methods:{
      getKey(){
        let sm4Config = {
          key: this.key, // 密鑰  前后端一致即可,后端提供,一般通過接口請(qǐng)求獲取到
          iv: this.iv, // iv是initialization vector的意思,就是加密的初始話矢量,初始化加密函數(shù)的變量,也叫初始向量。一般通過接口請(qǐng)求獲取到
          mode: 'cbc', // 加密的方式有兩種,ecb和cbc兩種
          cipherType: 'base64'
        }
        let sm4 = new Sm4js(sm4Config)
        // 對(duì)數(shù)據(jù)進(jìn)行加密   encrypt - 加密方法
        this.encrypted = sm4.encrypt(this.cardId)
        // 對(duì)數(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 為對(duì)稱加密。其加密強(qiáng)度與AES相當(dāng)。該算法不公開,調(diào)用該算法時(shí),需要通過加密芯片的接口進(jìn)行調(diào)用。

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

SM3 消息摘要。可以用MD5作為對(duì)比理解。該算法已公開。校驗(yàn)結(jié)果為256位。

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

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

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

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

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

兩種模式的概念不同

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

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

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

ECB模式:1、簡(jiǎn)單;2、有利于并行計(jì)算;3、誤差不會(huì)bai被傳送;

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

兩種模式的缺點(diǎn)

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

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

總結(jié)

到此這篇關(guān)于如何使用sm4js進(jìn)行加密和國密sm4的文章就介紹到這了,更多相關(guān)sm4js加密和國密sm4內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決element-ui的el-select選擇器的@blur事件失效的坑

    解決element-ui的el-select選擇器的@blur事件失效的坑

    這篇文章主要介紹了解決element-ui的el-select選擇器的@blur事件失效的坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue組件系列之TagsInput詳解

    vue組件系列之TagsInput詳解

    TagsInput 是一種可編輯的輸入框,通過回車或者分號(hào)來分割每個(gè)標(biāo)簽,用回退鍵刪除上一個(gè)標(biāo)簽。這篇文章主要介紹了vue組件TagsInput的相關(guān)知識(shí),需要的朋友可以參考下
    2020-05-05
  • vue項(xiàng)目實(shí)現(xiàn)通過ip地址訪問和localhost訪問方式

    vue項(xiàng)目實(shí)現(xiàn)通過ip地址訪問和localhost訪問方式

    這篇文章主要介紹了vue項(xiàng)目實(shí)現(xiàn)通過ip地址訪問和localhost訪問方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue中使用@blur獲取input?val值

    vue中使用@blur獲取input?val值

    這篇文章主要介紹了vue中使用@blur獲取input?val值的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue中各選項(xiàng)及鉤子函數(shù)執(zhí)行順序詳解

    vue中各選項(xiàng)及鉤子函數(shù)執(zhí)行順序詳解

    今天小編就為大家分享一篇vue中各選項(xiàng)及鉤子函數(shù)執(zhí)行順序詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue?3.0?項(xiàng)目創(chuàng)建過程及解決方案

    Vue?3.0?項(xiàng)目創(chuàng)建過程及解決方案

    這篇文章主要介紹了Vue?3.0?項(xiàng)目創(chuàng)建過程,首先要確保電腦上已安裝node.js,確保已安裝?Vue?CLI,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-04-04
  • vue中v-for指令完成列表渲染

    vue中v-for指令完成列表渲染

    這篇文章主要給大家分享的是vue中v-for指令完成列表渲染,下面文化章就圍繞中v-for的相關(guān)資料在Vue中列表渲染做個(gè)簡(jiǎn)單總結(jié)和使用演示,需要的朋友可以參考一下,希望對(duì)大家有所幫助
    2021-11-11
  • Vue使用axios圖片上傳遇到的問題

    Vue使用axios圖片上傳遇到的問題

    后端寫個(gè)上傳圖片的接口可不是很簡(jiǎn)單,只需要讓這個(gè)字段限制為圖片格式,后臺(tái)做個(gè)保存的邏輯就完事了,前端處理還要牽扯到請(qǐng)求頭,數(shù)據(jù)格式的處理等等問題,按照老傳統(tǒng)把圖片按照字符串往接口put發(fā)現(xiàn)返回的全是400錯(cuò)誤,直到我知道了前端的FormData方法!
    2021-05-05
  • VUE3+vite項(xiàng)目中動(dòng)態(tài)引入組件與異步組件的詳細(xì)實(shí)例

    VUE3+vite項(xiàng)目中動(dòng)態(tài)引入組件與異步組件的詳細(xì)實(shí)例

    在做vue3項(xiàng)目中時(shí),每次使用都需要先進(jìn)行引入,下面這篇文章主要給大家介紹了關(guān)于VUE3+vite項(xiàng)目中動(dòng)態(tài)引入組件與異步組件的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • vue使用csp的簡(jiǎn)單示例

    vue使用csp的簡(jiǎn)單示例

    Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式框架,與其它大型框架不同的是,Vue被設(shè)計(jì)為可以自底向上逐層應(yīng)用,下面這篇文章主要給大家介紹了關(guān)于vue使用csp的相關(guān)資料,需要的朋友可以參考下
    2022-08-08

最新評(píng)論