[英]IIS windows authentication error (401.1)
我已經將IIS 8.0與PHP 5.3以及SQL Server一起配置。
我不確定出了什么問題。 在瀏覽器中輸入URL時,我可以在網絡瀏覽器中看到JSON字符串,
但是當我將其傳遞給下面的代碼時,它返回了我
IIS 8.0 Detailed Error - 401.2 - Unauthorized
401.2錯誤頁面在我的日食中。
我正在通過Windows身份驗證連接到數據庫。 因此,我在IIS中設置了啟用Windows身份驗證。 除了Windows身份驗證之外,我無法進行其他任何身份驗證,因此在這種情況下,我的JSONstring也完全不會從瀏覽器返回。
我已經嘗試了以下網址中提到的解決方案
http://support.microsoft.com/kb/942043
問題仍然存在
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.params.CoreProtocolPNames;
public class JSONTester {
/**
* @param args
* @throws Exception
*/
public static void main(String[] args)
{
InputStream is = null;
String json = "";
try
{
// defaultHttpClient
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost("http://localhost/hive/get_all_products.php");
httpPost.getParams().setBooleanParameter(CoreProtocolPNames.USE_EXPECT_CONTINUE, false);
HttpResponse httpResponse = httpClient.execute(httpPost);
HttpEntity httpEntity = httpResponse.getEntity();
is = httpEntity.getContent();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(
is, "iso-8859-1"), 8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
json = sb.toString();
} catch (Exception e) {
System.out.println(e.toString());
}
System.out.println(json);
}
}
任何幫助都會很棒。
謝謝 !!!
確保用於身份驗證的帳戶具有網站目錄中文件的權限。
Internet Explorer是唯一使用現成的集成模式進行NTLM身份驗證的瀏覽器,這就是為什么您的URL在“瀏覽器”中可用的原因。 您的Java HttpClient必須顯式進行身份驗證,並應對來自服務器的NTLM挑戰。 請參閱HttpClient NTLM身份驗證 :
NTLM是HttpClient支持的最復雜的身份驗證協議。 它是Microsoft設計的專有協議,沒有公開可用的規范... NTLM身份驗證要求NTCredentials實例可用於服務器的域名或默認憑據。 請注意,由於NTLM不使用領域的概念,因此HttpClient使用服務器的域名作為領域的名稱。 還要注意,提供給NTCredentials的用戶名不應以域開頭-即:“ adrian”是正確的,而“ DOMAIN \\ adrian”是不正確的...
HttpClient對NTLMv1(NTLM協議的早期版本)提供了有限的支持。 HttpClient完全不支持NTLMv2 。
帶回家的重要一點是,HttpClient的不支持集成身份驗證。 您必須提供明確的憑據,由於要求明確提供帳戶密碼,因此它始終會探查不良做法。 確保您不存儲它,而是向用戶詢問它,這與Firefox在訪問請求NTLM挑戰的站點時所采用的方法相同。
閱讀NTLM身份驗證協議和安全支持提供程序以獲取更多詳細信息。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.