object-c实现的 在PHP中oauth加密算法

说起这个算法,在php中我是这么实现的

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
function generateSig ($params$secret '')
{
    if (empty($secret)) {
        $secret $this->appSecret;
    }
    $str '';
    ksort($params);
    foreach ($params as $k => $v) {
        if (! is_array($v)) {
            $str .= "$k=$v";
        else {
            ksort($v);
            $str .= "$k=" . json_encode($v);
        }
    }
    return bin2hex(hash_hmac('sha1'$str$secret, TRUE));
}

那么在ios的应用中,应该如何实现呢,纠结了半天,其实是很简单的,只是自己错把secret放进了加密数据中,导致结果出现问题。下面展示一下自己的object-c在ios中的实现过程。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
+ (NSString *)getSignature:(NSDictionary *)parameters secret:(NSString *)secret
{
    NSMutableString *baseString = [[NSMutableString alloc] init];
    //排序
    NSArray *sortArray = [parameters.allKeys sortedArrayUsingSelector:@selector(compare:)];
    for(NSString *key in sortArray)
    {
        NSString *value = [parameters objectForKey:key];
        if(value && [value isKindOfClass:[NSString class]])
        {
            [baseString appendFormat:@"%@=%@", key, value];
        }
    }
     
    const char *cKey  = [secret cStringUsingEncoding:NSUTF8StringEncoding];
    const char *cData = [baseString cStringUsingEncoding:NSUTF8StringEncoding];
     
    uint8_t cHMAC[CC_SHA1_DIGEST_LENGTH];
     
    CCHmac(kCCHmacAlgSHA1, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
     
    NSString *hash;
    NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2];
    for(int i = 0; i < CC_SHA1_DIGEST_LENGTH; i++)
        [output appendFormat:@"%02x", cHMAC[i]];
    hash = output;
    return hash;
}

在这里不能缺少的库是

1
2
#import <CommonCrypto/CommonDigest.h>
#import <CommonCrypto/CommonHMAC.h>

应该是下面这个,如果使用到MD5,上面那个是不能缺少的

posted @   jevan  阅读(452)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示