ios开发使用Basic Auth 认证方式

         我们app的开发通常有2种认证方式   一种是Basic Auth,一种是OAuth;现在普遍还是使用OAuth的多,而使用Basic Auth认证的少,正好呢我今天给大家介绍的就是使用的比较少的Badic Auth认证方式,这种认证方式开发和调试简单, 没有复杂的页面跳转逻辑和交互过程,更利于发起方控制。然而缺点就是安全性更低,不过也没事,我们可以使用https安全加密协议,这样才更安全。

        我使用的是AFNetworking发送的网络请求,因此我们用Basic Auth认证方式就不能再使用AFN的默认的GET或者POST请求,而是自己定义的NSMutableRequest请求,使用AFN发送,如下面代码:

  

 //http的get请求地址
    NSString *urlStr=[NSString stringWithFormat:@"https://192.168.1.157:8443/v1/sms/send/%@",self.username.text];
    NSURL *url = [NSURL URLWithString:urlStr];
    //自定义的request
    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];
    //请求过期时间
    request.timeoutInterval = 10;
    //get请求
    request.HTTPMethod = @"GET";
    //配置用户名 密码
    NSString * str = [NSString stringWithFormat:@"%@:%@",@"lairen.com",@"sdclean.com"];
    //进行加密  [str base64EncodedString]使用开源Base64.h分类文件加密
    NSString * str2 = [NSString stringWithFormat:@"Basic %@",[str base64EncodedString]];
    [request setValue:str2 forHTTPHeaderField:@"Authorization"];
    AFHTTPRequestOperation *op=[[AFHTTPRequestOperation alloc]initWithRequest:request];
    //设置返回数据为json数据
    op.responseSerializer= [AFJSONResponseSerializer serializer];
    //发送网络请求
    [op setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
        
        NSLog(@"%@",responseObject);
    } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
         NSLog(@"%@",error);
    }];
    //请求完毕回到主线程
    [[NSOperationQueue mainQueue] addOperation:op];
     使用Basic Auth认证方式,AFN发送网络请求就是上述代码的格式,其中代码的一些难懂的点,我在下图做了注释;


      我注释的第一个是用户名,第二个是密码,这个使我们Basic Auth认证方式必须设置的请求头,然后第三个呢是我们为了我确保安全把用户名和密码的字符串进行了Base64加密,使用的2个文件是开源的Base64.h  Base64.m 。github上面就可以下载。

  上述代码中的这行是对字符串进行的加密,记住是使用的Base64.h分类方法进行的加密,一定要先导入Base64.h文件才可以这样加密。

[str base64EncodedString]

NSString * str2 = [NSString stringWithFormat:@"Basic %@",[str base64EncodedString]];

  到这里我们的Basic Auth认证方式就讲完了,怎么样,很简单吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值