openssl对数组加密解密的完整实现代码
本例是用C实现的对一个数组进行加密,加密到第二个数组,然后解密到另一个数组的完整实现代码。
- #include <stdio.h>
- #include <string.h>
- #include "openssl/evp.h"
- #include "openssl/x509.h"
- static void disp(void * pbuf,int size)
- { int i=0;
- for( i=0;i<size;i++)
- printf("%02x ",*((unsigned char *)pbuf+i));
- putchar('\n');
- }
- /*
- * key:加密密钥,一般设置位24,不知为啥
- * iv:加密初始向量
- * in_enc:明文数组,输入数组
- * out_enc:加密后的数组,输出密文数组
- * in_len:明文长度
- * out_len:密文长度
- * */
- //加密函数
- int EncryptBuffer(unsigned char * key,unsigned char *iv,unsigned char * in_enc, unsigned char *out_enc,int in_len,int *out_len)
- {
- ;
- int outl; //第一次使用update加密的数据长度
- int outl2; //剩余的字段,经过final填充后的长度
- int inl;
- int rv;
- EVP_CIPHER_CTX ctx;
- EVP_CIPHER_CTX_init(&ctx); //初始化ctx
- rv = EVP_EncryptInit_ex(&ctx,EVP_des_ede3_ecb(),NULL,key,iv); //设置密码算法、key和iv
- if(rv != 1)
- {
- printf("Err\n");
- return -1;
- }
- inl=in_len;
- rv = EVP_EncryptUpdate(&ctx,out_enc,&outl,in_enc,in_len);//加密
- if(rv != 1)
- {
- printf("Err\n");
- return -1;
- }
- //加密结束
- rv = EVP_EncryptFinal_ex(&ctx,out_enc+outl,&outl2);
- if(rv != 1)
- {
- EVP_CIPHER_CTX_cleanup(&ctx);
- return -1;
- }
- *out_len=outl+outl2;
- EVP_CIPHER_CTX_cleanup(&ctx); //清除EVP加密上下文环境
- printf("加密已完成\n");
- }
- /*
- * key:加密密钥,一般设置位24,不知为啥
- * iv:加密初始向量
- * in_dec:密文数组,输入数组
- * out_dec:解密后的数组,输出数组
- * in_len:密文长度
- * out_len:明文长度
- * */
- //解密函数
- int DecryptBuffer(unsigned char * key,unsigned char *iv,unsigned char * in_dec, unsigned char *out_dec,int in_len,int *out_len)
- {
- int outl; //第一次使用update解密的数据长度
- int outl2; //剩余的字段,经过final解密并去除填充后的长度
- int rv;
- EVP_CIPHER_CTX ctx;
- //初始化ctx
- EVP_CIPHER_CTX_init(&ctx);
- //设置解密的算法、key和iv
- rv = EVP_DecryptInit_ex(&ctx,EVP_des_ede3_ecb(),NULL,key,iv);
- if(rv != 1)
- {
- EVP_CIPHER_CTX_cleanup(&ctx);
- return -1;
- }
- //循环读取原文,解密后后保存到明文文件。
- rv = EVP_DecryptUpdate(&ctx,out_dec,&outl,in_dec,in_len);//解密
- if(rv != 1)
- {
- EVP_CIPHER_CTX_cleanup(&ctx);
- return -1;
- }
- //解密结束
- rv = EVP_DecryptFinal_ex(&ctx,out_dec+outl,&outl2);
- if(rv != 1)
- {
- EVP_CIPHER_CTX_cleanup(&ctx);
- return -1;
- }
- *out_len=outl+outl2;
- EVP_CIPHER_CTX_cleanup(&ctx);//清除EVP加密上下文环境
- printf("解密已完成\n");
- }
- int main()
- {
- int len=128+4;
- int dec_len,len2;
- unsigned char key[EVP_MAX_KEY_LENGTH]; //保存密钥的数组
- unsigned char iv[EVP_MAX_KEY_LENGTH]; //保存初始化向量的数组
- //EVP加密上下文环境
- unsigned char out[len+EVP_MAX_KEY_LENGTH]; //保存加密后明文的缓冲区数组
- unsigned char dec[len+EVP_MAX_KEY_LENGTH]; //保存解密后明文的缓冲区数组
- unsigned char in[len+EVP_MAX_KEY_LENGTH]; //保存原文的缓冲区
- int i=0;
- //设置key和iv
- for(i=0;i<8;i++)
- {
- key[i]=i;
- }
- for(i=0;i<8;i++)
- {
- iv[i]=i;
- }
- for(i=0;i<len;i++)
- {
- in[i]=i;
- }
- disp(in,len);
- EncryptBuffer(key,iv,in,dec,len,&dec_len);
- printf("dec_len:%d\n",dec_len);
- disp(dec,dec_len);
- DecryptBuffer(key,iv,dec,out,dec_len,&len2);
- disp(out,len2);
- printf("解密候数据长度:%d\n",len2);
- return 0;
- }
http://blog.csdn.net/xueyushenzhou/article/details/23281675
openssl对数组加密解密的完整实现代码的更多相关文章
- openssl evp RSA 加密解密
openssl evp RSA 加密解密 可以直接使用RSA.h 提供的接口 如下测试使用EVP提供的RSA接口 1. EVP提供的RSA 加密解密 主要接口: int EVP_PKEY_encryp ...
- OpenSSL 中 RSA 加密解密实现源代码分析
1.RSA 公钥和私钥的组成.以及加密和解密的公式: 2.模指数运算: 先做指数运算,再做模运算.如 5^3 mod 7 = 125 mod 7 = 6 3.RSA加密算法流程: 选择一对不同的.而且 ...
- CryptoAPI与openssl RSA非对称加密解密(PKCS1 PADDING)交互
(以下代码中都只做测试用,有些地方没有释放内存...这个自己解决下) 1.RSA非对称的,首先提供一个供测试用的证书和私钥的数据 1)pem格式的证书和私钥(公私钥是对应的)的base64编码 voi ...
- AES字节数组加密解密流程
AES类时微软MSDN中最常用的加密类,微软官网也有例子,参考链接:https://docs.microsoft.com/zh-cn/dotnet/api/system.security.crypto ...
- 利用openssl进行RSA加密解密
openssl是一个功能强大的工具包,它集成了众多密码算法及实用工具.我们即可以利用它提供的命令台工具生成密钥.证书来加密解密文件,也可以在利用其提供的API接口在代码中对传输信息进行加密. RSA是 ...
- 用openssl库RSA加密解密
#include <stdio.h> #include <openssl/rsa.h> #include <openssl/pem.h> #include < ...
- C++调用openssl实现DES加密解密cbc模式 zeropadding填充方式 pkcs5padding填充方式 pkcs7padding填充方式
============================================== des cbc 加密 zeropadding填充方式 ======================= ...
- openssl RSA基本加密解密
#include <stdio.h> #include <string.h> #include <stdlib.h> #include <openssl/bn ...
- 提供openssl -aes-256-cbc兼容加密/解密的简单python函数
原文链接:http://joelinoff.com/blog/?p=885 这里的示例显示了如何使用python以与openssl aes-256-cbc完全兼容的方式加密和解密数据.它是基于我在本网 ...
随机推荐
- 为什么memset的第二个参数不把int替换成char
memset是一个经常被用来初始化数组的函数,其定义如下: 1 void * memset ( void * ptr, int value, size_t num ); 它的效果大致是把以ptr为起始 ...
- Android项目使用support v7时遇到的各种问题
Android项目使用support v7时遇到的各种问题 点击你的工程右键-->Properties-->Android 1.查看你引用的appcompat_v7包是否引用正确 2.用较 ...
- Thread的run()与start()的区别
Java的线程是通过java.lang.Thread类来实现的.VM启动时会有一个由主方法所定义的线程.可以通过创建Thread的实例来创建新的线程.每个线程都是通过某个特定Thread对象所对应的方 ...
- Linux企业级项目实践之网络爬虫(1)——项目概述及准备工作
我们在学习了Linux系统编程之后,需要一些实战项目来提高自己的水平,本系列我们通过编写一个爬虫程序,将我们学习的知识进行综合应用,同时在实现项目的过程中逐渐养成一些有用的思维方式,并具有初步的软件开 ...
- Enum Types
参考Java的官方tutorial和Doc整理如下. What is Enum An enum type is a special data type. It enables for a variab ...
- C# - List操作 - 按照字母排序
有Family的类如下: public class FamilyModel { public string Name { set; get; } } 创建List List<FamilyMode ...
- mac复制粘贴剪切
win下复制粘贴剪切: Ctrl+C,Ctrl+V,Ctrl+X; mac下lion之后已经有了一直让win用户吐槽的剪切功能: 复制粘贴剪切:Command+C,Command+V,Command+ ...
- Visual Studio 2008项目中WinForm窗口图标显示为类图标,仅仅能打开代码而无法打开视图问题解决
背景: 今天打开一个Winform项目的时候.图标显示为类文件的样子而不是窗口的样子,在代码中右键也没有View Designer选项.双击图标打开的是代码而非窗口设计界面,百度后也没 ...
- HDU2111 Saving HDU 【贪心】
Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- Android-它们的定义Dialog
Android-它们的定义Dialog 2014年4月27日 星期天 天气晴朗 心情平静 本篇博文来分享一个也是开发中常常须要用到的功能-自己定义对话框,这里我用到了Android中的图形资源shap ...