Когда в URL кодируется пробел +
и когда он кодируется %20
?
url
url-encoding
ДО Н.Э.
источник
источник
Ответы:
Из Википедии (выделение и ссылка добавлены):
Таким образом, реальный процент кодирования использует,
%20
а данные формы в URL-адресах находятся в измененной форме, которая использует+
. Таким образом, вы, скорее всего, увидите только+
URL-адреса в строке запроса после?
.источник
multipart/form-data
использует кодировку MIME;application/x-www-form-urlencoded
использует+
и правильно закодированные URI%20
.http://www.bing.com/search?q=hello+world
это ресурс с пробелом в имениhttp://camera.phor.net/cameralife/folders/2012/2012-06%20Pool%20party/
mailto:support@example.org?subject=I%20need%20help
. Если вы пробовали это с +, электронное письмо будет открываться с + es вместо пробелов.Эта путаница объясняется тем, что URL до сих пор «не работают».
Это сводится к:
Вы должны иметь
%20
до?
и+
после.Источник
источник
key1=value1&key1=value2
там, где ключи и значения кодируются с соблюдением любых правил,encodeURIComponent
но AFAIK содержание части запроса полностью на 100% до приложения. В остальном это касается только первой#
, официальной кодировки нет.Я бы порекомендовал
%20
.Вы жестко их кодируете?
Это не очень согласованно для разных языков. Если я не ошибаюсь, в PHP
urlencode()
обрабатывает пробелы как,+
тогда как Pythonurlencode()
обрабатывает их как%20
.РЕДАКТИРОВАТЬ:
Кажется, я ошибаюсь. Python
urlencode()
(по крайней мере, в 2.7.2) используетquote_plus()
вместоquote()
и таким образом кодирует пробелы как "+". Представляется также, что рекомендация W3C - это "+", как указано здесь: http://www.w3.org/TR/html4/interact/forms.html#h-17.13.4.1И на самом деле, вы можете следить за этой интересной дискуссией на собственном трекере проблем Python о том, что использовать для кодирования пробелов: http://bugs.python.org/issue13866 .
РЕДАКТИРОВАТЬ № 2:
Я понимаю, что наиболее распространенный способ кодирования "" - это "+", но просто примечание, это может быть только я, но я нахожу это немного запутанным:
источник
URLEncoder.encode()
метод в Java также конвертирует его+
.Пробел может быть закодирован только в «+» в части запроса «пары ключ-значение контента» типа application / x-www-form-urlencoded запроса URL-адреса. На мой взгляд, это МОЖЕТ, а НЕ ДОЛЖЕН. В остальных URL он закодирован как% 20.
По моему мнению, лучше всегда кодировать пробелы как% 20, а не как «+», даже в части запроса URL, потому что это спецификация HTML (RFC-1866), которая указывает, что символы пробела должны кодироваться как « + «in» application / x-www-form-urlencoded »пары ключ-значение типа содержимого (см. пункт 8.2.1. подпункт 1)
Этот способ кодирования данных формы также приведен в более поздних спецификациях HTML. Например, посмотрите соответствующие параграфы о application / x-www-form-urlencoded в спецификации HTML 4.01 и т. Д.
Вот пример строки в URL, где спецификация HTML допускает кодирование пробелов в виде плюсов: « http://example.com/over/there?name=foo+bar ». Таким образом, только после «?» Пробелы можно заменить на плюсы . В других случаях пробелы должны быть закодированы в% 20. Но так как трудно правильно определить контекст, лучше никогда не кодировать пробелы как «+».
Я бы порекомендовал кодировать в процентах все символы, кроме «незарезервированных», определенных в RFC-3986, п.2.3.
Реализация зависит от языка программирования, который вы выбрали.
Если ваш URL содержит национальные символы, сначала закодируйте их в UTF-8, а затем закодируйте в процентах результат.
источник