配置过滤器在服务器端给响应添加头信息
public class CacheFilter implements javax.servlet.Filter {
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
HttpServletResponse response = (HttpServletResponse) res
response.setHeader("Pragma ", "public")
response.setHeader("Cache-Control ", "public")
chain.doFilter(req, response)
}
public void init(FilterConfig filterConfig) {
}
public void destroy() {
}
}
在web.xml中配置相应的url-pattern
方法二:
在html文件中添加标签
<meta http -equiv="Pragma " content="public">
<meta http -equiv="Cache-control " content="public">
1、翻开Alamofire 源码,5.0后Alamofire 将 证书验证类放于ServerTrustEvaluation类中2、在ServerTrustEvaluation 中存在
DefaultTrustEvaluator 默认策略,只有合法证书才能通过验证
RevocationTrustEvaluator 对注销证书做的一种额外设置
PinnedCertificatesTrustEvaluator 证书验证模式,代表客户端会将服务器返回的证书和本地保存的证书中的 所有内容 全部进行校验,如果正确,才继续执行。
PublicKeysTrustEvaluator 公钥验证模式,代表客户端会将服务器返回的证书和本地保存的证书中的
DisabledTrustEvalutor 该选项下验证一直都是通过的,无条件信任。
CompositeTrustEvalutor 自定义验证,需要返回一个布尔类型的结果
我的需求是不验证HTTPS证书,因为我们没有申请SSL证书
所以需要对请求完全信任DisabledTrustEvalutor
接下来的问题是,如何设置
看Session 类中有一个serverTrustManager对象,但是声明实用的是let,也就是不可修改,
那么再看下serverTrustManager对象里面的evaluators属性(我们主要网这个属性里添加过滤域名),也是let声明,好吧都不能改
那就自己自定义一个Session
首先 声明一个全局的Session,局部的会被销毁,可能会造成请求取消等问题
也就是要能持有Session,一般是在封装的类中持有它
然后就是关键的设置了,上源码
由于我需要监测请求情况,所以添加了LearnEventMonitor时间监听,这个需要自己添加,遵守协议EventMonitor就行。
需要注意的就是参数的格式问题
5.0后参数的编码格式有两个类选择:
1、ParameterEncoding
2、ParameterEncoder
相同点
都是在Session中创建Request时使用
都是用来把把参数编码进URLRequest中
都可以决定参数的编码位置(url query string、body表单、bodyjson)
UploadRequest因为不带参数,所以不会使用这俩
不同点
初始化参数不同
ParameterEncoding只能编码字典数据, ParameterEncoder用来编码任意实现Encodable协议的数据类型
ParameterEncoding编码实现简单,因为都是字典数据,body表单编码时,只需要先编码成query string,然后utf8转成data丢入body就行,ParameterEncoder使用的是一个自己Alamofire自己实现的URLEncodedFormEncoder来进行表单数据编码,可以编码Date,Data等特殊数据
ParameterEncoding只有在创建DataRequest跟DownloadRequest时使用,DataStreamRequest无法使用,而ParameterEncoder这三个Request子类都能用来初始化
ParameterEncoder
协议很简单,也是只有一个方法,把Parameters类型的参数编码进URLRequest中,但是要求Parameters类型必须符合Encodable协议。
其实有很多地方类似ParameterEncoding,也是把参数编码编码进Request,编码位置也是可以控制,但是对参数要求不同:
ParameterEncoding要求参数是字典类型,字典的value是Any的,编码为url query string时会直接强制转成String,因此对于标准类型以外的数据,编码出来的值就会错误。编码为JSON时,标准类型以外的数据,会导致编码错误,抛出异常
ParameterEncoder要求参数符合Encodable协议,编码时使用的是Encoder协议对象,编码为json时,用的是JSONEncoder,编码为url query string时,用的是自己实现的URLEncodedFormEncoder编码器
1.JSONParameterEncoder编码json数据
使用系统的JSONEncoder来编码数据,可以控制json的格式,ios11以上还支持根据key来排序(json字典为无序)
2.URLEncodedFormParameterEncoder编码url query string数据
url编码, 使用Destination来判断编码到url query还是body中, 编码数据使用的是URLEncodedFormEncoder类
本文参考链接
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)