所謂的隱寫術就是在不”破壞“(指正常打開,并不指修改二進制文件)文件的情況下,把機密信息寫入進文件,然后經過處理后,把文件的信息提取出來。
舉一個例子:
在抗日戰爭時期,我方在偷取到日方機密文件后會寫下藏頭詩。這個藏頭詩一般人看不懂,只有特定的人才看得懂。
再舉一個例子:比如把一個bmp格式的圖片文件放入某人的身份證信息,正常打開這個圖片,只會顯示原圖片,經過處理提取后才能把身份證信息提取出來。
所以這就產生了一個問題,一個文件的格式,到底是什么樣的。我們可以對這個文件做什么樣的處理,才能不受破壞(指正常打開,并不指修改二進制文件)。
在Windows上,有后綴名這個概念,linux里面沒有后綴名概念,Windows上,后綴名只有讓操作系統找到打開他們的適合的方式,而這個文件是不是圖片或者音頻,就得看他的文件格式。
在認識bmp文件格式之前,我們先來認識下txt文件
先打開注冊表(運行處輸入regedit),在HKEY_CLASSES_ROOT目錄下找到.txt,并且找到他的默認的數據,為txtfile,如下圖所示:
現在就知道.txt文件和一個叫txtfile的東西有關,現在到注冊表找到這個txtfile。同樣在HKEY_CLASSES_ROOT下可以找到txtfile,如下圖所示:
這時我們可以看到它的默認圖標是調用了一個叫imagers.dll的東西。
然后我們繼續往下看
這里面我們可以看到打開方式是command也就是cmd。用的是notepad打開的。
意思就是說,我的這臺電腦,如果遇到.txt的文件就會調用notepad對它進行打開。
下面我們來介紹Windows下最簡單的圖片文件bmp格式。如果我們把一個空的文件叫1.txt,改成1.bmp后,我們發現,圖片瀏覽器根本打不開。這是因為這個1.txt里面文件內部(二進制代碼)并沒有發送改變。
下面來看看bmp文件格式。
首先我們用QQ接一個圖并且保存為bmp格式,如下圖所示:
現在提供給大家一個工具,這個工具對識別文件格式有相當高的效率。
下載地址如下:
鏈接: https://pan.baidu.com/s/1boNo4px
密碼: 4ysy
安裝以漢化里面都有說明,在此不再說明。
搞好后,我們打開010 Editor 然后把文件拖入進入,如下圖所示:
此時圖如下我們來分析下:
在這個圖里面:
1.我們可以看到最開頭的兩個十六進制為42H,4DH轉為ASCII后分別表示BM,這是bmp的標識。
2.紅色箭頭是圖片的大小(這里對應的十六進制為26 3D 17 00,但這設計大小端轉化,所以他一個轉為00 17 3D 26,換成十進制就為1522982)。
3.黃色的那兩個箭頭一般填充為0。
4.橘色監聽的bfOffBits是從文件的第一個字節到位圖數據的偏移大小。
5.biSze是指這個struct BITMAPINDOHEADER bmih占40個字節大小。
6.biWidth,和biHeight指圖片的寬和高(為什么高度是負數,大家可以嘗試下把高度該成正數,然后修改第一個顏色的值,就可以發現問題了(第一個點就變成了左下角))。
6.黑色箭頭bitBitCount代表:BGRA 藍、綠、紅、alpha,來存儲一個像素,藍占多少,綠占多少,紅占多少,alpha是透明度,每一個分項占1byte每一個像素占4bytes(有些只有24位,意思就是沒有alpha這個透明度,因為這個alpha只有在高端的那些圖片處理上才用得著,一般的圖片瀏覽器不會顯示這個東西)。
7.這兩個結構體結束后:剩下的部分就是像素的BGRA了。
我們現在來修改像素里面的BGR。改成如下情況:
我們保存,查看下圖片:
這時我們就可以看到這樣的圖片了:
這時我們再次修改他的透明度如下所示:
這時我們再觀察圖片:
我們發現圖片并沒有被改變
這是因為:目前的Windows系統下90%的圖片查看器會直接忽略掉bmp文件的alpha通道
只有那些高端的,要圖片處理的,才會用到alpha通道。
所以把機密信息拆開,保存到alpha通道里面,就實現了文件的隱藏,
隱藏后的文件,我們在寫一個特定的程序,就可以提取出來了。
下面幾節將介紹如何寫這種程序。
新聞熱點
疑難解答