Je suis sûr à 99% qu'une telle fonction n'existe pas dans le RTL (à partir de Delphi 2009). Bien sûr, cependant, il est trivial d'écrire une telle fonction.
Mise à jour
HTTPUtil.HTMLEscape est ce que vous recherchez:
function HTMLEscape(const Str: string): string;
Je n'ose pas publier le code ici (violation du droit d'auteur, sans doute), mais la routine est très simple. Il code "<", ">", "&" et "" » à <
, >
, &
et "
. Il remplace également les caractères # 92, # 160 .. # 255 en décimal codes, par exemple \
.
Cette dernière étape est inutile si le fichier est UTF-8, et également illogique, parce que les caractères spéciaux plus élevés, tels que ∮ sont laissées telles quelles, tandis que des caractères spéciaux inférieurs, tels que x, sont codés.
Mise à jour 2
En réponse à la réponse de Stijn Sanders, j'ai fait un simple test de performance.
program Project1;
{$APPTYPE CONSOLE}
uses
Windows, SysUtils;
var
t1, t2, t3, t4: Int64;
i: Integer;
str: string;
const
N = 100000;
function HTMLEncode(const Data: string): string;
var
i: Integer;
begin
result := '';
for i := 1 to length(Data) do
case Data[i] of
'<': result := result + '<';
'>': result := result + '>';
'&': result := result + '&';
'"': result := result + '"';
else
result := result + Data[i];
end;
end;
function HTMLEncode2(Data: string):string;
begin
Result:=
StringReplace(
StringReplace(
StringReplace(
StringReplace(
Data,
'&','&',[rfReplaceAll]),
'<','<',[rfReplaceAll]),
'>','>',[rfReplaceAll]),
'"','"',[rfReplaceAll]);
end;
begin
QueryPerformanceCounter(t1);
for i := 0 to N - 1 do
str := HTMLEncode('Testing. Is 3*4<3+4? Do you like "A & B"');
QueryPerformanceCounter(t2);
QueryPerformanceCounter(t3);
for i := 0 to N - 1 do
str := HTMLEncode2('Testing. Is 3*4<3+4? Do you like "A & B"');
QueryPerformanceCounter(t4);
Writeln(IntToStr(t2-t1));
Writeln(IntToStr(t4-t3));
Readln;
end.
La sortie est
532031
801969
Un moyen Delphi pour échapper HTML ... Intraweb! ;-) – LachlanG