我正在尝试使用基本身份验证连接到我的服务器,但是当我设置Authorization标头时,它会导致getInputStream抛出fileNotFound异常。
以下是相关代码:
URL url = new URL(myurl);
//set up the connection
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setReadTimeout(10000);//this is in milliseconds
conn.setConnectTimeout(15000);//this is in milliseconds
String authHeader = getAuthHeader(userID,pass);
conn.setRequestMethod("GET");
conn.setDoInput(true);
conn.setRequestProperty("authorization", authHeader);
//starts the query
conn.connect();
int response = conn.getResponseCode();
is = conn.getInputStream(); //throws the fileNotFound exception
这是抛出的异常:
java.io.FileNotFoundException: http://<myIPaddress>/login/
奇怪的是,如果我尝试将请求属性设置为“授权”或“授权”或该词的任何变体,我发现fileNotFound异常仅抛出。如果我将它设置为“content-type”或“authosodifjsodfjs”(随机字符串),则抛出 not ,如下所示:
conn.setRequestProperty("content-type",authHeader)//no exception thrown
conn.setRequestProperty("authosodifjsodfjs",authHeader)//no exception thrown
如果我没有设置此标头,我可以使用此代码连接到服务器,并获得我期望的正确的访问被拒绝消息。 如果我使用python的“请求”模块,我也可以连接到服务器并正确登录,所以这对服务器来说不是问题。
所以我的问题如下:
1)将请求属性设置为“授权”时,我做错了什么?如何正确设置auth标头?
2)如果这是HttpURLConnection的错误,我该如何提交错误报告?
谢谢。
编辑:建议从以下地址切换:
conn.setRequestProperty("Authorization", authHeader);
为:
conn.addRequestProperty("Authorization", authHeader);
这并没有解决问题。它仍然抛出同样的例外。
编辑: 仍然不确定为什么“授权”和“授权”导致fileNotFounExceptions,但使用全部大写似乎工作正常。这是闪亮的新工作代码:
conn.setRequestProperty("AUTHORIZATION",authHeader);
所以看起来它需要全部上限。 “HTTP_”将自动添加到此标头的前面,因此服务器将看到的标头是“HTTP_AUTHORIZATION”,这应该是它。
答案 0 :(得分:9)
以下是我的OAuth代码的一部分,它设置了授权标头:
httpUrlConnection.setUseCaches(false);
httpUrlConnection.setRequestProperty("User-Agent", "MyAgent");
httpUrlConnection.setConnectTimeout(30000);
httpUrlConnection.setReadTimeout(30000);
String baseAuthStr = APIKEY + ":" + APISECRET;
urlConnection.addRequestProperty("Authorization", "Basic " + baseAuthStr);
urlConnection.addRequestProperty("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
httpUrlConnection.connect();