Linux下C語言使用openssl庫進行MD5校驗

http://blog.csdn.net/cassie_huang/article/details/53212933

作者:無腦仔的小明?
出處:http://www.cnblogs.com/wunaozai/?

我們以一個字符串為例,新建一個文件filename.txt,在文件內寫入hello ,然后在Linux下可以使用命令md5sum filename.txt計算md5值 ==>?b1946ac92492d2347c6235b4d2611184 ?。雖然寫入的是hello這5個字符,但是我們使用命令xxd filename.txt后可以看出文件結尾處會有個0x0a這個回車符。所以在下面的代碼中才會有\n。

[cpp]?view plain?copy
  1. //打開/usr/include/openssl/md5.h這個文件我們可以看到一些函數??
  2. //?初始化?MD5?Contex,?成功返回1,失敗返回0??
  3. int?MD5_Init(MD5_CTX?*c);??
  4. //?循環調用此函數,可以將不同的數據加在一起計算MD5,成功返回1,失敗返回0??
  5. int?MD5_Update(MD5_CTX?*c,?const?void?*data,?size_t?len);??
  6. //?輸出MD5結果數據,成功返回1,失敗返回0??
  7. int?MD5_Final(unsigned?char?*md,?MD5_CTX?*c);??
  8. //?MD5_Init,MD5_Update,MD5_Final三個函數的組合,直接計算出MD5的值??
  9. unsigned?char?*MD5(const?unsigned?char?*d,?size_t?n,?unsigned?char?*md);??
  10. //?內部函數,不需要調用??
  11. void?MD5_Transform(MD5_CTX?*c,?const?unsigned?char?*b);??


新建一個cpp文件(C文件也可以)用于計算MD5值
[cpp]?view plain?copy
  1. #include?<openssl/md5.h>??
  2. #include?<string.h>??
  3. #include?<stdio.h>??
  4. ??
  5. int?main()??
  6. {??
  7. ????MD5_CTX?ctx;??
  8. ????unsigned?char?outmd[16];??
  9. ????int?i=0;??
  10. ??
  11. ????memset(outmd,0,sizeof(outmd));??
  12. ????MD5_Init(&ctx);??
  13. ????MD5_Update(&ctx,"hel",3);??
  14. ????MD5_Update(&ctx,"lo\n",3);??
  15. ????MD5_Final(outmd,&ctx);??
  16. ????for(i=0;i<16;i<i++)??
  17. ????{??
  18. ????????printf("%02X",outmd[i]);??
  19. ????}??
  20. ????printf("\n");??
  21. ????return?0;??
  22. }??

編譯選項為: g++ MD5test.cpp -lssl -o MD5test(如果是C語言可以使用gcc?MD5test.c -o ?MD5test)

運行后的結果為:?B1946AC92492D2347C6235B4D2611184

注意這里用到openssl庫,可以自行根據網上教程安裝。

下面這個代碼是對文件進行MD5計算。

[cpp]?view plain?copy
  1. #include?<openssl/md5.h>??
  2. #include?<string.h>??
  3. #include?<stdio.h>??
  4. ??
  5. int?main()??
  6. {??
  7. ????MD5_CTX?ctx;??
  8. ????unsigned?char?outmd[16];??
  9. ????char?buffer[1024];??
  10. ????char?filename[32];??
  11. ????int?len=0;??
  12. ????int?i;??
  13. ????FILE?*?fp=NULL;??
  14. ????memset(outmd,0,sizeof(outmd));??
  15. ????memset(filename,0,sizeof(filename));??
  16. ????memset(buffer,0,sizeof(buffer));??
  17. ????printf("請輸入文件名,用于計算MD5值:");??
  18. ????scanf("%s",filename);??
  19. ????fp=fopen(filename,"rb");??
  20. ????if(fp==NULL)??
  21. ????{??
  22. ????????printf("Can't?open?file\n");??
  23. ????????return?0;??
  24. ????}??
  25. ??
  26. ????MD5_Init(&ctx);??
  27. ????while((len=fread(buffer,1,1024,fp))>0)??
  28. ????{??
  29. ????????MD5_Update(&ctx,buffer,len);??
  30. ????????memset(buffer,0,sizeof(buffer));??
  31. ????}??
  32. ????MD5_Final(outmd,&ctx);??
  33. ??
  34. ????for(i=0;i<16;i<i++)??
  35. ????{??
  36. ????????printf("%02X",outmd[i]);??
  37. ????}??
  38. ????printf("\n");??
  39. ????return?0;??
  40. }??
運行得到結果后,我們可以使用md5sum命令進行驗證。

文章為轉載,略微改了幾個字眼。


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/384283.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/384283.shtml
英文地址,請注明出處:http://en.pswp.cn/news/384283.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

dup、dup2、fcntl

dup、dup2&#xff0c;復制文件描述符 int dup(int oldfd);  //返回文件描述表中沒有被占用的最小可用的描述符&#xff0c;新舊描述符作用相同 int dup2(int oldfd, int newfd);  //如果new已經被打開&#xff0c;先關閉再拷貝就會指向同一個文件&#xff0c;如果old和new…

進程

創建子進程&#xff1a;fork調用&#xff0c; 一次fork調用返回兩個值&#xff0c;1、返回子進程的pid&#xff08;非負整數&#xff09; 2、返回0 父進程的fork返回子進程的id&#xff0c;子進程的fork返回0&#xff08;表示執行成功&#xff09; 創建單個子進程&#xff1a; …

Ubuntu在vmware虛擬機無法上網的解決方法

http://blog.csdn.net/xueyushenzhou/article/details/50460183 在vmware中安裝Ubuntu之后&#xff0c;我們希望基本的功能如上網、傳輸文件等功能都是可用的&#xff0c;但是經常遇到不能上網的情況。使用筆記本時&#xff0c;我們經常希望能通過無線網卡上網&#xff0c;但是…

exec函數族

fork創建子進程后執行的是和父進程相同的程序&#xff08;但有可能執行不同的代碼分支&#xff09;&#xff0c;子進程往往要調用一種exec函數以執行另一個程序。當進程調用一種exec函數時&#xff0c;該進程的用戶空間代碼和數據完全被新程序替換&#xff0c;從新程序的啟動例…

IO 多路復用之poll總結

http://www.cnblogs.com/Anker/p/3261006.html IO多路復用之poll總結 1、基本知識 poll的機制與select類似&#xff0c;與select在本質上沒有多大差別&#xff0c;管理多個描述符也是進行輪詢&#xff0c;根據描述符的狀態進行處理&#xff0c;但是poll沒有最大文件描述符數量的…

wait、waitpid

父進程調用wait函數可以回收子進程的終止信息&#xff0c;該函數有三個功能&#xff1a;&#xff08;一次wait調用回收一個子進程 回收多個用循環&#xff09; 1、阻塞等待子進程退出 2、回收子進程殘留資源 3、獲取子進程結束狀態&#xff08;退出原因&#xff09; pid_t wait…

C++項目中的extern C {}

http://www.cnblogs.com/skynet/archive/2010/07/10/1774964.html 引言 在用C的項目源碼中&#xff0c;經常會不可避免的會看到下面的代碼&#xff1a; 123456789#ifdef __cplusplusextern "C" {#endif/*...*/#ifdef __cplusplus}#endif它到底有什么用呢&#xff0c;…

管道

管道&#xff0c;其本質是一個偽文件&#xff08;實為內核緩沖區&#xff09;&#xff1b;由兩個文件描述符引用&#xff0c;一個表示讀端、一個表示寫端&#xff1b;規定數據從管道的寫端流入&#xff0c;讀端流出。 管道的原理&#xff1a;管道實為內核使用環形隊列機制&…

C/S、B/S的區別

C/S結構&#xff0c;即Client/Server(客戶機/服務器)結構&#xff0c;是大家熟知的軟件系統體系結構&#xff0c;通過將任務合理分配到Client端和Server端&#xff0c;降低了系統的通訊開銷&#xff0c;可以充分利用兩端硬件環境的優勢。早期的軟件系統多以此作為首選設計標準。…

extern c用法解析

