Java: как сделать сеанс просмотра HTTP - PullRequest
2 голосов
/ 10 июня 2011

Я пытаюсь создать приложение Java, которое отправляет некоторые запросы POST на сервер.Первый запрос - это запрос информации об аутентификации.Затем, когда я отправляю следующий запрос, я получаю ответ, что мой сеанс истек.Но я отправляю следующий запрос в течение той же секунды, поэтому он не может быть превышен по тайм-ауту.

Так что я предполагаю, что в Java есть что-то вроде HTTP-сессии, которую мне нужно использовать для отправки моегозапросите, чтобы сервер знал, что он следует предыдущему запросу.

Я искал в Google, но ничего не могу найти.Только кое-что о сервлетах.Но я создаю настольное приложение.

PS: я новичок в отправке HTTP-запросов и подобных вещей.

Заранее спасибо,
Martijn


Изменить: Это код, который я использую в настоящее время:

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStreamWriter;
import java.net.URL;
import java.net.URLConnection;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;

/**
 *
 * @author martijn
 */
public class PostRequest {

    private String _url;
    private List<PostParameter> params;

    public PostRequest(String url) {
        this._url = url;
        this.params = new ArrayList<PostParameter>();
    }

    public void addParam(String key, String value)
    {
        params.add(new PostParameter(key, value));
    }

    public String getURL()
    {
        return _url;
    }

    public InputStream request() throws IOException {
        URL url = new URL(this._url);
        URLConnection conn = url.openConnection();
        if (params.size() > 0) {

            conn.setDoOutput(true);

            StringBuilder data = new StringBuilder();
            for (int i = 0; i < params.size(); i++) {
                if (i > 0) {
                    data.append("&");
                }
                String key = params.get(i).key;
                String value = params.get(i).value;
                data.append(URLEncoder.encode(key, "UTF-8"));
                data.append("=");
                data.append(URLEncoder.encode(value, "UTF-8"));
            }

            OutputStreamWriter wr = new OutputStreamWriter(conn.getOutputStream());
            wr.write(data.toString());
            wr.flush();
        }

        return conn.getInputStream();
    }

    public class PostParameter {

        public String key;
        public String value;

        public PostParameter(String key, String value) {
            this.key = key;
            this.value = value;
        }

        public PostParameter() {
        }

        public String getKey() {
            return key;
        }

        public String getValue() {
            return value;
        }

        public void setKey(String key) {
            this.key = key;
        }

        public void setValue(String value) {
            this.value = value;
        }
    }
}

А затем отправить два запроса друг за другом:

PostRequest postAuthentication = new PostRequest("http://blahblah.com");
postAuthentication.addParam("user", user);
postAuthentication.addParam("password", pass);
Utils.dumpReader(postAuthentication.request());

PostRequest postDoSomething = new PostRequest("http://blahblah.com/function.php");
postDoSomething.addParam("func", "blah");
postDoSomething.addParam("value", "14");
Utils.dumpReader(postDoSomething.request());
    // Here I'm getting the session is expired.

Ответы [ 4 ]

4 голосов
/ 10 июня 2011
2 голосов
/ 10 июня 2011

Если идентификатор сессии хранится в файлах cookie, вы должны предоставить способ хранения файлов cookie и передачи их во второй запрос.Обратитесь к этому примеру для обработки файлов cookie в HTTP-клиенте Apache .

0 голосов
/ 10 июня 2011

Сервер, вероятно, использует куки-файлы сеанса HTTP (только) для отслеживания запросов.Вам нужно будет проанализировать HTTP-трафик на сервер (при использовании браузера), чтобы увидеть, так ли это.Сервер предоставляет файлы cookie клиенту через заголовок ответа Set-Cookie.

Если предположение верно, что файлы cookie необходимы, то файл cookie должен предоставляться клиентом на каждый запрос к серверу.Это делается клиентом, устанавливающим заголовок запроса Cookie.

Я предполагаю, что вы используете класс HttpUrlConnection, предоставляемый Java API. По этой теме в StackOverflow существует очень полный ответ от Balus .См. Раздел «Ведение сессии».

0 голосов
/ 10 июня 2011

Когда вы получаете ответ на запрос аутентификации, вам необходимо сохранить информацию о сеансе. При отправке следующего запроса вам необходимо добавить информацию о сеансе в запрос.

http://en.wikipedia.org/wiki/HTTP_cookie

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...