iOS Handling Authentication Challenge

本文介绍了在iOS中处理网络身份验证挑战的方法,包括识别挑战类型、实现代理方法、创建凭据实例以及处理错误。主要关注NSURLSession的代理方法,特别是如何处理Session-Wide和Task-Specific的认证挑战,并提供了示例代码说明如何响应和验证服务器的证书。
摘要由CSDN通过智能技术生成

目录

1. Challenge 类型

2. 实现哪一个代理方法

3. 判断Authentication Challenge的类型

4. 创建Credential实例

5. 调用Completion Handler

6. 对于错误的处理


NSURLSession 引入后, request被包装进data task或者download task中发送至server, 如果server需要客户端的认证, session task 会尝试处理,如果无法处理则会发起客户端的challenge,调用Session 或者 task didReceiveChallenge的代理方法。如何handle一个challenge, 苹果有官方文档:

https://developer.apple.com/documentation/foundation/url_loading_system/handling_an_authentication_challenge?language=objc

主要就是要实现didReceiveChallenge的代理方法并在代理方法中handle challenge, 对服务器做出正确回应。

1. Challenge 类型

Challenge类型可以从challenge的 property NSURLProtectionSpace authenticationMethod 获取,主要有以下几种类型:

Session-Wide Authentication Challenges

Use client certificate authentication for this protection space.

Negotiate whether to use Kerberos or NTLM authentication for this protection space.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值