URL kódolás és dekódolás

URL-sztringek kódolása és dekódolása, biztonságos kezelés speciális karakterekkel és nem-ASCII szövegekkel, alkalmas lekérdezési paraméterek és elérési útvonalak átvitelére.

Kódolás

Kódolási mód

Dekódolás

Használati útmutató

Az URL-kódolás a speciális vagy nem-ASCII karaktereket %XX formátumba alakítja, hogy biztonságosan továbbíthatók legyenek az URL-ben.
Használja a „Kódolás” gombot a szöveg URL-ben biztonságos formába alakításához (pl. lekérdezési paraméterekhez).
Használja a „Dekódolás” gombot a %XX sorozatok visszaalakításához eredeti karakterekké.
Gyakori esetek: lekérdezési paraméterek feldolgozása, űrlapadatok átvitele, API-hívások stb.

Gyors példák

Eredeti szöveg
https://example.com/search?q=你好世界&type=text
URL-kódolás
https://example.com/search?q=%E4%BD%A0%E5%A5%BD%E4%B8%96%E7%95%8C&type=text

Funkciók

  • Két kódolási mód: encodeURIComponent és encodeURI
  • Flexibilis szóközkezelés: + vagy %20 formában
  • Valós idejű konverzió és bemeneti/kimeneti hossz statisztikák megjelenítése
  • Másolás/törlés gombok és kétirányú küldés a másik panelra
  • Teljes nemzetköziítés és DaisyUI több témás támogatás

Mi az URL-kódolás

Az URL-kódolás a karaktereket %XX százalékos kódolási sorozatokká alakítja, hogy biztonságosan továbbíthatók legyenek az URL-ben.

Az encodeURIComponent egyedi összetevőkhöz (például egyetlen lekérdezési paraméter értékéhez) alkalmas, és majdnem minden nem alfanumerikus karaktert kódol.

Az encodeURI teljes URI-sztringekhez használható, és nem kódolja a ?, &, =, / stb. strukturális jelentéssel bíró fenntartott karaktereket.

Gyakori alkalmazások

  • Lekérdezési paraméterek (keresési kulcsszavak, szűrési feltételek stb.) létrehozása
  • GET/POST űrlapadatok kódolt átvitele
  • API-kérelem-paraméterek kódolása
  • Felhasználói bemenetek biztonságos beillesztése az URL útvonal-szeleteibe

GYIK és csapdák

  • encodeURI vs encodeURIComponent: paraméterekhez component, teljes linkhez URI
  • Szóköz és +: az application/x-www-form-urlencoded a lekérdezési karakterláncban gyakran + jelet használ szóköz helyett
  • Kerülje a dupla dekódolást: többszörös dekódolás rombolja az adatokat
  • Érvénytelen százalékos sorozat hibát dob; szükséges a kivételek elegáns kezelése

Hogyan végezhető URL-kódolás programozási nyelveken

JavaScript
Kódolás
// Component (recommended for query values)
const encoded = encodeURIComponent(text);
// If you need '+' for spaces in query strings
const encodedPlus = encoded.replace(/%20/g, '+');
// Full URI
const encodedUri = encodeURI(url);
Dekódolás
// Treat '+' as space if needed
const input = plusAsSpace ? s.replace(/\+/g, ' ') : s;
// Component
const dec1 = decodeURIComponent(input);
// Fallback to decodeURI when input is a full URL
const dec2 = decodeURI(input);
PHP
Kódolás
// Component (RFC 3986)
$encoded = rawurlencode($text);
// '+' for spaces (application/x-www-form-urlencoded)
$encodedPlus = str_replace('%20', '+', $encoded);
// Full query usage
$query = http_build_query(['q' => '你好 世界', 'type' => 'text']);
Dekódolás
// Component
$decoded = rawurldecode($s);
// If input uses '+' for spaces
$decodedPlus = urldecode($s);
Python
Kódolás
from urllib.parse import quote, quote_plus

# Component (RFC 3986)
enc = quote(text, safe='')
# '+' for spaces (application/x-www-form-urlencoded)
enc_plus = quote_plus(text)
Dekódolás
from urllib.parse import unquote, unquote_plus

# Component
dec = unquote(s)
# Input with '+' for spaces
dec_plus = unquote_plus(s)
Go
Kódolás
import (
    "net/url"
)

// Query component
enc := url.QueryEscape(text) // spaces => +
// Path segment
// go1.8+
// url.PathEscape(text)
Dekódolás
import (
    "net/url"
)

// Query component
dec, _ := url.QueryUnescape(s)
// Path segment
// url.PathUnescape(s)
Rust
Kódolás
// Cargo.toml: urlencoding = "^2"
use urlencoding::{encode, encode_binary};

let enc = encode(text);              // component; spaces => %20
let enc_plus = enc.replace("%20", "+"); // if you need '+' for spaces
Dekódolás
use urlencoding::decode;

// decode treats '+' as space
let dec = decode(s)?; // Result, _>
Java
Kódolás
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;

// Query param / form style (spaces => '+')
String enc = URLEncoder.encode(text, StandardCharsets.UTF_8);
// For RFC3986-like component encoding, replace '+' with %20 if needed
String encSpace = enc.replace("+", "%20");
Dekódolás
import java.net.URLDecoder;
import java.nio.charset.StandardCharsets;

// URLDecoder treats '+' as space
String dec = URLDecoder.decode(s, StandardCharsets.UTF_8);