我已经使用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);
}
}
任何帮助都会很棒。
谢谢!!!
答案 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了解详情。