C語言中怎么利用DES模塊實現(xiàn)加密功能,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
成都創(chuàng)新互聯(lián)公司是由多位在大型網(wǎng)絡公司、廣告設計公司的優(yōu)秀設計人員和策劃人員組成的一個具有豐富經(jīng)驗的團隊,其中包括網(wǎng)站策劃、網(wǎng)頁美工、網(wǎng)站程序員、網(wǎng)頁設計師、平面廣告設計師、網(wǎng)絡營銷人員及形象策劃。承接:網(wǎng)站制作、成都網(wǎng)站設計、網(wǎng)站改版、網(wǎng)頁設計制作、網(wǎng)站建設與維護、網(wǎng)絡推廣、數(shù)據(jù)庫開發(fā),以高性價比制作企業(yè)網(wǎng)站、行業(yè)門戶平臺等全方位的服務。DES(Data Encryption Standard)
DES一度是電子數(shù)據(jù)對稱加密的主導者。他影響了現(xiàn)代加密學。最早是在IBM于1970年基于更早的Horst Feistel的設計而開發(fā)出來的,算法應美國國家標準局(NBSNational_Bureau_of_Standards) National Bureau of Standards)代理人的邀請加入對美國政府敏感電子數(shù)據(jù)加密的候選方案。在1976年,經(jīng)過和美國國家安全局(NSA)磋商,NBS最終選擇了一個精簡版本在1977年發(fā)布。
如今在很多應用的加密還是會考慮使用DES。這個主要由于56-byte key size
AES(Advanced Encryption Standard)
是美國聯(lián)邦政府采用的一種區(qū)塊加密標準。這個標準用來替代原先的DES,已經(jīng)被多方分析且廣為全世界所使用。經(jīng)過五年的甄選流程,高級加密標準由美國國家標準與技術(shù)研究院(NIST)于2001年11月26日發(fā)布于FIPS PUB 197,并在2002年5月26日成為有效的標準。2006年,高級加密標準已然成為對稱密鑰加密中最流行的算法之一。
編譯openssl
wget ftp://ftp.openssl.org/source/openssl-1.0.0c.tar.gz tar -zxf openssl-1.0.0c.tar.gz cd openssl-1.0.0c/ ./config --prefix=/usr/local --openssldir=/usr/local/ssl make && make install ./config shared --prefix=/usr/local --openssldir=/usr/local/ssl make clean make && make install
代碼示例
DES
include文件
#include#include #ifndef uchar #define uchar unsigned char #endif
引入lib
libeay32.lib // for windows -lcrypto // for linux
加密代碼
int encrypt_data(const char *_key, const char *_vt,char *_raw_ptr,size_t _raw_size , char **_dst_buf, size_t *_dst_size) { DES_key_schedule schedule; uchar key1[8]; des_cblock *iv3; int pading ; size_t i, vt_size ; char *mid_buf; memset( key1,0,8); memcpy( key1, _key, 8 ); DES_set_key_unchecked( (const_DES_cblock*)&key1, &schedule); vt_size = strlen( _vt ); iv3 = (des_cblock *)malloc(vt_size * sizeof(uchar)); memcpy(iv3,_vt,vt_size); pading = 8 - (_raw_size % 8); *_dst_size = _raw_size + pading; mid_buf = (char*)malloc(*_dst_size); memcpy(mid_buf,_raw_ptr,_raw_size ); for (i = _raw_size ; i < *_dst_size; i++ ) { mid_buf[i] = pading; } *_dst_buf = (char*)malloc(*_dst_size); DES_cbc_encrypt( (const uchar*)mid_buf, (unsigned char *)*_dst_buf, *_dst_size, &schedule, iv3, DES_ENCRYPT); free(iv3); free(mid_buf); return 1; }
解密代碼
int decrypt_data(const char *_key, const char *_vt,char *_raw_ptr,size_t _raw_size , char **_dst_buf, size_t *_dst_size ) { DES_key_schedule schedule; uchar key1[8]; des_cblock *iv3; int pading ; size_t i, vt_size ; char *mid_buf; memset( key1,0,8); memcpy( key1, _key, 8 ); DES_set_key_unchecked( (const_DES_cblock*)&key1, &schedule); vt_size = strlen( _vt ); iv3 = (des_cblock *)malloc(vt_size * sizeof(uchar)); memcpy(iv3,_vt,vt_size); *_dst_buf = (char*)malloc(_raw_size); DES_cbc_encrypt( (const uchar*)_raw_ptr, *_dst_buf, _raw_size, &schedule, iv3, DES_DECRYPT); free(iv3); return 1; }
編譯運行
scons腳本SConstruct
import glob env = Environment() env["CPPPATH"] = [ '/home/abel/lib/openssl-1.0.2f/include' ] env['LIBPATH'] = [ '/home/abel/lib/openssl-1.0.2f' ] env['CPPDEFINES'] = ['LINUX', '_DEBUG' ] env['CCFLAGS'] = '-g -std=gnu99' env['LIBS'] = [ 'm', 'crypto', 'dl', 'profiler' ] env.Program( target = "./test_des", source = ( glob.glob( './*.c' ) ) )
測試代碼
int test_fun( int agrn, char *agrv[] ) { char *_key = "jkl;!@#$"; char *_vt = "asdf!@#$"; char *_raw_ptr ; size_t _raw_size; char *_dst_buf; size_t _dst_size; char *_final_buf; size_t _final_size; _raw_ptr = (char *)malloc(sizeof(char)*5); memcpy(_raw_ptr, "hello", 5); _raw_size = 5; encrypt_data(_key, _vt,_raw_ptr,_raw_size , &_dst_buf, &_dst_size) ; decrypt_data(_key,_vt, _dst_buf, _dst_size, &_final_buf, &_final_size ); printf( "final: %s\n", _final_buf ); free(_dst_buf); return 0; }
關(guān)于C語言中怎么利用DES模塊實現(xiàn)加密功能問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設公司行業(yè)資訊頻道了解更多相關(guān)知識。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。