這篇文章主要講解了“C語(yǔ)言如何利用DES模塊實(shí)現(xiàn)加密功能”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“C語(yǔ)言如何利用DES模塊實(shí)現(xiàn)加密功能”吧!
成都創(chuàng)新互聯(lián)-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比東海網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式東海網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋東海地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴(lài)。
DES(Data Encryption Standard)
DES一度是電子數(shù)據(jù)對(duì)稱(chēng)加密的主導(dǎo)者。他影響了現(xiàn)代加密學(xué)。最早是在IBM于1970年基于更早的Horst Feistel的設(shè)計(jì)而開(kāi)發(fā)出來(lái)的,算法應(yīng)美國(guó)國(guó)家標(biāo)準(zhǔn)局(NBSNational_Bureau_of_Standards) National Bureau of Standards)代理人的邀請(qǐng)加入對(duì)美國(guó)政府敏感電子數(shù)據(jù)加密的候選方案。在1976年,經(jīng)過(guò)和美國(guó)國(guó)家安全局(NSA)磋商,NBS最終選擇了一個(gè)精簡(jiǎn)版本在1977年發(fā)布。
如今在很多應(yīng)用的加密還是會(huì)考慮使用DES。這個(gè)主要由于56-byte key size
AES(Advanced Encryption Standard)
是美國(guó)聯(lián)邦政府采用的一種區(qū)塊加密標(biāo)準(zhǔn)。這個(gè)標(biāo)準(zhǔn)用來(lái)替代原先的DES,已經(jīng)被多方分析且廣為全世界所使用。經(jīng)過(guò)五年的甄選流程,高級(jí)加密標(biāo)準(zhǔn)由美國(guó)國(guó)家標(biāo)準(zhǔn)與技術(shù)研究院(NIST)于2001年11月26日發(fā)布于FIPS PUB 197,并在2002年5月26日成為有效的標(biāo)準(zhǔn)。2006年,高級(jí)加密標(biāo)準(zhǔn)已然成為對(duì)稱(chēng)密鑰加密中最流行的算法之一。
編譯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 <openssl/des.h> #include <openssl/pkcs7.h> #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; }
編譯運(yùn)行
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' ) ) )
測(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; }
感謝各位的閱讀,以上就是“C語(yǔ)言如何利用DES模塊實(shí)現(xiàn)加密功能”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)C語(yǔ)言如何利用DES模塊實(shí)現(xiàn)加密功能這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
本文題目:C語(yǔ)言如何利用DES模塊實(shí)現(xiàn)加密功能
文章地址:http://m.newbst.com/article0/jhshoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、、標(biāo)簽優(yōu)化、網(wǎng)站策劃、ChatGPT、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)