OK, ich denke, ich werde mit einem Hybrid gehen benutzerdefinierten Funktionen eingestellt:
Encode. Verwenden encodeURIComponent(), dann in setzen schlitzt zurück
Dekodieren: Dekodiert alle gefundenen% Hex-Werte.
Hier ist eine vollständigere Variante dessen, was ich am Ende mit (es behandelt Unicode richtig, auch):
function quoteUrl(url, safe) {
if (typeof(safe) !== 'string') {
safe = '/'; // Don't escape slashes by default
}
url = encodeURIComponent(url);
// Unescape characters that were in the safe list
toUnencode = [ ];
for (var i = safe.length - 1; i >= 0; --i) {
var encoded = encodeURIComponent(safe[i]);
if (encoded !== safe.charAt(i)) { // Ignore safe char if it wasn't escaped
toUnencode.push(encoded);
}
}
url = url.replace(new RegExp(toUnencode.join('|'), 'ig'), decodeURIComponent);
return url;
}
var unquoteUrl = decodeURIComponent; // Make alias to have symmetric function names
Beachten Sie, wenn Sie nicht brauchen „sichere“ Zeichen bei der Kodierung ('/'
standardmäßig in Python), dann können Sie einfach die integrierten Funktionen encodeURIComponent()
und decodeURIComponent()
direkt verwenden.
Auch wenn es Unicode-Zeichen (dh Zeichen mit Codepunkt> = 128) in der Zeichenfolge, dann encodeURIComponent()
Kompatibilität mit JavaScripts zu halten, der Python quote_url()
sein müsse:
def quote_url(url, safe):
"""URL-encodes a string (either str (i.e. ASCII) or unicode);
uses de-facto UTF-8 encoding to handle Unicode codepoints in given string.
"""
return urllib.quote(unicode(url).encode('utf-8'), safe)
Und unquote_url()
würde be:
def unquote_url(url):
"""Decodes a URL that was encoded using quote_url.
Returns a unicode instance.
"""
return urllib.unquote(url).decode('utf-8')
Wenn Sie Ihre eigene Frage zu beantworten, gehen, um Nehmen Sie sich die Zeit, eine ausführlichere Antwort zu geben, um anderen zu helfen, die auf die gleiche Frage stoßen. –
@Chris: Hmm, tut mir leid. Ich werde meine Antwort erweitern und etwas Code hinzufügen. – Cameron