📄 dxcachedrealaudiologging.pas
字号:
unit DXCachedRealAudioLogging;
interface
///////////////////////////////////////////////////////////////////////////////
// Component: TDXCachedRealAudioLogging
// Author: G.E. Ozz Nixon Jr. (onixon@dxsock.com)
// Copyright: All code is the property of Brain Patchwork DX (tm) and part of
// the DXSock (r) product, which are (c) 1999,2002 Brain Patchwork DX.
// Version: 2.3 (2nd Generation Code)
// ==========================================================================
// This is a descendant to TDXCachedLogging that has been setup for writing
// RealAudio log files.
///////////////////////////////////////////////////////////////////////////////
uses
DXCachedLogging,
Classes;
{$I DXAddons.def}
{$WARNINGS OFF}
type
TDXCachedRealAudioLogging=class(TDXCachedLogging)
private
// Private declarations
fsDateFormat:string;
fInternalDF:string;
protected
// Protected declarations
procedure SetDateFormat(value:string);
public
// Public declarations
constructor Create(AOwner:TComponent); {$IFNDEF OBJECTS_ONLY}override;
{$ENDIF}
destructor Destroy; override;
procedure Writeln(ClientAddress, RemoteIdent, AuthUser,
ReceivedRequest:string; StatusCode, ByteTransfered:Integer; PlayerAgent,
StatusLength:string);
published
// Published declarations
property TimeStampFormat:string read fsDateFormat
write SetDateFormat;
end;
{$WARNINGS ON}
implementation
uses
DXString,
SysUtils;
constructor TDXCachedRealAudioLogging.Create(AOwner:TComponent);
begin
inherited Create(AOwner);
TimeStampFormat:='dd/mmm/yyyy:hh:nn:ss @GMT@';
end;
destructor TDXCachedRealAudioLogging.Destroy;
begin
inherited Destroy;
end;
procedure TDXCachedRealAudioLogging.SetDateFormat(value:string);
begin
fsDateFormat:=Value;
fInternalDF:=StringReplace(Value, '@GMT@', TimeZoneBias, [rfReplaceAll]);
end;
procedure TDXCachedRealAudioLogging.Writeln(ClientAddress, RemoteIdent,
AuthUser, ReceivedRequest:string; StatusCode, ByteTransfered:Integer;
PlayerAgent, StatusLength:string);
var
Value:string;
begin
if AuthUser='' then AuthUser:='-';
if RemoteIdent='' then RemoteIdent:='-';
Value:=FormatDateTime(fInternalDF, Now);
Value:=ClientAddress+#32+RemoteIdent+#32+AuthUser+' ['+Value+'] "'+
ReceivedRequest+'" '+IntegerToString(StatusCode)+#32+IntegerToString(ByteTransfered)+
' ['+PlayerAgent+'] [Stat1:'+StatusLength+']';
inherited Writeln(Value);
end;
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -