程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 關於數據校驗

關於數據校驗

編輯:關於C++

1.什麼是數據校驗

通俗的說,就是為保證數據的完整性,用一種指定的算法對原始數據計算出的一個校驗值。接收方用同樣的算法計算一次校驗值,如果和隨數據提供的校驗值一樣,就說明數據是完整的。

2.最簡單的檢驗

實現方法:最簡單的校驗就是把原始數據和待比較數據直接進行比較,看是否完全一樣這種方法是最安全最准確的。同時也是效率最低的。

適用范圍:簡單的數據量極小的通訊。

應用例子:龍珠cpu在線調試工具bbug.exe。它和龍珠cpu間通訊時,bbug發送一個字節cpu返回收到的字節,bbug確認是剛才發送字節後才繼續發送下一個字節的。

3.奇偶校驗Parity Check

實現方法:在數據存儲和傳輸中,字節中額外增加一個比特位,用來檢驗錯誤。校驗位可以通過數據位異或計算出來。

應用例子:單片機串口通訊有一模式就是8位數據通訊,另加第9位用於放校驗值。

4.bcc異或校驗法(block check character)

實現方法:很多基於串口的通訊都用這種既簡單又相當准確的方法。它就是把所有數據都和一個指定的初始值(通常是0)異或一次,最後的結果就是校驗值,通常

把她附在通訊數據的最後一起發送出去。接收方收到數據後自己也計算一次異或和校驗值,如果和收到的校驗值一致就說明收到的數據是完整的。

校驗值計算的代碼類似於:

unsigned uCRC=0;//校驗初始值

for(int i=0;i<DataLenth;i++) uCRC^=Data[i];

適用范圍:適用於大多數要求不高的數據通訊。

應用例子:ic卡接口通訊、很多單片機系統的串口通訊都使用。

5.crc循環冗余校驗(Cyclic Redundancy Check)

實現方法:這是利用除法及余數的原理來進行錯誤檢測的.將接收到的碼組進行除法運算

,如果除盡,則說明傳輸無誤;如果未除盡,則表明傳輸出現差錯。crc校驗

具還有自動糾錯能力。

crc檢驗主要有計算法和查表法兩種方法,網上很多實現代碼。

適用范圍:CRC-12碼通常用來傳送6-bit字符串;CRC-16及CRC-CCITT碼則用是來傳送

8-bit字符。CRC-32:硬盤數據,網絡傳輸等

應用例子:rar,以太網卡芯片、MPEG解碼芯片中

6.md5校驗和數字簽名

實現方法:主要有md5和des算法。

適用范圍:數據比較大或要求比較高的場合。如md5用於大量數據、文件校驗,des用於保

密數據的校驗(數字簽名)等等。

應用例子:文件校驗、銀行系統的交易數據

7.數據校驗的一個實際應用

防止自己的程序被篡改的例子。

有些可執行程序,當被改了資源時再運行會有文件已損壞的提示,這就是使

用了數據校驗。本例是用md5做為數據校驗的算法。當然你可以使用個性化的

比如des作為數字簽名,那樣安全性更高。

編譯時,將提示如圖1的信息,請記下上面的數值,然後寫回程序的比較字符

中。再次編譯就不會提示了,直接進入程序。如果你使用pe資源修改器修改

改該exe文件了資源,再運行又會出現圖1的提示。具體請見代碼及注釋。

本文配套源碼

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved