关于融云请求token

作者: 温州的柯 | 来源:发表于2016-04-22 11:14 被阅读1964次

    说在前面的话

    在下小白学习ios开发已有一段时间了,没有报实体班,基本看视频自学,随之而来的当然各种各样的问题。我认为学习是一个渐进的连续的过程,当遇到问题时,网上搜集的有些答案可能适合你,但也有可能你基本看不大懂,这会阻碍学习的兴趣和进度。所以,我把我当前阶段遇到的问题,以我的理解的方式和大家分享一下,如有谬误,求大神指正,也希望各种小伙伴一起探讨哟。

    遭遇

    这两天在捣鼓一个IM(instant messaging)用到了融云的SDK,由于我才学习ios开发不久,做到需要在app里请求token之时,按照正常流程我上了融云的官网去找文档和教程。然后。。。。

    1.png

    第一眼看到我完全晕掉了,接口不应该是一个函数一个方法什么的我扔进去参数就可以得到我想要的吗? 注意红色框框里的东西 前两个对于这个阶段的你肯定不陌生,然后,时间戳,呀!什么鬼,数据签名??Hell?不知道你懂不懂反正当时我不懂。继续往后看SHA1算法这。。。。。

    4.jpg

    very good 最近第三方类用的比较勤快 于是我很自觉的就去git上搜了下哈希这玩意 好嘛。越看越复杂。
    还好最后在cocoaChina上搜到了一位道友到问题,在此感谢

    7.png

    照着写成swift,直到红色框框,一看sha1这玩意应该是个自定义的函数,没错拉到下面也贴出了代码


    6.png

    继续照写 到达框框处时,又不对劲了,这啥子语法啊,能这么写?,硬着头皮写上去,结果编译器就报错了。当时想的是直接上git下个这个函数算了,但是一看,比这段代码还复杂,于是继续摸索下有了这么一段

    5.png

    而且也有这个函数的样板,但是xcode7.3更新了,现给出最新版本

    extension String {
        func sha1() -> String {
            let data = self.dataUsingEncoding(NSUTF8StringEncoding)!
            var digest = [UInt8](count:Int(CC_SHA1_DIGEST_LENGTH),repeatedValue:
                0)
            CC_SHA1(data.bytes, CC_LONG(data.length), &digest)
            
            let hexBytes = digest.map(){String(format:"%02hhx",$0)}
            return hexBytes.joinWithSeparator("")
        }
    
    

    我再给它包装一下

     func sha1Calcu(str:String) -> String {
            return str.sha1()
        }
    
    

    这是String的一个扩展,也就是说String类型的实例能调用所以最后给出完整的http请求token方法

    func requestToken(userID:String) -> Void {
            let dicUser = ["userId":userID,"name":userID,"portraitUrl":""] //请求token的用户信息 
            let str = "https://api.cn.rong.io/user/getToken.json" //网址接口
            let appKey = "你的Appkey"
            let appSecret = "你的AppSecret"
            
            let nonce = "\(arc4random())"   //生成随机数
            let timestamp = "\(NSInteger( NSDate.timeIntervalSinceReferenceDate()))"//时间戳
           
          let sha1Value = sha1Calcu(appSecret+nonce+timestamp) //数据签名
            
            let headers = [              //照着文档要求写的Http 请求的 4个head  (回头再学习下http)
                "App-key":appKey
                ,"Nonce":nonce
                ,"Timestamp":timestamp
                ,"Signature":sha1Value
            ]
        //此处我用到了第三方的网络请求库,用系统的自带的也可以叫NSUrlSession,用过一次感觉相对这个比较复杂一点点点点
            Alamofire.request(.POST, str, parameters: dicUser,  headers: headers)   .responseJSON { (response) in                          
                
    //如果请求成功,这个response里面的result下的value就是这玩意
    //{"code":200,"userId":"sample","token":"LalOUsa3cyWOrfwlMfOp1CSuIH8lXjFx9vVolp0sVjdawJkv1sjb+0LZAig7gpMO3SkK0wWywvI8gfIkQMYp2A=="}
    // 怎么从里面拿到token大家应该都会吧:)
    
               if let dic = reponse.result.value  as? NSDictionary {
               let code = dic.valueForKey("code") as! NSNumber
                if code.stringValue == "200" {
    // 以下是我自己对服务器的操作,把拿到的token上传到我数据服务器里去
                    self.userToken = dic.valueForKey("token") as? String
                    self.userInfo["tokenme"] = self.userToken
                    
                    
                    self.userInfo.saveInBackground()
                    self.navigationController?.popViewControllerAnimated(true)
                    self.successNotice("注册成功!")
                    
                    
                    
                    
                  }
    
    

    哈哈,一时没忍住就长篇大论了。对于大牛来说这本是三言两语就能搞定的,但我觉得吧过程也很重要哟_

    3.jpg

    相关文章

      网友评论

        本文标题:关于融云请求token

        本文链接:https://www.haomeiwen.com/subject/kuvtrttx.html