В основном мне нужно выполнить дайджест-аутентификацию. Первое, что я попробовал, это официальный пример здесь .
Но когда я пытаюсь выполнить его (с некоторыми небольшими изменениями, Post вместо метода Get), я получаю
org.apache.http.auth.MalformedChallengeException: missing nonce in challange
at org.apache.http.impl.auth.DigestScheme.processChallenge(DigestScheme.java:132)
Когда это не удалось, я попытался использовать:
DefaultHttpClient client = new DefaultHttpClient();
client.getCredentialsProvider().setCredentials(new AuthScope(null, -1, null), new UsernamePasswordCredentials("<username>", "<password>"));
HttpPost post = new HttpPost(URI.create("http://<someaddress>"));
List<NameValuePair> nvps = new ArrayList<NameValuePair>();
nvps.add(new BasicNameValuePair("domain", "<username>"));
post.setEntity(new UrlEncodedFormEntity(nvps, HTTP.UTF_8));
DigestScheme digestAuth = new DigestScheme();
digestAuth.overrideParamter("algorithm", "MD5");
digestAuth.overrideParamter("realm", "http://<someaddress>");
digestAuth.overrideParamter("nonce", Long.toString(new Random().nextLong(), 36));
digestAuth.overrideParamter("qop", "auth");
digestAuth.overrideParamter("nc", "0");
digestAuth.overrideParamter("cnonce", DigestScheme.createCnonce());
Header auth = digestAuth.authenticate(new
UsernamePasswordCredentials("<username>", "<password>"), post);
System.out.println(auth.getName());
System.out.println(auth.getValue());
post.setHeader(auth);
HttpResponse ret = client.execute(post);
ByteArrayOutputStream v2 = new ByteArrayOutputStream();
ret.getEntity().writeTo(v2);
System.out.println("----------------------------------------");
System.out.println(v2.toString());
System.out.println("----------------------------------------");
System.out.println(ret.getStatusLine().getReasonPhrase());
System.out.println(ret.getStatusLine().getStatusCode());
Сначала у меня есть только переопределенные параметры DigestScheme "realm" и "nonce". Но оказалось, что PHP-скрипт, выполняемый на сервере, требует всех других параметров, но независимо от того, указываю я их или нет, DigestScheme не генерирует их в Authorization RequestPreperty, когда я вызываю его метод authenticate (). А PHP-скрипт возвращает HTTP-код ответа 200 с сообщением о том, что PHP-скрипт требует параметров cnonce, nc и qop.
Я боролся с этим два дня, и не повезло. Исходя из всего, я думаю, что причиной проблемы является сценарий PHP. Мне кажется, что он не отправляет вызов, когда приложение пытается получить к нему несанкционированный доступ.
Есть идеи у кого-нибудь?
Edit:
Еще одна вещь, я попытался соединиться с cURL, и это работает.