`
yidongkaifa
  • 浏览: 4059726 次
文章分类
社区版块
存档分类
最新评论

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;

分享到:
评论

相关推荐

    Encrypt-Decrypt-with-OpenSSL---RSA:使用openssl进行数据加密和解密-RSA

    使用OpenSSL-RSA加密解密 什么是OpenSSL? OpenSSL是开放源代码库,可使用TLS(传输安全层)和SSL(安全套接字层)在网络上提供安全通信。 它支持许多加密算法AES,DSA,RSA,SHA1,SHA2,MD5。。有关更多信息 什么...

    openssl中的rsa等算法的使用示例

    一个简单的程序,通过调用openssl中的RSA加密算法对明文加密,然后用MD5算法提取明文摘要,最后用RSA算法对密文解密,简单演示了数字签名的过程。 其中,加密过程采用CBC模式,分块长度为256位,最后一个分块不足一...

    基于OPENSSL的加密算法工具

    OpenSSL是一个强大的安全套接字层密码库,Apache使用它加密HTTPS,OpenSSH使用它加密SSH,但是,你不应该只将其作为一个库来...本工具调用了OPENSSL中的加密算法库,用来实现包含DES、AES、RSA以及摘要算法的加解密。

    openssl-0.9.8m.tar.gz

    openssl-0.9.8m.tar.gz ,里面包含了大部分的加密算法,包括RSA,AES加密,经过本人测试。该源码网上有,也可以从官网上下载

    openssl-1.0.0a

     OpenSSL一共实现了4种非对称加密算法,包括DH算法、RSA算法、DSA算法和椭圆曲线算法(EC)。DH算法一般用户密钥交换。RSA算法既可以用于密钥交换,也可以用于数字签名,当然,如果你能够忍受其缓慢的速度,那么也...

    c++通过openssl实现rsa加密解密【windows版】

    c++通过使用openssl实现rsa加密解密算法,网上有很多文章和例子,但是大部分都是linux版的,并且内容不全、代码老旧等各种问题,导致最后无法调试,这里提供的源码是用code::blocks编写的c++源码,可以直接运行...

    openssl非对称加密rsa算法[归类].pdf

    openssl非对称加密rsa算法[归类].pdf

    openssl rsa算法加密

    openssl rsa算法加密,

    OpenSSL-1_0_0d_Win32

    非对称加密算法 OpenSSL一共实现了4种非对称加密算法,包括DH算法、RSA算法、DSA算法和椭圆曲线算法(EC)。DH算法一般用户密钥交换。RSA算法既可以用于密钥交换,也可以用于数字签名,当然,如果你能够忍受其缓慢的...

    php版本rsa加密算法

    php版本基于rsa算法包含公钥加密,私钥解密/私钥加密,公钥解密.使用openssl实现非对称加密

    基于OpenSSL的RSA加解密的C语言实现

    1.该程序是基于OpenSSL的使用纯C语言来实现RSA加解密的,在Linux环境下开发完成,建议在Linux环境下使用(在Windows环境下需要自行修改); 2.该程序具有生成RSA密钥对、RSA公钥加密和RSA私钥解密的功能,支持手动...

    openssl-demo:openssl 使用 RSA 加密和解密的演示,使用 sha1 签名和验证。 demo模拟了签名-加密-解密-验证的完整过程

    openssl-demo A demo of openssl encrypt & decrypt using RSA, signature & ...采用RSA算法进行加密,每100字节加密一次。(可自定义,需要注意padding为RSA_PKCS1_PADDING时需要留出11个字节的空间,也就是最多117)

    openssl RSA加解密例子

    基于openssl写的RSA的公钥加密,私钥解密,私钥加密,公钥解密的测试例子,密钥类型是rsa1024的PEM格式。

    使用openssl实现rsa非对称加密算法示例

    主要介绍了使用openssl实现rsa非对称加密算法的示例,大家参考使用吧

    使用OpenSSL实现RSA、AES、MD5算法-VS2017-C++.rar

    用OpenSSL库实现的RSA、AES和MD5算法,用C++在Visual Studio 2017上写的,RSA和AES的秘钥长度可调、生成秘钥、加密解密都可以实现。

    openssl-1.1.1p

    (3)支持各种新的加密算法 SHA3,SHA512 / 224,SHA512 / 256 EdDSA(包括Ed25519和Ed448) X448(添加到1.1.0中的现有X25519支持) 多素数RSA SM2,SM3,SM4 SipHash ARIA(包括TLS支持)

    Delphi RSA 加密解密签名验签控件 RSA_Component(1.0.0.0).rar

    RSA加密演算法是一种非对称加密演算法。在公开密钥加密和电子商业中RSA被广泛使用。 典型的应用 1. 苹果App签名, iOS App 签名的原理; 2. 支付宝签名验证 ; 2. HTTPS 加密连接; 3. 程序直接用RSA+AES加密通信 ...

    C语言不使用openssl实现RSA4096

    使用C语言实现rsa4096的加密解密操作,并将加密后的结果进行base64编码,解密之前先使用base64解码,再进行解密操作。私钥公钥操作分为两个工程,互不干扰

    OpenSSL RSA 非对称加密(VS2013,C++实现)

    生成密钥及加密解密选择密钥时不支持中文路径 其它都已经实现。 C++代码,VS2013做的mfc程序, 调用openssl库的RSA算法实现非对称加密 公钥加密,私钥解密(私钥解密时需要密码) 支持大文件

    read.rar_openssl rsa 文件_rsa openssl

    使用openssl的RSA算法对文字加密,并添加到文件中 对理解openssl有很大帮助

Global site tag (gtag.js) - Google Analytics