首先检查js代码的有没有逻辑问题,语法问题,若无,则进行下面的测试。
方案1:换一个jquery版本,
方案2:采用XMLHttp原生js的请求写法,
方案3:采用fetch请求的写法。
Android开发中,我们经常会使用HttpURLConnection类来发出网络请求,请求发出后,一般都会使用getResponseCode()来获取服务器返回的HTTP状态码,以便判断请求是否成功,诸如200、500、404之类的状态码使用getResponseCode()来获取是没有问题的,但是如果状态码是401,同时你使用的又是4.1.x/4.2.x/4.3.x的安卓系统的话,那么getResponseCode()可能会抛出IOException异常:Java.io.IOException: No authentication challenges found
之所以会出现这个问题,是因为服务器在返回401的时候,没有同时在header中设置“WWW-Authenticate”响应头,这个响应头的作用是告诉客户端,服务器需要哪种类型的认证(Basic或者Digest),通常这个响应头对客户端来说没什么作用,但是标准就是这么规定的。如果服务器没返回这个响应头,那么客户端在解析的时候就会找不到这个header而导致抛出异常。
解决这个问题的方法有两种:
1)从服务器入手,在返回信息的时候,服务器设置一个假的“WWW-Authenticate”响应头,比如:WWW-Authenticate: Basic realm="fake",或者遇到未授权的请求时,直接返回403,而不是返回401;
2)从客户端入手,修改代码,在获取响应码的时候捕捉异常:
[java] view plain copy
HttpURLConnection connection = ...
try {
connection.getResponseCode()
} catch (IOException e) {
int responsecode = connection.getResponseCode()
}
如果getResponseCode()抛出IOException,那么在捕获异常后,再次获取响应码,这时候就可以正常获取到了,so,就是这么简单。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)