HttpPost с заголовком, файлами cookie, параметрами - 417 - ожидание не выполнено - PullRequest
3 голосов
/ 08 августа 2011

Хорошо, это будет долго, так что спасибо всем, кто читает это до конца.

Условие: я не могу получить доступ к серверу, я просто пытаюсь опубликовать данные как новостькомментарий.

Я отчаянно проверяю это в течение пары часов, но у меня все еще нет никакого успеха.В основном мне нужен такой запрос:

POST http://www.example.com/gen/processtalkback.php
Cookie: userid=XXXX; password=XXXX
Content-Type: application/x-www-form-urlencoded
reference_id=XXXX&talkback_command=newentry&talkback_content=comment&talkback_viewpage=1&reference_area=11

Так что ничего особенного, только два заголовка с двумя cookie-файлами и дескриптором контента и пятью параметрами.Два файла cookie являются обязательными, поэтому я установил их следующим образом:

CookieStore cookieStore = httpClient.getCookieStore();

BasicClientCookie cookie = new BasicClientCookie("userid", "XXXX");
cookie.setDomain("http://www.example.com");
cookieStore.addCookie(cookie);

BasicClientCookie cookie2 = new BasicClientCookie("password", "XXXX");
cookie2.setDomain("http://www.example.com");
cookieStore.addCookie(cookie2);

После этого я установил заголовок и содержимое для объекта HttpPost и выполнил его:

HttpPost httpost = new HttpPost("http://www.example.com/gen/processtalkback.php");
httpost.setHeader("Content-Type", "application/x-www-form-urlencoded");
List<NameValuePair> nvps = new ArrayList<NameValuePair>(5);
nvps.add(new BasicNameValuePair("reference_id", "XXXX"));
...
httpost.setEntity(new UrlEncodedFormEntity(nvps));

HttpResponse httpResponse = httpClient.execute(httpost);

Я смотрю вответ, и он показывает мне:

Log.i("RESPONSE", httpResponseActivity.getStatusLine() + EntityUtils.toString(httpResponse .getEntity()));

HTTP/1.1 417 Expectation Failed
<?xml version="1.0" encoding="iso-8859-1"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
     <title>417 - Expectation Failed</title>
    </head>
    <body>
     <h1>417 - Expectation Failed</h1>
    </body>
</html>

Я действительно не знаю, в чем проблема.С расширениями Firefox, такими как "poster" или "HttpRequester", я успешно разместил сообщение:

POST http://www.example.com/gen/processtalkback.php
Cookie: userid=XXXX; password=XXXX
Content-Type: application/x-www-form-urlencoded
reference_id=XXXX&talkback_command=newentry&talkback_content=comment&talkback_viewpage=1&reference_area=11

200 OK
X-Powered-By:  PHP/5.3.6
Set-Cookie:  ...
Expires:  Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control:  no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma:  no-cache
Content-Type:  text/html; charset=utf-8
Transfer-Encoding:  chunked
Date:  Sun, 07 Aug 2011 16:24:01 GMT
Server:  lighttpd/1.4.22
 <a name="commentanchor"></a>
...

Я также попробовал его с объектом Parameter, но все равно безуспешно:

HttpParams params = new BasicHttpParams();          
params.setParameter("reference_id", "XXXX");
...
httpost.setParams(params);

Что моглобыть причиной проблемы?Я что-то пропустил?Какие-либо особенности Apache HttpClient, о которых я не знаю?Мне известно о том, что сервер сообщает мне что-то об этой ошибке, поэтому я искал в Интернете и попробовал одно из решений для этого:

params.setBooleanParameter("http.protocol.expect-continue", false);

Все еще безуспешно.

Что я получил от прослушивания через приложение "shark for root" без этого параметра:

Data:
POST /gen/processtalkback.php
HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Content-Length: 119
Host: www.example.com
Connection: Keep-Alive
User-Agent: Apache-HttpClient/UNAVAILABLE (java 1.4)
Expect: 100-Continue

HEX: .....

А теперь с параметром:

Data:
POST /gen/processtalkback.php
HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Content-Length: 119
Host: www.example.com
Connection: Keep-Alive
User-Agent: Apache-HttpClient/UNAVAILABLE (java 1.4)
reference_id=XXXX...............

HEX: .....

Что я получил с помощью firebug от публикациипо браузеру:

Host    www.example.de
User-Agent  Mozilla/5.0
Accept  text/javascript, text/html, application/xml, text/xml, */*
Accept-Language en-us,de-de;q=0.8,en;q=0.5,de;q=0.3
Accept-Encoding gzip, deflate
Accept-Charset  ISO-8859-1,utf-8;q=0.7,*;q=0.7
DNT 1
Connection  keep-alive
X-Requested-With    XMLHttpRequest
X-Prototype-Version 1.7
Content-Type    application/x-www-form-urlencoded; charset=UTF-8
Referer ...
Content-Length  134
Cookie  ...
Pragma  no-cache
Cache-Control   no-cache

Почему файлы cookie не отображаются в моих попытках запрограммированного httppost?Было бы здорово, если бы у кого-то была идея.: -)

Ответы [ 2 ]

3 голосов
/ 08 августа 2011

Получил работу с другим подходом.Я использовал этот код сообщения на немецком форуме: http://www.android -hilfe.de / android-app-entwicklung / 6398-http-post-request-mit-cookie.html

ИтакМне в основном нужно было написать

URL url = new URL("http://www.example.com/gen/processtalkback.php");

HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setDoOutput(true);
connection.setRequestMethod("POST");
connection.setRequestProperty("Cookie", "userid=XXXX; password=XXXX");
connection.connect();

Акула:

Data:
POST /gen/processtalkback.php
HTTP/1.1
cookie: userid=XXXX; password=XXXX
User-Agent: Dalvik/1.2.0 (Linux; U; Android 2.2.2; ...
Host: www.example.com
Connection: Keep-Alive
Content-Type: application/x-www-form-urlencoded
Content-Length: 119

HEX: .....

Почтовое содержание было отправлено отдельно:

Data:
reference_id=XXXX&talkback_command=newentry&talkback_content=comment&talkback_viewpage=1&reference_area=11

HEX: .....

И оно работало отлично!Я действительно сбит с толку, почему этот подход был успешным в первый раз, и попытка его с Apache HttpClient в течение нескольких часов привела к буквальному разрыву волос.

Кто-нибудь знает более подробную информацию?Я был бы очень признателен за любое объяснение.

2 голосов
/ 01 августа 2012

У меня была такая же проблема на Android 2.2 (работала без них на Android> 2.2). Работал со мной только при использовании обоих параметров, например:

HttpParams params = new BasicHttpParams();          

params.setParameter("reference_id", "XXXX");
params.setBooleanParameter("http.protocol.expect-continue", false);

httpost.setParams(params);
...