openssl之EVP系列之1---算法封装

    ---依据openssl doc/crypto/EVP.pod翻译和自己的理解写成

    (作者:DragonKing, Mail: wzhah@263.net ,公布于:http://openssl.126.com 之openssl专业论坛,版本号:openssl-0.9.7)

    

    EVP系列的函数定义包括在"evp.h"里面。这是一系列封装了openssl加密库里面全部算法的函数。

通过这种统一的封装,使得仅仅须要在初始化參数的时候做非常少的改变,就能够使用同样的代码但採用不同的加密算法进行数据的加密和解密。

EVP系列函数主要封装了三大类型的算法。要支持所有这些算法。请调用OpenSSL_add_all_algorithms函数,以下分别就其结构作一个简单的介绍。

【公开密钥算法】

    函数名称:EVP_Seal*...*。EVP_Open*...*

    功能描写叙述:该系列函数封装提供了公开密钥算法的加密和解密功能,实现了电子信封的功能。

    相关文件:p_seal.c,p_open.c

    【数字签名算法】

    函数名称:EVP_Sign*...*,EVP_Verify*...*

    功能描写叙述:该系列函数封装提供了数字签名算法和功能。

相关文件:p_sign.c,p_verify.c

    【对称加密算法】

    函数名称:EVP_Encrypt*...*

    功能描写叙述:该系列函数封装提供了对称加密算法的功能。

    相关文件:evp_enc.c,p_enc.c,p_dec.c,e_*.c

    【信息摘要算法】

    函数名称:EVP_Digest*...*

    功能描写叙述:该系列函数封装实现了多种信息摘要算法。

    相关文件:digest.c,m_*.c

    【信息编码算法】

    函数名称:EVP_Encode*...*

    功能描写叙述:该系列函数封装实现了ASCII码与二进制码之间的转换函数和功能。

    相关文件:encode.c

    

    注意:

    自从出现engin版本号以后,全部对称加密算法和摘要算法能够用ENGINE模块实现的算法取代。

假设ENGINE模块实现的对称加密和信息摘要函数被注冊为缺省的实现算法,那么当使用各种EVP函数时,软件编译的时候会自己主动将该实现模块连接进去。

openssl之EVP系列之1---算法封装的更多相关文章

  1. openssl之EVP系列之7---信息摘要算法结构概述

    openssl之EVP系列之7---信息摘要算法结构概述     ---依据openssl doc/crypto/EVP_DigestInit.pod翻译和自己的理解写成     (作者:Dragon ...

  2. openssl之EVP系列之12---EVP_Seal系列函数介绍

    openssl之EVP系列之12---EVP_Seal系列函数介绍     ---依据openssl doc/crypto/EVP_SealInit.pod翻译和自己的理解写成     (作者:Dra ...

  3. openssl之EVP系列之2---对称加密算法概述

    openssl之EVP系列之2---对称加密算法概述     ---依据openssl doc/crypto/EVP_EncryptInit.pod和doc/ssleay.txt cipher.doc ...

  4. openssl之EVP系列之13---EVP_Open系列函数介绍

    openssl之EVP系列之13---EVP_Open系列函数介绍     ---依据openssl doc/crypto/EVP_OpenInit.pod翻译和自己的理解写成     (作者:Dra ...

  5. openssl之EVP系列之9---EVP_Digest系列函数的一个样例

    openssl之EVP系列之9---EVP_Digest系列函数的一个样例     ---依据openssl doc/crypto/EVP_DigestInit.pod翻译     (作者:Drago ...

  6. openssl之EVP系列之8---EVP_Digest系列函数具体解释

    openssl之EVP系列之8---EVP_Digest系列函数具体解释     ---依据openssl doc/crypto/EVP_DigestInit.pod翻译和自己的理解写成     (作 ...

  7. openssl之EVP系列之11---EVP_Verify系列函数介绍

    openssl之EVP系列之11---EVP_Verify系列函数介绍     ---依据openssl doc/crypto/EVP_VerifyInit.pod翻译和自己的理解写成     (作者 ...

  8. openssl之EVP系列之6---EVP_Encrypt系列函数编程架构及样例

    openssl之EVP系列之6---EVP_Encrypt系列函数编程架构及样例     ---依据openssl doc/crypto/EVP_EncryptInit.pod和doc/ssleay. ...

  9. openssl之EVP系列之10---EVP_Sign系列函数介绍

    openssl之EVP系列之10---EVP_Sign系列函数介绍     ---依据openssl doc/crypto/EVP_SignInit.pod翻译     (作者:DragonKing, ...

随机推荐

  1. POJ 2451 Uyuw's Concert(半平面交nlgn)

    //#pragma comment(linker, "/STACK:16777216") //for c++ Compiler #include <stdio.h> # ...

  2. django学习之Model(四)MakingQuery

    上一篇写到MakingQuey中的filter,本篇接着来. 10)-扩展多值的关系 如果对一个ManyToManyField或ForeignKey的表进行filter过滤查询的话,有2中方法可以用. ...

  3. 基于visual Studio2013解决算法导论之013基数排序

     题目 基数排序 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <malloc.h> #in ...

  4. [置顶] 63行代码完美实现html5 贪吃蛇游戏

    以前也很少关注html5,感觉选择html已经慢慢成为趋势,想了解下.就找了个游戏学习了,写完这个游戏感觉html5和js结合很紧密,如果js不是特别好.估计需要先补习下js,这个只是个人的建议,不一 ...

  5. A_全然背包

    /* copyright: Grant Yuan algorithm: 全然背包 time : 2014.7.18 __________________________________________ ...

  6. debian支持ll命令

    debian支持ll命令 $ ll -bash: ll: command not found 没有ll这个命令.尽管也知道ll事实上 是ls -l 这个命令的别名,可是总感觉不是非常习惯.由于之前一直 ...

  7. 配置免安装版JAVA1.7的环境变量

    我用的是免安装版JAVA1.7,假设想获取JDK能够联系问我要. 1.開始配置环境变量,右击[我的电脑]---[属性]-----[高级]---[环境变量],如图: 2.选择[新建系统变量]--弹出&q ...

  8. 基于JSP+SERVLET的新闻发布系统(三)

    拖了这么久..今天把栏目管理还有新闻管理模块的也挂出来.. 栏目管理跟用户管理一样. 这里重点讲解新闻管理. 效果图如上: 1,可选择栏目类别,且栏目类别是动态生成的. 默认生成的文章是未审核状态的. ...

  9. Domain(AD) 管理

    新建账户 文件夹权限管理

  10. 三种LVS负载均衡技术的优缺点----负载均衡调度算法

    三种LVS负载均衡技术的优缺点归纳以下表: VS/NATVS/TUNVS/DR 服务器操作系统任意支持隧道多数(支持Non-arp) 服务器网络私有网络局域网/广域网局域网 服务器数目(100M网络) ...