-
Notifications
You must be signed in to change notification settings - Fork 79
Expand file tree
/
Copy pathexec.xml
More file actions
190 lines (180 loc) · 6.85 KB
/
exec.xml
File metadata and controls
190 lines (180 loc) · 6.85 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
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: b412bbd26214f7281ac7dd858710e09952a275f2 Maintainer: aur Status: ready -->
<!-- Reviewed: no -->
<refentry xml:id="function.exec" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>exec</refname>
<refpurpose>Выполняет внешнюю программу</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type class="union"><type>string</type><type>false</type></type><methodname>exec</methodname>
<methodparam><type>string</type><parameter>command</parameter></methodparam>
<methodparam choice="opt"><type>array</type><parameter role="reference">output</parameter><initializer>&null;</initializer></methodparam>
<methodparam choice="opt"><type>int</type><parameter role="reference">result_code</parameter><initializer>&null;</initializer></methodparam>
</methodsynopsis>
<para>
Функция <function>exec</function> выполняет команду
<parameter>command</parameter>.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>command</parameter></term>
<listitem>
<para>
Команда, которую выполнит функция.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>output</parameter></term>
<listitem>
<para>
Функция заполнит массив строками вывода команды,
если в списке аргументов передали переменную для параметра <parameter>output</parameter>.
Функция не включит в массив пробельные символы наподобие <literal>\n</literal>, которые завершают строки.
Обратите внимание: функция <function>exec</function> добавит новые элементы в конец массива,
если массив уже содержит элементы.
Перед передачей элементов в функцию <function>exec</function> на массиве вызывают языковую конструкцию
<function>unset</function>, если добавлять новые элементы в конец массива не требуется.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>result_code</parameter></term>
<listitem>
<para>
Функция запишет в эту переменную статус возврата команды, которую выполнила система,
если аргументы передали и в параметр <parameter>result_code</parameter>,
и в параметр <parameter>output</parameter>.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Функция возвращает последнюю строку из результата команды.
Функция <function>passthru</function> помогает, когда требуется
выполнить команду и вернуть сырые данные из команды
без посредников.
</para>
<para>
Функция возвращает &false;, если возникла ошибка.
</para>
<para>
Функция вернёт данные вывода команды, которая выполнилась, только если установили
параметр <parameter>output</parameter>.
</para>
</refsect1>
<refsect1 role="errors">
&reftitle.errors;
<para>
Выдаётся ошибка уровня <constant>E_WARNING</constant>,
если функция <function>exec</function> не выполнила команду <parameter>command</parameter>.
</para>
<para>
Функция выбрасывает исключение <classname>ValueError</classname>,
если параметр <parameter>command</parameter> не указали или параметр содержит нулевые байты.
</para>
</refsect1>
<refsect1 role="changelog">
&reftitle.changelog;
<informaltable>
<tgroup cols="2">
<thead>
<row>
<entry>&Version;</entry>
<entry>&Description;</entry>
</row>
</thead>
<tbody>
<row>
<entry>8.0.0</entry>
<entry>
Теперь функция <function>exec</function> выбрасывает исключение <classname>ValueError</classname>,
если параметр <parameter>command</parameter> не указали или параметр содержит нулевые байты;
раньше функция выдавала ошибку уровня <constant>E_WARNING</constant> и возвращала &false;.
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Пример выполнения внешней программы функцией <function>exec</function></title>
<programlisting role="php">
<![CDATA[
<?php
// Выводит имя пользователя, от имени которого запустили процесс php/httpd
// (применимо к системам с командой whoami в системном пути)
$output = null;
$retval = null;
exec('whoami', $output, $retval);
echo "Команда вернёт статус $retval и значение:\n";
print_r($output);
?>
]]>
</programlisting>
&example.outputs.similar;
<screen>
<![CDATA[
Команда вернёт статус 0 и значение:
Array
(
[0] => cmb
)
]]>
</screen>
</example>
</para>
</refsect1>
<refsect1 role="notes">
&reftitle.notes;
&warn.escapeshell;
¬e.exec-bg;
¬e.exec-bypass-shell;
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><function>system</function></member>
<member><function>passthru</function></member>
<member><function>escapeshellcmd</function></member>
<member><function>pcntl_exec</function></member>
<member><link linkend="language.operators.execution">Оператор исполнения</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
-->