1、问题出现原因:一个http请求,直接能访问,但是放到后端接口调用就报错了,请求头也加了;
2、网上查了问题详解如下:HTTP返回的状态码中,401错误表示的是被请求的页面需要用户名和密码。401的错误详细的可以描述为:客户端发送请求抖到服务端,页面需要验证服务端会返回401的错误。如图:
?网上的解决办法思路:
HTTP的认证中,经常会被使用到认证方式分别是BASIC认证和DIGEST认证,我们具体来看BASIC的认证方式是一种流行,行业标准的身份验证方式,是在HTTP1.0中指定。主要是指使用用户ID和密码使用Base64编码标准进行编码,并通过HTTP进行传属,只有当用户ID和密码有效时,服务器才允许用户访问。
在我们的案例中,使用的认证方式是BASIC的认证方式,那么在客户端向服务端发送请求的时候,带上用户信息,再次请求可以成功。
3、解决办法:写了一个工具类:
package com.hehuang.project.util;
import javax.xml.bind.DatatypeConverter;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
public class GetAPIResultUtil {
public static String getAPI(String urlPath ) {
//拼接接收的信息
StringBuffer info=new StringBuffer();
//读取每行的数据
String inputline="";
try {
//实例化URL对象
URL url= new URL(urlPath);
//获取应用程序和 URL 之间的通信链接
HttpURLConnection connection = (HttpURLConnection)url.openConnection();
connection.setRequestProperty("accept", "*/*");
String AccountPassword = "用户名:密码";
String basicAuth = "Basic " + ????????????DatatypeConverter.printBase64Binary(AccountPassword.getBytes());
connection.setRequestProperty("Authorization", basicAuth);
connection.setRequestMethod("GET");
connection.connect();
if(connection.getResponseCode()==200){
System.out.println("请求成功");
}else{
System.out.println("请求失败");
System.out.println("编码"+connection.getResponseCode());
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return info.toString();
}
}
4、问题解决了,关键是代码中标记颜色的部分,这是一种方法,仅供大家参考,如有不对的地方,欢迎交流指出。
?
|