iOS MD5 算法

- (NSString *)MD5Hash

{

const char *cStr = [self UTF8String];//转化为utf-8

unsigned char result[16];//开辟一个16字节(128位:md5加密出来就是128位/bit)的空间(一个字节=8字位=8个二进制数)

           /* extern unsigned char *CC_MD5(const void *data, CC_LONG len, unsigned char *md)官方封装好的加密方法,把cStr字符串转换成了32位的16进制数列(这个过程不可逆转) 存储到了result这个空间中*/

CC_MD5(cStr, strlen(cStr), result);//

return [NSString stringWithFormat:

@"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X",

result[0], result[1], result[2], result[3], 

result[4], result[5], result[6], result[7],

result[8], result[9], result[10], result[11],

result[12], result[13], result[14], result[15]];

/* x表示十六进制,%02X  意思是不足两位将用0补齐,如果多余两位则不影响

 NSLog("%02X", 0x888);  //888

NSLog("%02X", 0x4); //04

*/

MD5加密算法多数用于验证,比如说密码匹配用的就是MD5加密后得到的数值。

输出方式用一个for循环来解决更为方便

NSMutableString *Mstr = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH];

    for (int i=0; i<CC_MD5_DIGEST_LENGTH; i++) {

        [Mstr appendFormat:@"%02X",result[i]];

    }

  •  return Mstr;

    MD5算法 不管是什么语言得到的结果都是一样的.可能会有人遇到过ios客户端和java服务器端匹配MD5值会有不一样的,我猜测:并不是算   法有问题,可能是某一方求MD5值少了一步,直接这样搞定的

  • NSMutableString *Mstr = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH];

        for (int i=0; i<CC_MD5_DIGEST_LENGTH; i++) {

            [Mstr appendFormat:@"%d",(char)result[i]];

        }

     return Mstr;


}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值