中利用校驗碼為圖設置水印覆蓋
四、示例程序的設計實現(xiàn)
首先我們把本文中最關(guān)鍵的用于產(chǎn)生CRC校驗和(余數(shù))的函數(shù)CheckOut()的實現(xiàn)部分主要代碼做了介紹,其中為了減少運算量、方便編程、將煩瑣的多項式長除取余的過程按照前面講述的CRC算法的運算過程和原理將其預先設定在一個256字節(jié)長的數(shù)組表CheckTable中,實際運算時只須按索引對其查表即可:
BYTE CCRCDlg::CheckOut(BYTE *byteData, UINT nCount)
{
……
static BYTE CheckTable[256]=
{
0x00,0x07,0x0e,0x09,0x1c,0x1b,0x12,0x15,0x38,0x3f,
0x36,0x31,0x24,0x23,0x2a,0x2d,0x70,0x77,0x7e,0x79,
0x6c,0x6b,0x62,0x65,0x48,0x4f,0x46,0x41,0x54,0x53,
0x5a,0x5d,0xe0,0xe7,0xee,0xe9,0xfc,0xfb,0xf2,0xf5,
0xd8,0xdf,0xd6,0xd1,0xc4,0xc3,0xca,0xcd,0x90,0x97,
0x9e,0x99,0x8c,0x8b,0x82,0x85,0xa8,0xaf,0xa6,0xa1,
0xb4,0xb3,0xba,0xbd,0xc7,0xc0,0xc9,0xce,0xdb,0xdc,
0xd5,0xd2,0xff,0xf8,0xf1,0xf6,0xe3,0xe4,0xed,0xea,
0xb7,0xb0,0xb9,0xbe,0xab,0xac,0xa5,0xa2,0x8f,0x88,
0x81,0x86,0x93,0x94,0x9d,0x9a,0x27,0x20,0x29,0x2e,
0x3b,0x3c,0x35,0x32,0x1f,0x18,0x11,0x16,0x03,0x04,
0x0d,0x0a,0x57,0x50,0x59,0x5e,0x4b,0x4c,0x45,0x42,
0x6f,0x68,0x61,0x66,0x73,0x74,0x7d,0x7a,0x89,0x8e,
0x87,0x80,0x95,0x92,0x9b,0x9c,0xb1,0xb6,0xbf,0xb8,
0xad,0xaa,0xa3,0xa4,0xf9,0xfe,0xf7,0xf0,0xe5,0xe2,
0xeb,0xec,0xc1,0xc6,0xcf,0xc8,0xdd,0xda,0xd3,0xd4,
0x69,0x6e,0x67,0x60,0x75,0x72,0x7b,0x7c,0x51,0x56,
0x5f,0x58,0x4d,0x4a,0x43,0x44,0x19,0x1e,0x17,0x10,
0x05,0x02,0x0b,0x0c,0x21,0x26,0x2f,0x28,0x3d,0x3a,
0x33,0x34,0x4e,0x49,0x40,0x47,0x52,0x55,0x5c,0x5b,
0x76,0x71,0x78,0x7f,0x6a,0x6d,0x64,0x63,0x3e,0x39,
0x30,0x37,0x22,0x25,0x2c,0x2b,0x06,0x01,0x08,0x0f,
0x1a,0x1d,0x14,0x13,0xae,0xa9,0xa0,0xa7,0xb2,0xb5,
0xbc,0xbb,0x96,0x91,0x98,0x9f,0x8a,0x8d,0x84,0x83,
0xde,0xd9,0xd0,0xd7,0xc2,0xc5,0xcc,0xcb,0xe6,0xe1,
0xe8,0xef,0xfa,0xfd,0xf4,0xf3
};
……
BYTE Result = CheckTable[*byteData];
for(UINT i=1;inCount;i++)//對數(shù)據(jù)流進行CRC校驗和計算
{
Result = Result^(*(byteData+i));
Result = CheckTable[Result];
}
……
return Result;//返回計算出來的CRC校驗和。
}
該函數(shù)的兩個入口形參BYTE *byteData和 UINT nCount分別表示要計算CRC校驗碼的數(shù)據(jù)流和該數(shù)據(jù)流的長度。函數(shù)返回值為計算出來的CRC校驗碼,其他函數(shù)只須簡單的調(diào)用此函數(shù)即可得到關(guān)于某段數(shù)據(jù)序列的校驗碼,下面是為BMP 位圖設置印鑒的部分主要代碼:
……
//首先讀取文件到緩存中去,并得到文件的長度
en(FileName,CFile::modeReadWrite);
int FileLen=tLength();
//為緩存動態(tài)分配內(nèi)存空間
BYTE* buf;
buf=new BYTE [FileLen];
ekToBegin();
ad(buf,FileLen);
//調(diào)用CheckOut函數(shù)計算BMP位圖的位圖陣列部分(38字節(jié)以后部分)的CRC校驗碼
BYTE crc=CheckOut(buf+38,FileLen-38);
//在前面提到過模2減法,在以2為模的加、減法中,都是和異或運算相同的。
//把經(jīng)過模2減法的計算結(jié)果保存到BMP位圖的保留空間中
buf[6]=0^crc;
ek(6,CFile::begin);
ite(buf+6,1);
//釋放申請過的內(nèi)存空間、關(guān)閉打開的文件
delete[] buf;
ose();
……
至于檢驗文件是否經(jīng)過處理的代碼和前面的設置印鑒的代碼是非常類似的,也是先將文件讀取到緩存中,只是要把存放在第六字節(jié)保留字段中的印鑒水印重新恢復到數(shù)據(jù)序列的末尾,然后再把該序列被G(x)除,通過判斷能否整除即可斷定該文件是否曾被改動過:
……
en(FileName,CFile::modeReadWrite);
int FileLen=tLength();
……
//讀取文件到緩存
BYTE* buf;
buf=new BYTE [FileLen+1];
可以找到倉庫管理員 ekToBegin();
ad(buf,FileLen);
ose();
//將印鑒恢復到數(shù)據(jù)序列的末尾
buf[FileLen]=buf[6];
//計算帶有校驗碼(印鑒)的序列被G(x)標準多項式整除的余數(shù)
BYTE crc=CheckOut(buf+38,FileLen-37);
//判斷crc(余數(shù))是否為0(即能否整除),來判定文件的原始性。
if(crc!=0)
AfxMessageBox(\"警告!文件被改動過了!\"); //CRC校驗錯誤!印鑒有損。
else
AfxMessageBox(\"文件沒有發(fā)生過改動!\"); //CRC校驗正確,印鑒完好。
delete[] buf;
……
小結(jié):
本文對CRC校驗在文件印鑒水印方面的應用做了簡要的介紹,在對CRC 校驗和其他文件格式有了更深入的了解后,對本文的代碼稍加改動,就可以對其他格式的文件設置類似的印鑒水印。本程序在Windows2000 Professional下,由Microsoft Visual C++ 6.0編譯調(diào)試通過。 查看本文來源
昆明醫(yī)院哪家白癜風醫(yī)院好蘭州白癜風哪里治療好
重慶醫(yī)院婦科哪家醫(yī)院好
- 男子偽造才可倒賣物資被上海警方查處
- 親爸帶娃想沒用,給娃制作了一個“簡易秋千”火了,網(wǎng)友:厲害了
- 孕七個月初產(chǎn)檢“無胎心”,多和這些因素有關(guān),孕媽可要注意防范!
- 韓衛(wèi)東:供需錯配導致今年市場震蕩非常大
- 高精地圖受到限制了自動駕駛“進城”?
- 服喬布斯不服坎貝爾,蘋果傳奇設計團隊解散內(nèi)幕曝光
- 河南省市場監(jiān)管局抽檢16大類1856廠內(nèi)食品樣品,合格1820廠內(nèi)
- 劉畊宏躺贏!帕梅拉被曝買水軍洗白錄播,水軍文集也被揭發(fā)是謊話
- 現(xiàn)在起至7上半年上海各區(qū)每周周末安排一次社區(qū)篩查
- Mysteel日報:黑色金屬期貨先跌后上漲
- 豬肉機器價格,豬肉機多少錢?
- 男人不并不知道你4件事,說明你在他心里什么都不是