-
Notifications
You must be signed in to change notification settings - Fork 80
Expand file tree
/
Copy pathurlencode.xml
More file actions
162 lines (151 loc) · 6.57 KB
/
urlencode.xml
File metadata and controls
162 lines (151 loc) · 6.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 767338231c3e14c7be5399b8e2e0c3b60f7ae8dd Maintainer: aur Status: ready -->
<!-- Reviewed: no -->
<refentry xml:id="function.urlencode" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink">
<refnamediv>
<refname>urlencode</refname>
<refpurpose>Кодирует строку для безопасного включения в структуру URL-адреса</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type>string</type><methodname>urlencode</methodname>
<methodparam><type>string</type><parameter>string</parameter></methodparam>
</methodsynopsis>
<para>
Функцией часто кодируют часть URL-адреса с аргументами запроса, чтобы передавать переменные на следующую страницу.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>string</parameter></term>
<listitem>
<para>
Строка для кодирования.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Функция возвращает строку в которой каждый символ, кроме буквенно-цифровых и <literal>-_.</literal>,
заменила знаком <literal>%</literal>, за которым следует
два шестнадцатеричных числа, а пробелы закодировала знаком
<literal>+</literal>.
Строка кодируется аналогично данным при отправке веб-формы
с типом контента <literal>application/x-www-form-urlencoded</literal>.
Функция не соблюдает предписание стандарта <link xlink:href="&url.rfc;3986">RFC 3986</link>
и по историческим причинам кодирует пробелы знаком +, тогда как функция <function>rawurlencode</function>
кодирует пробелы по правилам стандарта.
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Пример кодирования строки функцией <function>urlencode</function></title>
<programlisting role="php">
<![CDATA[
<?php
$userinput = 'Data123!@-_ +';
echo "Пользовательские данные: $userinput\n";
echo '<a href="mycgi?foo=', urlencode($userinput), '">';
?>
]]>
</programlisting>
&example.outputs;
<screen role="html">
<![CDATA[
Пользовательские данные: Data123!@-_ +
<a href="mycgi?foo=Data123%21%40-_+%2B">
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Пример преобразования строки функциями <function>urlencode</function> и <function>htmlentities</function></title>
<programlisting role="php">
<![CDATA[
<?php
$foo = 'Data123!@-_ +';
$bar = "Содержание, которое отличается от значения $foo";
echo "foo: $foo\n";
echo "bar: $bar\n";
$query_string = 'foo=' . urlencode($foo) . '&bar=' . urlencode($bar);
echo '<a href="mycgi?' . htmlentities($query_string) . '">';
?>
]]>
</programlisting>
&example.outputs;
<screen role="html">
<![CDATA[
foo: Data123!@-_ +
bar: Содержание, которое отличается от значения Data123!@-_ +
<a href="mycgi?foo=Data123%21%40-_+%2B&bar=Not+the+same+content+as+Data123%21%40-_+%2B">
]]>
</screen>
</example>
</para>
</refsect1>
<refsect1 role="notes">
&reftitle.notes;
<note>
<para>
С PHP-переменными, значения которых совпадают с HTML-сущностями, работают осторожно.
При разборе HTML-разметки браузер анализирует последовательности символов наподобие &amp, &copy и &pound
и преобразовывает именованные сущности в символы, которыми заменяет названия переменных в URI-идентификаторе.
Это насущная проблема, о которой консорциум W3C рассказывает много лет.
Подробнее об обработке символа амперсанда рассказывает страница: <link xlink:href="&url.argsep;">&url.argsep;</link>.
</para>
<para>
PHP поддерживает изменение разделителя аргументов URL-адресов на «точку с запятой»,
которую предложил W3C, через ini-директивы arg_separator.
Бо́льшая часть пользовательских агентов не отправляет данные формы в формате
с разделителем «точка с запятой». Поэтому в URL-адресах HTML-разметки лучше
указывать разделитель &amp;, а не &, чтобы обойти проблему несогласованной обработки URL-адресов.
Для этого не потребуется изменять PHP-директивы arg_separator.
При разделении аргументов символом & URL-адреса кодируют функциями <function>htmlentities</function>
или <function>htmlspecialchars</function>.
</para>
</note>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>urldecode</function></member>
<member><function>htmlentities</function></member>
<member><function>rawurlencode</function></member>
<member><function>rawurldecode</function></member>
<member><link xlink:href="&url.rfc;3986">RFC 3986</link></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->