安装openssl及实现RSA加密解密的详细步骤

1.openssl的安装


从官网上下载你需要的openssl版本,既有Linux平台下的,又有windows平台下的,其中Linux平台下的安装很简单,直接一个apt-get(Ubuntu)命令即可,

这里介绍Windows平台下的安装。

点击Win32OpenSSL-1_0_1i对应的安装文件,安装完后可以看到目C:\OpenSSL-Win32,其中包含了OpenSSL的各类文件。

如下图所示:


C:\OpenSSL-Win32\bin添加到环境变量path中,将C:\OpenSSL-Win32下的includelib目录拷贝到C:\ProgramFiles\Microsoft Visual Studio 9.0\VC中。下面开始测试openssl命令:


下面来看一个openssl应用的例子:

密钥在文件key.txt中,用des3算法对文件test.data进行加密和解密,并验证其正确性



2. 利用OpenSSL编程实现RSA加密、解密


首先是编写cryptoDemo.cpp程序

#include <memory.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#include "openssl\aes.h"

#pragma comment(lib,"libeay32.lib")

void testAes(char inString[], int inLen, char passwd[], int pwdLen)
{
	int i,j, len, nLoop, nRes;
	char enString[1024];
	char deString[1024];

	unsigned char buf[16];
	unsigned char buf2[16];
	unsigned char aes_keybuf[32];
	AES_KEY aeskey;

	// 准备32字节(256位)的AES密码字节
	memset(aes_keybuf,0x90,32);
	if(pwdLen<32){ len=pwdLen; } else { len=32;}
	for(i=0;i<len;i++) aes_keybuf[i]=passwd[i];
	// 输入字节串分组成16字节的块	
	nLoop=inLen/16; nRes = inLen%16;
	// 加密输入的字节串
	AES_set_encrypt_key(aes_keybuf,256,&aeskey);
	for(i=0;i<nLoop;i++){
		memset(buf,0,16);
		for(j=0;j<16;j++) buf[j]=inString[i*16+j];
		AES_encrypt(buf,buf2,&aeskey);
		for(j=0;j<16;j++) enString[i*16+j]=buf2[j];
	}
	if(nRes>0){
		memset(buf,0,16);
		for(j=0;j<nRes;j++) buf[j]=inString[i*16+j];
		AES_encrypt(buf,buf2,&aeskey);
		for(j=0;j<16;j++) enString[i*16+j]=buf2[j];
		//puts("encrypt");
	}
	enString[i*16+j]=0;
	// 密文串的解密	
	AES_set_decrypt_key(aes_keybuf,256,&aeskey);
	for(i=0;i<nLoop;i++){
		memset(buf,0,16);
		for(j=0;j<16;j++) buf[j]=enString[i*16+j];
		AES_decrypt(buf,buf2,&aeskey);
		for(j=0;j<16;j++) deString[i*16+j]=buf2[j];
	}
	if(nRes>0){
		memset(buf,0,16);
		for(j=0;j<16;j++) buf[j]=enString[i*16+j];
		AES_decrypt(buf,buf2,&aeskey);
		for(j=0;j<16;j++) deString[i*16+j]=buf2[j];
		//puts("decrypt");
	}
	deString[i*16+nRes]=0;
	//比较解密后的串是否与输入的原始串相同
	if(memcmp(inString,deString,strlen(inString))==0)
	{ printf("test success\r\n");} else { printf("test fail\r\n");}
   	printf("The original string is:\n  %s ", inString);
   	printf("The encrypted string is:\n  %s ", enString);
   	printf("The decrypted string is:\n  %s ", deString);
}

int main(int argc, char* argv[])
{
	char inString[] = "This is a sample. I am a programer.\n";
	char passwd[] = "0123456789ABCDEFGHIJK";

	testAes(inString, strlen(inString), passwd, strlen(passwd));

	return 0;
}

然后编译、链接、执行,参见截图:


充分发挥你的想象力吧,看看它能做些什么

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值