如何使用sm4js進(jìn)行加密和國(guó)密sm4總結(jié)
最近在開發(fā)過程中,用到了sm4國(guó)密加密,因?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、國(guó)密sm4的總結(jié)
3.1 、SM算法
國(guó)密即國(guó)家密碼局認(rèn)定的國(guó)產(chǎn)密碼算法。主要有SM1,SM2,SM3,SM4。密鑰長(zhǎng)度和分組長(zhǎng)度均為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 消息摘要??梢杂肕D5作為對(duì)比理解。該算法已公開。校驗(yàn)結(jié)果為256位。
SM4 無線局域網(wǎng)標(biāo)準(zhǔn)的分組數(shù)據(jù)算法。對(duì)稱加密,密鑰長(zhǎng)度和分組長(zhǎng)度均為128位。
3.2 、SM4加密有兩種模式:ecb和cbc
兩種模式的區(qū)別如下:
ECB:是一種基礎(chǔ)的加密方式,密文被分割成分組長(zhǎng)度相等的塊(不足補(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,適合傳輸長(zhǎng)度長(zhǎng)的報(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)行加密和國(guó)密sm4的文章就介紹到這了,更多相關(guān)sm4js加密和國(guó)密sm4內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue+Echarts實(shí)現(xiàn)基本K線圖的繪制
這篇文章主要為大家詳細(xì)介紹了如何利用Vue和Echarts實(shí)現(xiàn)基本K線圖的繪制,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-03-03
VUE+elementui組件在table-cell單元格中繪制微型echarts圖
這篇文章主要介紹了VUE+elementui組件在table-cell單元格中繪制微型echarts圖,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
vue?LogicFlow更多配置選項(xiàng)示例詳解
這篇文章主要為大家介紹了vue?LogicFlow更多配置選項(xiàng)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
Vue3父子組件互調(diào)方法的實(shí)現(xiàn)
本文主要介紹了Vue3父子組件互調(diào)方法的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
編寫Vue項(xiàng)目,如何給數(shù)組的第一位添加對(duì)象數(shù)據(jù)
這篇文章主要介紹了編寫Vue項(xiàng)目,如何給數(shù)組的第一位添加對(duì)象數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue-cli3執(zhí)行serve和build命令時(shí)nodejs內(nèi)存溢出問題及解決
這篇文章主要介紹了Vue-cli3執(zhí)行serve和build命令時(shí)nodejs內(nèi)存溢出問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
如何為Vue3提供一個(gè)可媲美Angular的ioc容器
ue3因其出色的響應(yīng)式系統(tǒng),以及便利的功能特性,完全勝任大型業(yè)務(wù)系統(tǒng)的開發(fā),這篇文章主要介紹了如何為Vue3提供一個(gè)可媲美Angular的ioc容器,需要的朋友可以參考下2024-08-08

