OPENSSL安装 以及使用openssl中的AES加密和解密

OPENSSL安装:(VS)

  1:第一步和所有的软件安装一样。

 2:将OPENSSL中INLUCDE 和 LIB 分别拷贝到VS中VC的INLUCDE 和LIB目录下(我的机器上的目录是:C:\Program Files\Microsoft Visual Studio 10.0\VC。

 3:在VS中项目的属性中,添加链接库,include链接库

如下图:

 

(1)添加链接库

加入下图红色的LIB

(2)添加INCLUDE文件,指向OPENSSL的INCLUDE文件夹

 

搞定!!

下面是源码!

#pragma once

//#include "targetver.h"

#include <stdio.h>
#include <tchar.h>
#include "openssl/evp.h"
#include "openssl/rsa.h"
#include "openssl/aes.h"
#include "openssl/rand.h"

#include<iostream>
using namespace std;

void main()
{
    bool do_encrypt(unsigned char *iv,unsigned char *key,unsigned char *inBuffer,int inLen,unsigned char *outBuffer,int * pOutLen);
    bool do_decrypt(unsigned char *iv,unsigned char *key,unsigned char *inBuffer,int inLen,unsigned char *outBuffer,int * pOutLen);
    void print_hex(unsigned char *buf,unsigned int len);
    void print_char(unsigned char *buf,unsigned int len);

char RIV[] = "helloUSTCThisCourseIsCalledInformationSecurtiy";
unsigned char iv[16];
unsigned char *inBuffer=new unsigned char[];
unsigned char *aseOutBuffer=new unsigned char[];

unsigned char key[16]="this'is'a'test!";
char c=' ';
int i=0,outLen,inLen;

for (int k=0;k<16;k++)
{
int x = rand()%sizeof(RIV);
iv[k] = RIV[x];
}
cout<<"请输入需要加密的明文,以*作为结束符:";
while(c!='*')
{
c=getchar();
inBuffer[i++]=c;
}
cout<<endl;
do_encrypt(iv,key,inBuffer,i-1,aseOutBuffer,&outLen);
cout<<"使用AES进行加密,生成的密文为:";
print_hex(aseOutBuffer,outLen);
cout<<endl<<endl;

do_decrypt(iv,key,aseOutBuffer,outLen,inBuffer,&inLen);
cout<<"使用AES进行解密,解密得到明文为:";
print_hex(inBuffer,inLen);
cout<<endl;
cout<<"即:";
print_char(inBuffer,inLen);
cout<<endl<<endl;
system("pause");
}

   bool do_encrypt(unsigned char *iv,unsigned char *key,unsigned char *inBuffer,int inLen,unsigned char *outBuffer,int * pOutLen)
{
    int tmplen;
    EVP_CIPHER_CTX ctx;
    EVP_CIPHER_CTX_init(&ctx);
    EVP_EncryptInit_ex(&ctx,EVP_aes_128_cbc(),NULL,key,iv);
    
    if(!EVP_EncryptUpdate(&ctx,outBuffer,pOutLen,inBuffer,inLen))
    {
        return false;
    }
    
    if(!EVP_EncryptFinal_ex(&ctx,outBuffer+*pOutLen,&tmplen))
    {
        return false;
    }
*pOutLen+=tmplen;
EVP_CIPHER_CTX_cleanup(&ctx);
    return true;
}

  bool do_decrypt(unsigned char *iv,unsigned char *key,unsigned char *inBuffer,int inLen,unsigned char *outBuffer,int * pOutLen)
{
        int tmplen;
        EVP_CIPHER_CTX ctx;
        EVP_CIPHER_CTX_init(&ctx);
        EVP_DecryptInit_ex(&ctx,EVP_aes_128_cbc(),NULL,key,iv);
        if(!EVP_DecryptUpdate(&ctx,outBuffer,pOutLen,inBuffer,inLen))
        {
        return false;
        }
        if(!EVP_DecryptFinal_ex(&ctx,outBuffer+*pOutLen,&tmplen))
        {
        return false;
        }
        *pOutLen+=tmplen;
        EVP_CIPHER_CTX_cleanup(&ctx);
        return true;
}

 void print_hex(unsigned char *buf,unsigned int len)
{
    for(int i=0;i<len;i++)
        printf("%0.2x",buf[i]);
}

 void print_char(unsigned char *buf,unsigned int len)//字符形式显示数组内容
{
    for(int i=0;i<len;i++)
        printf("%c",buf[i]);
    
}

 

 

转载于:https://www.cnblogs.com/shenghaishiweini/p/3375124.html

OpenSSL和cURL都是常用的加密和网络通信库,为很多开源项目和应用程序提供了安全和通信功能的支持。 OpenSSL是一个强大的开源加密库,提供了一系列加密算法和协议的实现,如SSL/TLS、RSA、AES等。它不仅可以用于数据加密和身份验证,还可以进行证书管理和数字签名等操作。OpenSSL作为一个动态库可以被其他应用程序链接和使用。 cURL是一个功能强大的开源网络传输工具,支持多种网络协议如HTTP、FTP、SMTP等。它可以用于文件上传、下载和访问远程资源,还可以进行cookie管理和代理配置等。cURL同样作为一个动态库可以被其他应用程序链接和使用。 在使用这两个库时,需要注意以下几点: 1. 功能和用途:OpenSSL主要用于加密和安全通信,提供了各种加密算法和协议的实现,而cURL主要用于网络传输和资源访问。根据实际需求选择合适的库。 2. 兼容性:根据项目的需求,选择适合的OpenSSL和cURL版本。确保库版本与操作系统、编译器和其他依赖库之间的兼容性。 3. 安全性和漏洞修复:由于OpenSSL和cURL是开源项目,会不断发布新的版本来修复安全漏洞和错误。及时更新到最新版本可以提高应用程序的安全性。 4. API和文档:了解和熟悉OpenSSL和cURL提供的API和文档,可以更好地使用它们的功能和特性。这样可以减少错误和提高代码质量。 总结而言,OpenSSL和cURL是两个重要的动态库,分别提供了加密和安全通信、网络传输和资源访问的功能。在使用时,需要根据项目需求选择合适的库版本,并了解其API和文档,以确保应用程序的安全和正确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值