C語言中怎么利用DES模塊實現(xiàn)加密功能,針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

DES(Data Encryption Standard)
DES一度是電子數(shù)據(jù)對稱加密的主導(dǎo)者。他影響了現(xiàn)代加密學(xué)。最早是在IBM于1970年基于更早的Horst Feistel的設(shè)計而開發(fā)出來的,算法應(yīng)美國國家標(biāo)準(zhǔn)局(NBSNational_Bureau_of_Standards) National Bureau of Standards)代理人的邀請加入對美國政府敏感電子數(shù)據(jù)加密的候選方案。在1976年,經(jīng)過和美國國家安全局(NSA)磋商,NBS最終選擇了一個精簡版本在1977年發(fā)布。
如今在很多應(yīng)用的加密還是會考慮使用DES。這個主要由于56-byte key size
AES(Advanced Encryption Standard)
是美國聯(lián)邦政府采用的一種區(qū)塊加密標(biāo)準(zhǔn)。這個標(biāo)準(zhǔn)用來替代原先的DES,已經(jīng)被多方分析且廣為全世界所使用。經(jīng)過五年的甄選流程,高級加密標(biāo)準(zhǔn)由美國國家標(biāo)準(zhǔn)與技術(shù)研究院(NIST)于2001年11月26日發(fā)布于FIPS PUB 197,并在2002年5月26日成為有效的標(biāo)準(zhǔn)。2006年,高級加密標(biāo)準(zhǔn)已然成為對稱密鑰加密中最流行的算法之一。
編譯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;
}編譯運行
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)站建設(shè)公司行業(yè)資訊頻道了解更多相關(guān)知識。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.chinadenli.net,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
標(biāo)題名稱:C語言中怎么利用DES模塊實現(xiàn)加密功能-創(chuàng)新互聯(lián)
轉(zhuǎn)載來于:http://www.chinadenli.net/article12/dpodgc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、營銷型網(wǎng)站建設(shè)、ChatGPT、微信公眾號、Google、網(wǎng)站維護
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容