Android中的Microsoft ISA Server身份验证

时间:2013-05-10 07:25:51

标签: java android security ntlm isa

我在Android中有一个应用程序,我从远程服务器读取文件,下面给出了读取文件的代码;

            URI uri = null;
            try {
                uri = new URI("http://192.168.1.116/Server1/Users.xml");
            } catch (URISyntaxException e) {
                e.printStackTrace();
            }
            HttpGet httpget = new HttpGet(uri);
            httpget.setHeader("Content-type", "application/json; charset=utf-8");
            httpget.setHeader("host", "192.168.1.116");

            HttpResponse response = null;
            try {
                response = httpClient.execute(httpget);

            } catch (ClientProtocolException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }

            HttpEntity responseEntity = response.getEntity();
            String result = null;
            try {
                result = EntityUtils.toString(responseEntity);
                Log.d("SERVER1", result);
            } catch (ParseException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }

现在所有远程文件都在代理(Microsoft ISA Server)之后,需要身份验证才能访问文件。请指导我如何从android传递身份验证参数来访问文件。

我尝试过以下代码,但没用,

           URL uri = null;
            try {
                uri = new URI("http:// 192.168.1.116/CookieAuth.dll?Logon");
            } catch (URISyntaxException e) {
                e.printStackTrace();
            }

             DefaultHttpClient httpclient = new DefaultHttpClient();
            httpclient.getCredentialsProvider()
                    .setCredentials(
                            AuthScope.ANY,
                            new NTCredentials(username, password, deviceIP,
                                    domainName));

            HttpPost httppost = new HttpPost(uri);
            httppost.setHeader("Content-type",
                    "application/x-www-form-urlencoded");
            List<NameValuePair> params = new ArrayList<NameValuePair>();
            params.add(new BasicNameValuePair("curl", "Z2FServer1/users.xmlZ2F"));
            params.add(new BasicNameValuePair("formdir", "3"));
            params.add(new BasicNameValuePair("username", "test"));
            params.add(new BasicNameValuePair("password", "test"));

            UrlEncodedFormEntity ent = null;
            try {
                ent = new UrlEncodedFormEntity(params, HTTP.UTF_8);
            } catch (UnsupportedEncodingException e1) {
                // TODO Auto-generated catch block
                e1.printStackTrace();
            }
            httppost.setEntity(ent);
            try {
                response = httpclient.execute(httppost);

                Log.i("Test", response.getStatusLine().toString());

                HttpEntity entity = response.getEntity();

                if (entity != null) {

                    InputStream instream = entity.getContent();
                    result = convertStreamToString(instream);
                    Log.d("ISA Server", result);

                    instream.close();
                }

            } catch (Exception e) {
                e.printStackTrace();
            }

但它给了HTTP1.1 500内部服务器错误。我也尝试过以下链接,但同样的错误  https://stackoverflow.com/a/10937857/67381

1 个答案:

答案 0 :(得分:1)

在我的情况下,我使用

public static DefaultHttpClient getClient(String username, String password,
        Integer timeOut) {
    HttpParams httpParams = new BasicHttpParams();
    HttpConnectionParams.setConnectionTimeout(httpParams, timeOut);
    HttpConnectionParams.setSoTimeout(httpParams, timeOut);
    DefaultHttpClient retHttpClient = new DefaultHttpClient(httpParams);
    if (username != null) {
        retHttpClient.getCredentialsProvider().setCredentials(
                new AuthScope(AuthScope.ANY_HOST, AuthScope.ANY_PORT),
                new UsernamePasswordCredentials(username, password));
    }

    return retHttpClient;
}

尝试,可能有效。

P.S。

对于MS C#WebService应用程序,它不适用于ISA,但可能......