http://www.jianshu.com/p/5d2eeeb93590 引言C保留了一部分過程式語言的特點&#xff0c;因而它可以定義不屬于任何類的全局變量和函數。但是&#xff0c;C畢竟是一種面向對象的程序設計語言&#xff0c;為了支持函數的重載&#xff0c;C對全局函數的處理方式與C有明顯的不同。…

C語言實現單鏈表(帶頭結點)的基本操作(創建,頭插法,尾插法,刪除結點,打印鏈表)

http://blog.csdn.net/xiaofeige567/article/details/27484137 C語言實現單鏈表&#xff08;帶頭結點&#xff09;的基本操作&#xff08;創建&#xff0c;頭插法&#xff0c;尾插法&#xff0c;刪除結點&#xff0c;打印鏈表&#xff09; [plain] view plaincopy #include<…

靜態網頁與動態網頁區別

一、靜態web頁面&#xff1a;1、在靜態Web程序中&#xff0c;客戶端使用Web瀏覽器&#xff08;IE、FireFox等&#xff09;經過網絡(Network)連接到服務器上&#xff0c;使用HTTP協議發起一個請求&#xff08;Request&#xff09;&#xff0c;告訴服務器我現在需要得到哪個頁面&…

單向循環鏈表C語言實現

http://blog.csdn.net/morixinguan/article/details/51771633 我們都知道&#xff0c;單向鏈表最后指向為NULL&#xff0c;也就是為空&#xff0c;那單向循環鏈表就是不指向為NULL了&#xff0c;指向頭節點&#xff0c;所以下面這個程序運行結果就是&#xff0c;你將會看到遍歷…

web服務器原理

什么是web服務器&#xff1f; 在Mosaic瀏覽器&#xff08;通常被認為是第一個圖形化的web瀏覽器&#xff09;和超鏈接內容的初期&#xff0c;演變出了“web服務器”的新概念&#xff0c;它通過HTTP協議來提供靜態頁面內容和圖片服務。在那個時候&#xff0c;大多數內容都是靜態…

(C語言版)鏈表(三)——實現雙向鏈表創建、刪除、插入、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19760681 上午寫了下單向循環鏈表的程序&#xff0c;今天下午我把雙向鏈表的程序寫完了。其實雙向鏈表和單向鏈表也是有很多相似的地方的&#xff0c;聽名字可以猜到&#xff0c;每個節點都包含兩個指針&#xff0c;一個指針指…

競態條件

pause函數 調用該函數可以造成進程主動掛起&#xff0c;等待信號喚醒。調用該系統調用的進程將處于阻塞狀態(主動放棄cpu) 直到有信號遞達將其喚醒。 int pause(void); 返回值&#xff1a;-1 并設置errno為EINTR 返回值&#xff1a; ① 如果信號的默認處理動作是終止進程&#…

(C++版)鏈表(一)——實現單向鏈表創建、插入、刪除等相關操作

http://blog.csdn.net/fisherwan/article/details/25557545 前段時間用C語言實現了鏈表的相關操作&#xff0c;但是發現當時挺清楚的&#xff0c;過了一段時間又忘的差不多了&#xff0c;所以現在打算用C再實現一遍&#xff0c;由于初次用C實現&#xff0c;存在錯誤的地方還望大…

(C語言版)鏈表(二)——實現單向循環鏈表創建、插入、刪除、釋放內存等簡單操作

http://blog.csdn.net/fisherwan/article/details/19754585 昨天寫了單向鏈表的代碼&#xff0c;今天上午把單向循環鏈表的程序給敲完了。鏈表的相關操作一樣的&#xff0c;包含鏈表的創建、判斷鏈表是否為空、計算鏈表長度、向鏈表中插入節點、從鏈表中刪除節點、刪除整個鏈表…

計科院首頁靜態網頁

一.HTML代碼 <!DOCTYPE html><html><head><meta charset"UTF-8"><title>首頁</title> </head><body><div id"page"> <div id"page_head"> <div id"logo" aligncenter…

可重入函數

一個函數在被調用執行期間(尚未調用結束)&#xff0c;由于某種時序又被重復調用&#xff0c;稱之為“重入”。根據函數實現的方法可分為“可重入函數”和“不可重入函數”兩種。 注意事項 定義可重入函數&#xff0c;函數內不能含有全局變量及static變量&#xff0c;不能使用ma…