Openssl --RSA加密算法的使用

转载http://www.iteye.com/topic/1126997

1、Openssl --RSA加密算法的使用。

这两天简单的学习了一下openssl的使用。相关的介绍,可以在网上搜,挺多的。有些容易迷糊的概念,例如加密与身份验证,什么时候用公钥加密,什么时候用私钥。如果学习过密码学,应该很简单理解,我没学过,刚理解了些,赶紧记下,以防忘记。

用大家熟知C-S结构分析下吧:

首先请注意,公钥和私钥是一配一的,一个公钥对应一个私钥。

1)加密

客户和服务器通信,服务器要保证与客户通信的数据被保密,所以服务器会给客户一个公钥,客户用此公钥将自己的数据加密。然后将加密后的数据发给服 务器,服务器用自己的私钥解开密文还原成真的数据。公钥是可以公开的,没有必要保护它,因为你能用它加密,但是加密后,没有私钥,你确是无法解密的。即你 没法解开别人用此公钥加密的数据。你也就无法知道别人的数据。

2)身份验证

有时候服务器需要确定客户端的身份,所以需要客户端发送唯一的自己的标识,让服务器确定自己的身份。如何发呢?这就用的到私钥了。首先需要客户端 用自己的私钥将特征码加密后,将此数据发给服务器,服务器将使用你的公钥对密文进行解密,如果解密成功可唯一确定这是用你的私钥加密的密文。只要你不泄露 私钥,那么使用私钥的人肯定是你。其实这个逻辑挺简单的。


简单地做了一个例子。

  1. [代码]c#/cpp/oc代码:

    01 C代码 收藏代码
    02
    03 constchar* input ="fffffff fffff==\"~!@#$^ &* ()-_=+|?/.,`%%\"";
    04
    05 RSA *_rsa = RSA_generate_key(1024,RSA_F4,NULL,NULL);
    06
    07
    08 //encrypt with private key
    09 intflen = RSA_size(_rsa);
    10 char*encData = (char*)malloc(flen);
    11 bzero(encData, flen);
    12
    13 //encrypt
    14 intstatus = RSA_private_encrypt(flen,
    15 (unsignedchar*)input,
    16 (unsignedchar*)encData,
    17 _rsa,
    18 RSA_NO_PADDING);
    19 if(status) {
    20 NSData *data = [NSData dataWithBytes:encData length:status];
    21
    22 flen = RSA_size(_rsa);
    23 char*decData = (char*)malloc(flen);
    24 bzero(decData, flen);
    25
    26 //decrypt
    27 status = RSA_public_decrypt(flen,
    28 (unsignedchar*)[data bytes],
    29 (unsignedchar*)decData,
    30 _rsa,
    31 RSA_NO_PADDING);
    32 if(status) {
    33 NSLog(@"\n ------------\ndecData is %s\n---------------\n",decData);
    34
    35 }else
    36 NSLog(@"----error RSA_public_decrypt");
    37
    38 free(decData);
    39 encData = NULL;
    40 }else
    41 NSLog(@"----error RSA_private_encrypt");
    42
    43 free(encData);
    44 encData = NULL;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值