簡體   English   中英

IIS Windows身份驗證錯誤(401.1)

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM