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

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

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

    

    该系列函数封装了openssl加密库全部的信息摘要算法,通过这样的EVP封装,当使用不同的信息摘要算法时,仅仅须要对初始化參数改动一下就能够了,其他代码能够全然一样。这些算法包含MD2、MD5以及SHA等算法。

    【EVP_MD结构介绍】

    全部的算法都维护着以下定义的结构的一个指针,在此基础上实现了算法的功能。该结构EVP_MD例如以下:

    typedef struct env_md_st

    { 

     int type;

     int pkey_type;

     int md_size;

     unsigned long flags;

     int (*init)(EVP_MD_CTX *ctx);

     int (*update)(EVP_MD_CTX *ctx,const void *data,unsigned long count);

     int (*final)(EVP_MD_CTX *ctx,unsigned char *md);

     int (*copy)(EVP_MD_CTX *to,const EVP_MD_CTX *from);

     int (*cleanup)(EVP_MD_CTX *ctx);

     int (*sign)();

     int (*verify)();

     int required_pkey_type[5]; /*EVP_PKEY_xxx */

     int block_size;

     int ctx_size; 

    } EVP_MD;

    以下对该结构体的部分參数解释:

    type——信息摘要算法的NID标识

    pkey_type——是信息摘要-签名算法体制的对应NID标识,如NID_shaWithRSAEncryption

    md_size——是信息摘要算法生成的信息摘要的长度,如SHA算法是SHA_DIGEST_LENGTH,该值是20

    init——指向一个特定信息摘要算法的初始化函数。如对于SHA算法,指针指向SHA_Init

    update——指向一个真正计算摘要值的函数,比如SHA算法就是指向SHA_Update

    final——指向一个信息摘要值计算之后要调用的函数,该函数完毕最后的一块数据的处理工作。比如SHA算法就是指向SHA_Final.

    copy——指向一个能够在两个EVP_MD_CTX结构之间拷贝參数值的函数

    required_pkey_type——指向一个用来签名的算法EVP_PKEY的类型,如SHA算法就指向EVP_PKEY_RSA_method

    block_size——一个用来进行信息摘要的输入块的的长度(单位是字节)。如SHA算法就是SHA_CBLOCK

    ctx_size——是CTX结构的长度,在SHA算法里面应该就是sizeof(EVP_MD*)+sizeof(SHA_CTX)

    假设你要添加新的算法,那么能够定义这个结构。并进行必要的一直,然后就能够使用通用的函数了。跟EVP_CIPHER系列函数一样,使用这个封装技术,就能够在使用一种摘要算法时。比方MD5,在连接程序的时候就仅仅连接MD5的代码。假设使用证书来标识算法,那么就会导致全部其他的信息摘要算法代码都连接到程序中去了。

    【EVP_MD_CTX结构介绍】

    在调用函数的时候。一般来说须要传入上面说的type的參数和以下所定义的一个CTX结构。该结构EVP_MD_CTX定义例如以下:

    typedef struct env_md_ctx_st

    {

     const EVP_MD *digest;

     ENGINE *engine;

     unsigned long flags;

     void *md_data;

    }EVP_MD_CTX ;

    该结构的成员解释例如以下:

    digest——指向上面介绍的EVP_MD结构的指针

    engine——假设算法由ENGINE提供,该指针指向该ENGINE

    md_data——信息摘要数据

    【支持的信息摘要算法】

    EVP_md_null(void)

    EVP_md2(void)

    EVP_md4(void)

    EVP_md5(void)

    EVP_sha(void)

    EVP_sha1(void)

    EVP_dss(void)

    EVP_dss1(void)

    EVP_mdc2(void)

    EVP_ripemd160(void)

openssl之EVP系列之7---信息摘要算法结构概述的更多相关文章

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

    openssl之EVP系列之1---算法封装     ---依据openssl doc/crypto/EVP.pod翻译和自己的理解写成     (作者:DragonKing, Mail: wzhah ...

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. javascript-ajax之json学习笔记

    ajax什么时候解析json的时候用eval 1.如果是原生js实现的ajax,就需要eval转json对象 如果使用了类似jquery的js插件,里面有些方法是不需要转的,因为jquery已经帮你处 ...

  2. MAJOR-MINOR-MKDEV

    标记一下,容易忘,以免每次查代码. ./include/linux/types.h:21:typedef __u32 __kernel_dev_t; ./include/linux/types.h:2 ...

  3. mysql之log-slave-updates参数

    1.引言 使用Mysql的replication机制实现主从同步时,其是由三个线程实现了,主库一个I/O线程,从库一个I/O线程和一个SQL线程.配置时主库需要开始bin-log参数,即在配置文件中添 ...

  4. Unity3D - 使用TexturePacker打包图集以及NGUI对旋转sprites的支持

    作者:EnigmaJJ 博客地址:http://www.cnblogs.com/twjcnblog/ 在Unity中使用NGUI时,为了减少draw call,我们会将美术用到的小图打成一张图集,如图 ...

  5. 非侵入式Ajax

    基本准备 首先,新建一个ASP.NET MVC 3的空项目. 然后新增一个Model,代码如下: using System; using System.Collections.Generic; usi ...

  6. iOS开发之删除过期Provisioning Profiles方法

    1.在finder下打开go -> go to folder输入: ~/Library/MobileDevice/Provisioning Profiles 2.查看上面的列表,依照时间顺序删除 ...

  7. php zend studio 如何导入已经存在的项目

    点击 左上的   file->import ->General->在选择第二个[  Exissting ....]

  8. Servlet 打包部署

    默认情况下,Servlet 应用程序位于路径 <Tomcat-installation-directory>/webapps/ROOT 下,且类文件放在 <Tomcat-instal ...

  9. Hibernate一对多映射列表实例(使用xml文件)

    如果持久化类具有包含实体引用的列表(List)对象,则需要使用一对多关联来映射列表元素. 在这里,我们使用论坛应用场景,在论坛中一个问题有多个答案. 在这种情况下,一个问题可以有多个答案,每个答案可能 ...

  10. [转]Maven2中snapshot快照库的使用

    Post by 铁木箱子 in Java, 技术杂谈 on 2011-10-28 12:12. [转载声明] 转载时必须标注:本文来源于铁木箱子的博客http://www.mzone.cc[原文地址] ...