开源polarssl加密库使用详解之一:十六进制字符串转化为十六进制数字

来源:互联网 发布:无锡淘宝眼镜城 编辑:程序博客网 时间:2024/05/21 06:23

      

    

 第一个函数:

int unhexify(unsigned char *obuf, const char *ibuf)

在很多时候,我们要从文本中读取十六进制的密钥,或者其它信息。但是文本中是十六进制的字符,需要转换为十六进制的数字。此函就完成这样的功能。


实现代码如下:

int unhexify(unsigned char *obuf, const char *ibuf)

int unhexify(unsigned char *obuf, const char *ibuf){    unsigned char c, c2;    int len = strlen(ibuf) / 2;    assert(!(strlen(ibuf) %1)); // must be even number of bytes    while (*ibuf != 0)    {        c = *ibuf++;        if( c >= '0' && c <= '9' )            c -= '0';        else if( c >= 'a' && c <= 'f' )            c -= 'a' - 10;        else if( c >= 'A' && c <= 'F' )            c -= 'A' - 10;        else            assert( 0 );        c2 = *ibuf++;        if( c2 >= '0' && c2 <= '9' )            c2 -= '0';        else if( c2 >= 'a' && c2 <= 'f' )            c2 -= 'a' - 10;        else if( c2 >= 'A' && c2 <= 'F' )            c2 -= 'A' - 10;        else            assert( 0 );        *obuf++ = ( c << 4 ) | c2;    }    return len;}



此代码简单,有c语言基础的都应该能看懂,不懂的人可以回复我。


与之相反的,还有一个把十六进制数字转换为十六进制字符串:void hexify(unsigned char *obuf, const unsigned char *ibuf, int len)

实现代码如下:

void hexify(unsigned char *obuf, const unsigned char *ibuf, int len){    unsigned char l, h;    while (len != 0)    {        h = (*ibuf) / 16;        l = (*ibuf) % 16;        if( h < 10 )            *obuf++ = '0' + h;        else            *obuf++ = 'a' + h - 10;        if( l < 10 )            *obuf++ = '0' + l;        else            *obuf++ = 'a' + l - 10;        ++ibuf;        len--;    }}


==========================

下一篇准备讲解伪随机数发生器。

0 0
原创粉丝点击