![]() |
|
|
|
|
#1
|
||||
|
||||
|
Здравствуйте! Может, кто знает готовые функции для Дельфи для кодировки/декодировки кириллицы, как на этом сайте: http://meyerweb.com/eric/tools/dencoder/
|
|
#2
|
||||
|
||||
|
Ты про Quoted-printable? Там они просто в хекс формате. В indy вроде есть функционал для перекодирования.
|
|
#3
|
||||
|
||||
|
Я вот эту функцию имел ввиду, может, есть уже готовые: http://ru.wikipedia.org/wiki/URL#.D0...0.B8.D0.B5_URL
|
|
#4
|
||||
|
||||
|
Какие проблемы? Сам же ссылку дал.
Цитата: "Такое преобразование происходит в два этапа: сначала каждый символ кириллицы кодируется в Юникоде (UTF-8) в последовательность из двух байтов, а затем каждый байт этой последовательности записывается в шестнадцатеричном представлении". Код:
function CharInSet(C: AnsiChar; const CharSet: TSysCharSet): Boolean;
begin
Result := C in CharSet;
end;
function URLEncode(const Url: Utf8String): string;
var
I: Integer;
begin
Result := '';
for I := 1 to Length(Url) do begin
if CharInSet(Url[i], ['A'..'Z', 'a'..'z', '0'..'9', '-', '=', '&', ':', '/', '?', ';', '_']) then
Result := Result + Utf8ToAnsi(Url[i])
else
Result := Result + '%' + IntToHex(Ord(Url[i]), 2);
end;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
ShowMessage(URLEncode('Вот текст для perevoda 123789'));
end; |
|
#5
|
||||
|
||||
|
Проблема с декодировкой, т.е. обратно перевести.
|
|
#6
|
||||
|
||||
|
Искать пробовали???
Код:
function UrlDecode(Str: string): string;
function HexToChar(W: word): Char;
asm
cmp ah, 030h
jl @@error
cmp ah, 039h
jg @@10
sub ah, 30h
jmp @@30
@@10:
cmp ah, 041h
jl @@error
cmp ah, 046h
jg @@20
sub ah, 041h
add ah, 00Ah
jmp @@30
@@20:
cmp ah, 061h
jl @@error
cmp al, 066h
jg @@error
sub ah, 061h
add ah, 00Ah
@@30:
cmp al, 030h
jl @@error
cmp al, 039h
jg @@40
sub al, 030h
jmp @@60
@@40:
cmp al, 041h
jl @@error
cmp al, 046h
jg @@50
sub al, 041h
add al, 00Ah
jmp @@60
@@50:
cmp al, 061h
jl @@error
cmp al, 066h
jg @@error
sub al, 061h
add al, 00Ah
@@60:
shl al, 4
or al, ah
ret
@@error:
xor al, al
end;
function GetCh(P: PChar; var Ch: Char): Char;
begin
Ch := P^;
Result := Ch;
end;
var
P: PChar;
Ch: Char;
begin
Result := '';
P := @Str[1];
while GetCh(P, Ch) <> #0 do
begin
case Ch of
'+': Result := Result + ' ';
'%':
begin
Inc(P);
Result := Result + HexToChar(PWord(P)^);
Inc(P);
end;
else
Result := Result + Ch;
end;
Inc(P);
end;
end; |