IIS Windows身份验证错误(401.1)

时间:2013-01-31 06:49:18

标签: java sql-server http iis

我已经使用PHP 5.3配置IIS 8.0以及SQL Server。

我不确定出了什么问题。当我在浏览器中键入URL时,我能够在Web浏览器中看到我的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);
    }
}

任何帮助都会很棒。

谢谢!!!

2 个答案:

答案 0 :(得分:0)

确保您要通过身份验证的帐户拥有网站目录中文件的权限。

答案 1 :(得分:0)

Internet Explorer是唯一使用开箱即用的集成模式进行NTLM身份验证的浏览器,这就是您的URL在“浏览器”中运行的原因。您的Java HttpClient必须显式进行身份验证,并从服务器回答NTLM质询。见HttpClient NTLM Authentication

  

NTLM是支持的最复杂的身份验证协议   HttpClient的。它是微软设计的专有协议,没有   公开规范...... NTLM   身份验证需要提供NTCredentials实例   服务器的域名或默认凭据。注意   因为NTLM不使用HttpClient使用的领域的概念   服务器的域名作为领域的名称。还要注意   提供给NTCredentials的用户名不应以。为前缀   域 - 即:“adrian”是正确的,而“DOMAIN \ adrian”则不是   正确的...
  HttpClient为NTLM协议的早期版本NTLMv1提供有限的支持。 HttpClient根本不支持NTLMv2。

重要的是,HttpClient 支持集成身份验证。您必须提供显式凭据,这使得它始终可以探测不良做法,因为需要明确提供帐户密码。确保您不存储它,而是向用户询问,这与Firefox访问请求NTLM挑战的网站时的方式非常相似。

阅读The NTLM Authentication Protocol and Security Support Provider了解详情。