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

      

    

 第一个函数:

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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值