對稱加密

来源:http://www.cnblogs.com/buerjj/archive/2017/12/11/7957057.html
-Advertisement-
Play Games

對稱加密要使用密鑰 key 來進行加密,且加密解密過程中使用的密鑰是同一把。對稱加密常用的演算法有 DES 3DES AES 【對稱加密方式】 對稱加密方式有分組加密和流密碼的處理方式,本文主要講述一下分組加密。 分組加密:一般加密數據會很大,所以會先把大文件分成一塊一塊,對每一塊進行加密,最後對加密 ...


  對稱加密要使用密鑰 key 來進行加密,且加密解密過程中使用的密鑰是同一把。對稱加密常用的演算法有 DES 3DES AES

【對稱加密方式】

  對稱加密方式有分組加密和流密碼的處理方式,本文主要講述一下分組加密。

  分組加密:一般加密數據會很大,所以會先把大文件分成一塊一塊,對每一塊進行加密,最後對加密後的密文進行拼接。其中分組加密根據不同加密模式又分為 ECB 和 CBC .

【ECB分組模式】

  ECB又稱為電子密碼本模式,它在加密的時候呢是按固定的長度進行拆分,分組後對每一塊進行加密,當其中一塊明文數據發生改變,這塊明文數據對應的密文也會發生改變。如下圖:

   

終端演示ECB加密解密

加密:openssl enc -des-ecb -K 616263 -nosalt -in 123.txt -out 123.bin

  openssl 是一個加密包,enc 表示加密,這裡加密演算法是 des,ecb 表示分組模式,-K 表示密鑰即 616263 (終端上要求輸入16進位,不允許輸入字元,616263 即對應 abc )。nosalt 表示不加鹽,如果不加這句它會預設加鹽,並且我們不知道它的鹽加在什麼位置。這樣我們解密的時候就解不密了,所以我們主動讓它不加鹽。

  創建一個要加密的txt文本,裡面可以輸入一些內容,如下:

  

  cd 到此目錄,敲入上述加密命令後,這個目錄下多了 123.bin 文件,輸入命令 xxd 123.bin ,對密文進行查看,如下

00000000: ff92 bf58 6a78 9ff2 1d8e 208f c43c a517  ...Xjx.... ..<..

00000010: 1300 2f6a ccad d6dd                      ../j....

  前面說了ECB分組加密是將數據分成一塊一塊進行加密,這裡試一下將123.txt里的明文內容最後一行第一個字元改成8,然後再進行加密,得到一個新密文1234.bin。如下圖

  

 

  這時再用終端將 123.bin 和 1234.bin 文件都打開,對比下兩個密文有什麼區別。

  

  從上圖可以看出,改動一個字元後,只有其中一組數據發生了變化,其他組密文都一樣。所以可以看出 ECB 分組模式,是將數據分塊,然後每塊進行加密,最後將密文拼接。

 

【CBC分組模式】

   cbc 加密方式各個組的加密是受影響的,如下加密流程圖中可以很明顯看出,後面每一組的明文先與前一組生成的密文進行異或運算,然後再加密得到結果。一直往前推到第一組加密時,它前面沒有密文,就用一個初始化向量和明文進行異或。當一組明文數據發生改變時,這組密文以及後面的密文數據都將發生改變

  

終端演示ECB加密解密

  加密操作:還是對原來的123.txt進行演示,命令如下-iv後是隨意設置的初始向量

openssl enc -des-cbc -K 616263 -nosalt -iv 010203040506070809 -in 123.txt -out 123.bin

  經過上面命令後,生成了123.bin密文。現在對123.txt內容進行和上面操作一樣的修改,將最後一行第一個數字修改成8,然後用上述命令生成1234.bin密文。最後查看兩者密文如下:

  

  從上圖可以看出,前面16位是相同的,從17位開始,後面的數據就都不一樣了。這就說明CBC分組模式,它改動的數據會對後面的密文產生影響,而對它改動的前面的密文是不會發生變化的。

【前後端通信加密演示】

  後端用 node 作為服務端,前端用 vue 調用 node的介面。這樣主要是為了方便,加密解密的代碼都可以共用一套。

  1. node 端處理: 安裝 crypto-js 模塊。然後封裝一個加密解密的工具類 cryptoTool.js 。此工具類代碼如下:

 1 let crypto = require('crypto');
 2 
 3 // 解密
 4 function decString(string, callBack) {
 5   const decipher = crypto.createDecipher('aes-256-ecb', 'abcd');
 6   let decrypted = '';
 7   decipher.on('readable', () => {
 8     const data = decipher.read();
 9     if (data)
10       decrypted += data.toString('utf8');
11   });
12   decipher.on('end', () => {
13     callBack(decrypted)
14   });
15   const encrypted = string;
16   decipher.write(encrypted, 'hex');
17   decipher.end();
18 }
19 
20 // 加密
21 function encString(string) {
22   const cipher = crypto.createCipher('aes-256-ecb', 'abcd');
23   let encrypted = cipher.update(string, 'utf8', 'hex');
24   encrypted += cipher.final('hex');
25   return encrypted;
26 }
27 
28 module.exports = {
29   encString: encString,
30   decString: decString
31 };

 

  上述代碼中第 5 行和第 22 行中的加密演算法( 參數1 )和 key (參數2) 要對應一致,這裡的key寫的是 abcd, key 可以自己隨意定,但要加密和解密key對應上。關於加密演算法有很多,下圖列出參數1 和加密演算法和方式如下:

  

   

  node 介面代碼,如下: 前端將所有參數加密,node 對接收到參數解密前後進行列印

app.get('/info', (req, res) => {
  console.log(req.query);

  console.log('解密前 paramsStr =', req.query.paramsStr);
  let decName = cryptoTool.decString(req.query.paramsStr, (val) => {
    let resVal = JSON.parse(val);
    console.log('解密後 val =', resVal);
    console.log(resVal.name, resVal.height);
  });

  let returnJson = {
    code: 0,
    msg: "ok",
    data: "請求成功"
  };
  let returnStr = cryptoTool.encString(JSON.stringify(returnJson));
  res.end(returnStr);
});

 

   

  2. 前端 vue 代碼處理: 同樣安裝 crypto-js 第三方模塊,然後將上述 cryptoTool.js 放到 vue 工程,它與 node 可以共用一個加密文件,這裡發送網路請求使用 axios 框架。代碼如下:

  let jsonStr = JSON.stringify({name: 'lijinshi', height: 173, sex: 'boy'});
  let paramsStr = cryptoTool.encString(jsonStr); // 參數加密
  let params = {paramsStr: paramsStr};
  axios.get('host + port /info', {params: params})
  .then(res => {
    // 對服務端返回值解密
    let decStr = cryptoTool.decString(res.data, (val) => {
      console.log(JSON.parse(val));
    });
  })
  .catch(err => {
    console.log(err);
  })

 

【相關效果】

  1. 前端發送請求,一串加密字元串

  

  2. 服務端接收到如下:

  

  3. 前端接收到服務端返回值如下:

  

 

  ——以上。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 記得剛遇見css的時候,咱像是見了美人兒一樣,簡直是愛不釋手啊,簡簡單單寫幾行算不上代碼的代碼,就能做出這麼漂亮的東西,這也成了咱前端之路的最初動力。然而,隨著項目體量和頁面複雜度的增加,咱很快就發現這美人兒非但不漂亮,而且缺胳膊少腿兒的。 ...
  • 最近在用jQuery實現動態模糊查詢的時候,找了挺久都沒有找到像Vue.js的watch屬性這麼好用的動態模糊查詢方法。就分享一下目前遇到的坑和可以實現動態查詢的幾種方式。 1.jQuery的change()方法。 這個方法要失去所在的input框的焦點時,事件才會被觸發,感覺有點雞肋,也有可能是我 ...
  • 隨著網路的高速發展,網路性能的持續提高成為能否在芸芸App中脫穎而出的關鍵。高度聯結的世界意味著用戶對網路體驗提出了更嚴苛的要求。假如你的網站不能做到快速響應,又或你的App存在延遲,用戶很快就會移情你的競爭對手。以下為大家總結10條有關性能提升的經驗,以供參考: 1. 採用反向代理伺服器(Reve ...
  • JavaScript 三種工廠模式:簡單工廠模式、工廠方法模式、抽象工廠模式。 ...
  • [1]對象 [2]類 [3]封裝 [4]聚合 [5]繼承 [6]多態 ...
  • 做項目(Angular項目)時經常需要處理金額的顯示,需要在金額前面加上¥,但又不想用簡單在前面加“¥”這麼不優雅的方式,於是想到了CurrencyPipe。畢竟,CurrencyPipe還可以格式化數字。 按照官方提供的 "文檔" ,我寫出這樣的代碼: 刷新頁面,應該沒什麼問題! 什麼,怎麼是CN ...
  • 趕上公司去Windows化,有一大波.net站點需要轉成Node.js,於是自己就順便琢磨一個通用的Node版MVC框架。經過幾天的努力,beta版終於面世了!因為其高性能的特點,特地命名node-eagle ...
  • map():對數組中的每個元素重組裝 不改變原數組 Javascript版本1.6 every():檢測數組中每個元素是否符合條件,若數組中檢測出一個不滿足條件,返回false,則剩餘元素不再進行檢測,若所有元素滿足條件,返回true。不改變原數組 Javascript版本1.6 some():檢測 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...