TIdHTTP - сессия имеет истекшее сообщение в Delphi XE

Я пытаюсь передать мой код из Delphi 2007 в Delphi XE (пока нет обновления 1). Проблема, на которую я наткнулся, заключается в том, что в Delphi XE я получаю разные ответы от сервера после отправки второго сообщения GET.

В появившемся HTML-сообщении говорится, что мой сеанс истек. Однако тот же код работает без проблем в Delphi 2007 по сей день. Я искал информацию через Интернет и выяснил, что должен использовать CookieManager?

Дело в том, что я не использую в Delphi 2007, и когда я назначил его в Delphi XE, результат моего кода не изменился. Тем не менее, я получаю сообщение об истекшем сеансе.

Что еще я могу попробовать?

Обновление: Я нашел информацию о том, что Indy 10 имеет проблемы с файлами cookie, но они были исправлены.

Я загрузил снимок Indy10_4722, к сожалению, ошибка все еще происходит.

Обновление 2 - предоставленный код

Итак, я подготовил пример кода. Это совместимо с Delphi (2007 и XE). Однако, чтобы скомпилировать его в 2007 году, вам нужно Библиотека GraphicEx.

Код подключается к реальному серверу, загружает изображение безопасности и отображает его в форме. Перепишите буквы из изображения в поле редактирования и закройте форму. Это все, что вам нужно сделать, чтобы проверить его.

program IndyTest;

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Contnrs, Menus, ExtCtrls, IdBaseComponent,
  IdComponent, IdTCPConnection, IdTCPClient, IdHTTP,
  {$IFDEF VER220}PngImage{$ELSE}GraphicEx{$ENDIF}, StrUtils;

{$R *.res}

procedure LoadSecurityImage(AImage: TImage; AIdHTTP: TIdHTTP; AImgLink: String);
var
  PNGGraphic: {$IFDEF VER220}TPngImage{$ELSE} TPNGGraphic{$ENDIF};
  ResponseStream: TMemoryStream;
begin
  ResponseStream := TMemoryStream.Create;
  PNGGraphic   := {$IFDEF VER220}TPngImage.Create{$ELSE}TPNGGraphic.Create{$ENDIF};
  try
    AIdHTTP.Get(AImgLink, ResponseStream);
    ResponseStream.Position := 0;
    PNGGraphic.LoadFromStream(ResponseStream);
    AImage.Picture.Assign(PNGGraphic);
  finally
    ResponseStream.Free;
    PNGGraphic.Free;
  end;
end;

function GetImageLink(AIdHTTP: TIdHTTP): String;
var
  WebContentStream: TStringStream;
  Index, Index2: Integer;
begin
  Result := '';
  WebContentStream := TStringStream.Create('');
  try
    AIdHTTP.Request.ContentType := 'application/x-www-form-urlencoded';
    AIdHTTP.Get('http://czat.wp.pl/i,1,chat.html', WebContentStream);
    Index := Pos('id="secImg">', WebContentStream.DataString);
    if Index > 0 then
    begin
      Index := PosEx('src="', WebContentStream.DataString, Index) + 5;
      Index2 := PosEx('">', WebContentStream.DataString, Index);
      if Index > 10 then
      begin
        Result := Copy(WebContentStream.DataString, Index, Index2 - Index);
      end;
    end;
  finally
    WebContentStream.Free;
  end;
end;

procedure CheckForContent(const ANick, AImageSeed: String; AIdHTTP: TIdHTTP);
var
  WebContent: TStringStream;
  S: String;
begin
  WebContent := TStringStream.Create('');
  try
    AIdHTTP.Request.ContentType := 'application/x-www-form-urlencoded';
    S := 'http://czat.wp.pl/chat.html?i=31179&auth=nie&nick=' + ANick
      + '&regulamin=tak&simg=' + AImageSeed + '&x=39&y=13';
    AIdHTTP.Get(S, WebContent);
    if Pos('<div class="applet">', WebContent.DataString) > 0 then
      ShowMessage('It works properly.')
    else if Pos('<div id="alert">Sesja wygas', WebContent.DataString) > 0 then
      ShowMessage('Session expired')
    else
      ShowMessage('Unknown result.');
  finally
    WebContent.Free;
  end;
end;

var
  LogForm: TForm;
  SecurityImage: TImage;
  Edit: TEdit;
  IdHTTPWp: TIdHTTP;
begin
  Application.Initialize;
  IdHTTPWp := TIdHTTP.Create(Application);
  IdHTTPWp.AllowCookies := True;
  IdHTTPWp.HandleRedirects := True;
  IdHTTPWp.HTTPOptions := [hoForceEncodeParams];

  LogForm := TForm.Create(Application);
  LogForm.Position := poScreenCenter;
  SecurityImage := TImage.Create(LogForm);
  SecurityImage.Parent := LogForm;
  SecurityImage.AutoSize := True;
  Edit := TEdit.Create(LogForm);
  Edit.Parent := LogForm;
  Edit.Top := 64;
  LoadSecurityImage(SecurityImage, IdHTTPWp, GetImageLink(IdHTTPWp));
  LogForm.ShowModal;
  CheckForContent('TestUser', Edit.Text, IdHTTPWp);
  Application.Run;
end.

Обновление 3

Пакеты данных для примера Delphi 2007 здесь.

Пакеты данных для примера Delphi XE здесь.

Бесплатная программа для анализа пакетов SmartSniff.

Спасибо.

Ответ 1

Я думаю, вам стоит рассмотреть возможность проверки запроса с помощью таких инструментов, как httpanalyzer или fiddler.

Сначала используйте Internet Explorer и посмотрите, как он выполняет запрос.

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

Не живите, вы не отвечаете. Это только делает ваше соединение не отбрасываемым по каждому запросу на тот же сервер. См. Wikipedia