Два консольных приложения включают один сокет-сервер, использующий TTcpServer в режиме bmThreadBlocking, и один сокет-клиент, использующий TTcpClient в режиме bmBlocking. TTcpClient предназначен для подключения к серверу, отправки строки, а затем отключения. TTcpServer предназначен для прослушивания входящих соединений и вывода строки, полученной в обработчике события OnAccept.
Эти два консольных приложения отлично работают в Windows (XP и 7). Однако, когда я компилирую его с использованием CrossKylix или Kylix напрямую, приложения не могут работать должным образом в Linux (SuSE 10.0 и CentOs 5u7). Серверное приложение получает «[1] + Stopped ./TestSocketServer_1_Console_Native», как только один клиент подключается, т.е. в / после обработчика события TTApServer OnAccept. Не могли бы вы помочь прокомментировать эту проблему? Любая помощь будет оценена!
Два консольных приложения можно загрузить по адресу http://www.multiupload.com/9HIIG61W93
Исходный код также вставлен сюда для вашего удобства. (Номер порта 98765 или 1876 или другой номер не помогает.)
TestSocketServer_1_Console_Native
TestSocketServer_1_Console_Native.dpr
program TestSocketServer_1_Console_Native;
{$APPTYPE CONSOLE}
uses
uServerDataModule in 'uServerDataModule.pas' {ServerDataModule: TServerDataModule},
SysUtils;
begin
{ TODO -oUser -cConsole Main : Insert code here }
ServerDataModule := TServerDataModule.Create(nil);
try
ServerDataModule.tcpServerCCL.Active := True;
while True do
begin
Sleep(500);
end;
finally
ServerDataModule.Free;
end;
end.
uServerDataModule.pas
unit uServerDataModule;
interface
uses
SysUtils, Classes, Sockets;
type
TServerDataModule = class(TDataModule)
tcpServerCCL: TTcpServer;
private
{ Private declarations }
procedure tcpServerCCLAccept(Sender: TObject; ClientSocket: TCustomIpClient);
public
{ Public declarations }
constructor Create(AOwner: TComponent); override;
end;
var
ServerDataModule: TServerDataModule;
implementation
{$R *.dfm}
{ TServerDataModule }
constructor TServerDataModule.Create(AOwner: TComponent);
begin
inherited;
tcpServerCCL.Active := False;
tcpServerCCL.LocalPort := '98765';
tcpServerCCL.OnAccept := tcpServerCCLAccept;
end;
procedure TServerDataModule.tcpServerCCLAccept(Sender: TObject; ClientSocket:
TCustomIpClient);
var
l_InputStr: string;
begin
WriteLn('Accepted connection from ' + ClientSocket.LocalHost);
l_InputStr := ClientSocket.Receiveln();
Writeln(PChar(l_InputStr));
end;
end.
TestSocketClient_1_Console_Native
TestSocketClient_1_Console_Native.dpr
program TestSocketClient_1_Console_Native;
{$APPTYPE CONSOLE}
uses
uClientDataModule in 'uClientDataModule.pas' {ClientDataModule: TClientDataModule},
SysUtils;
begin
{ TODO -oUser -cConsole Main : Insert code here }
ClientDataModule := TClientDataModule.Create(nil);
try
if ClientDataModule.tcpClientCCL.Connect then
begin
ClientDataModule.tcpClientCCL.Sendln('hello from client');
end;
finally
end;
end.
uClientDataModule.pas
unit uClientDataModule;
interface
uses
SysUtils, Classes, Sockets;
type
TClientDataModule = class(TDataModule)
tcpClientCCL: TTcpClient;
private
{ Private declarations }
public
{ Public declarations }
constructor Create(AOwner: TComponent); override;
end;
var
ClientDataModule: TClientDataModule;
implementation
{$R *.dfm}
{ TClientDataModule }
constructor TClientDataModule.Create(AOwner: TComponent);
begin
inherited;
tcpClientCCL.Active := False;
tcpClientCCL.RemoteHost := '127.0.0.1';
tcpClientCCL.RemotePort := '98765';
end;
end.