您的位置:首页 > 其它

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

2014-01-11 16:02 381 查看
第一个函数:

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--;
    }
}


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

下一篇准备讲解伪随机数发生器。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: