HmacSHA256 算法

#import "AlgorithmManager.h"
#import <CommonCrypto/CommonCrypto.h>

@implementation AlgorithmManager


+ (NSString *)signWithHmacSHA256:(NSString *)input withKey:(NSString *)key{


    const char *cKey  = [key cStringUsingEncoding:NSASCIIStringEncoding];
    const char *cData = [input cStringUsingEncoding:NSASCIIStringEncoding];
    
    unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
    
    CCHmac(kCCHmacAlgSHA256, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
    
    NSData *HMACData = [[NSData alloc] initWithBytes:cHMAC length:sizeof(cHMAC)];
    
    const unsigned char *buffer = (const unsigned char *)[HMACData bytes];
    NSString *HMAC = [NSMutableString stringWithCapacity:HMACData.length * 2];
    
    for (int i = 0; i < HMACData.length; ++i)
        HMAC = [HMAC stringByAppendingFormat:@"%02lx", (unsigned long)buffer[i]];
    
    return HMAC;

}

@end

HmacSHA256 实现原理与HmacSHA1原理一样,只需要设置两个参数即可。

1. CC_SHA1_DIGEST_LENGTH -> CC_SHA256_DIGEST_LENGTH
2. kCCHmacAlgSHA1 ->kCCHmacAlgSHA256

同理 ,其它类型也可以设置。类型如下:

enum {
    kCCHmacAlgSHA1,
    kCCHmacAlgMD5,
    kCCHmacAlgSHA256,
    kCCHmacAlgSHA384,
    kCCHmacAlgSHA512,
    kCCHmacAlgSHA224
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,068评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 33,003评论 18 399
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,080评论 25 709
  • 今天二美推荐的题目是聊一聊自己最喜欢的电影。 最喜欢的电影。这个题目魔兄想了很久。 魔兄看过的电影非常多,特别喜欢...
    贾萧遥阅读 4,095评论 5 8
  • 也有过思绪泉涌的日子,每日都会写些散记,不觉厌烦,不觉枯燥。而若干年后看过去,当时那个心系天下,义愤填膺,爱打抱不...
    嬉皮的胖纸哟阅读 1,414评论 0 0

友情链接更多精彩内容