PHP Conference Japan 2024

xmlrpc_encode_request

(PHP 4 >= 4.1.0, PHP 5, PHP 7)

xmlrpc_encode_request生成方法请求的 XML

描述

xmlrpc_encode_request(字符串 $method, 混合 $params, 数组 $output_options = ?): 字符串
警告

此函数为实验性。此函数的行为、名称和周围文档可能会在 PHP 的未来版本中未经通知而更改。使用此函数需自行承担风险。

参数

method

要调用的方法的名称。

params

与方法签名兼容的方法参数。

output_options

指定输出选项的数组可能包含(默认值已强调)

  • output_type: php, xml

  • verbosity: no_white_space, newlines_only, pretty

  • escaping: cdata, 非 ASCII、非打印、标记(可以是包含一个值的字符串或包含多个值的数组)

  • version: simple, xmlrpc, soap 1.1, auto

  • encoding: iso-8859-1, iconv 支持的其他字符集

返回值

返回包含请求的 XML 表示形式的字符串。

示例

示例 #1 XMLRPC 客户端函数示例

<?php
$request
= xmlrpc_encode_request("method", array(1, 2, 3));
$context = stream_context_create(array('http' => array(
'method' => "POST",
'header' => "Content-Type: text/xml",
'content' => $request
)));
$file = file_get_contents("http://www.example.com/xmlrpc", false, $context);
$response = xmlrpc_decode($file);
if (
$response && xmlrpc_is_fault($response)) {
trigger_error("xmlrpc: $response[faultString] ($response[faultCode])");
} else {
print_r($response);
}
?>

参见

添加注释

用户贡献的注释 9 条注释

kelly at seankelly dot biz
21 年前
二进制字符串(使用 xmlrpc_set_type 设置)将进入您期望的 <base64>...</base64> 块中。但在每 80 个字符后,此函数都会插入 XML 实体“&#10;”,这是一个 Unicode 换行符,就像要导致换行一样,这确实很愚蠢。

尽管它可能很愚蠢,但它确实会导致某些 XML-RPC 服务器出现问题,例如 http://jakarta.apache.org/xmlrpc/(以前的 Helma)。使用类似以下内容去除这些实体

$req = preg_replace('/&#10;/', '', xmlrpc_encode_request("my.method", $args));

可以解决此问题。
fredrik at it dot cdon dot com
16 年前
需要注意的是,编码似乎什么也没有编码,只是指定进入 XML 标头的内容。

当使用此函数将 UTF 字符串发送到 apache xml-rpc servlet 并将其存储在 mysql 数据库中时,我们遇到了双重编码的 UTF 字符串被保存到数据库中的问题。通过将“escaping”设置为“markup”和“encoding”设置为“UTF-8”解决了此问题(不要忘记在 xmlrpc_decode 中也设置“utf-8”)。

似乎 UTF-8 编码的字符串会将其字节作为实体而不是字符作为实体进行转义。
cometfish at hotmail dot com
16 年前
上面的示例不正确 - 标头需要是一个数组,请参见“chris dot vigelius at gmx dot net”的帖子:http://au.php.net/manual/en/function.stream-context-create.php#74431
他的帖子还展示了如何进行浏览器身份验证,如下所示
<?php
$request
= xmlrpc_encode_request("methodName", array("methodParam"));
$auth = base64_encode($username.":".$password);
$header = (version_compare(phpversion(), '5.2.8'))
? array(
"Content-Type: text/xml","Authorization: Basic $auth")
:
"Content-Type: text/xml\r\nAuthorization: Basic $auth" ; //[1]
$context = stream_context_create(array('http' => array(
'method' => "POST",
'header' => $header,
'content' => $request
)));
$webservice="http://www.example.com/rpc";
$file = file_get_contents($webservice, false, $context);
$response = xmlrpc_decode($file);
if (
xmlrpc_is_fault($response)) {
return
"xmlrpc: $response[faultString] ($response[faultCode])";
} else {
return
$response;
}
?>

1 - 编辑器注释:这是来自“SandersWang dt php at gmail dot com”的修复
hfuecks at pinkgoblin dot com
22 年前
此函数应由 XML-RPC 客户端使用,用于创建 XML-RPC 请求的 XML 负载;

<?php
$params
= "system.methodSignature";
$method = "system.methodHelp";
$request = xmlrpc_encode_request($method,$params);
echo (
$request );
?>

生成;

<?xml version='1.0' encoding="iso-8859-1" ?>
<methodCall>
<methodName>system.methodHelp</methodName>
<params>
<param>
<value>
<string>system.methodSignature</string>
</value>
</param>
</params>
</methodCall>

第二个参数识别变量的类型并生成正确的 XML-RPC 结构。有关更多详细信息,请参阅 xmlrpc_encode()。
匿名
15 年前
有没有尝试过使用 xmlrpc 传输如下所示的数组?
$var1=array(7=>14,9=>18);

输出数组看起来完全不同!它会像这样
$var2=array(14,18);

我找到的唯一解决方案是在索引前添加一个空格
$var3=array(' 7'=>14,' 9'=>18);

使用此方法,您将获得正确的结果。($var1)
handco at gmail dot com
17 年前
带有函数重载的简单 OO 客户端

php 方法 test_helloworld 被转换为 xmlrpc 方法 test.helloworld。

class RpcClient {

private $_methods;
private $_context;
private $_url;

function __construct ($url, $user, $passwd) {
$auth = base64_encode(sprintf('%s:%s', $user,$passwd));
$this->_context = stream_context_create(array(
'http' => array(
'method' => 'POST',
'header' => "Content-Type: text/xml\r\n".
"Authorization: Basic $auth" ,

)
));
$this->_url = $url;

$this->registerMethod ("Test_HelloWorld");

}


function __call($methodName, $params) {
if (array_key_exists($methodName,$this->_methods)) {
// 调用 RPC 函数
$m = str_replace('_', '.', $methodName);
$r = xmlrpc_encode_request($m, $params,array('verbosity'=>'newlines_only'));
$c = $this->_context;
stream_context_set_option($c,'http','content',$r);
$f = file_get_contents($this->_url,false,$c);
$resp = xmlrpc_decode($f);
return $resp;
} else {
// 调用对象的函数
call_user_method_array($methodName, $this,$params);
}
}

private function registerMethod ($method) {
$this->_methods[$method] = true;
}

}
<URL:http://www.dlitz.net/go/contact/>
20 年前
请注意,据我所知,PHP 在 base64 字段中生成的 &#10; 字符似乎根本没有违反 XML-RPC 标准。XML-RPC 消息*是* XML 格式,因此,XML 实体应该在传递到 base64 解码器之前进行解码。因此,前面提到的基于 Jakarta 的 XML-RPC 服务器似乎违反了 XML 规范。即 PHP 中不需要“修复”此处的内容。
php at hendrik dash krauss dot de
19 年前
有关数组 output_options 的示例/文档,请参见 http://xmlrpc-epi.sourceforge.net/main.php?t=php_api#output_options

简而言之,output_options 允许您发送紧凑的 xmlrpc(没有 xmlrpc_encode 通常添加的所有“漂亮空格”),在发送之前应用自己的转义表,设置编码以及其他一些内容(页面甚至提到了 soap 1.1 ... 我不知道详细信息)。
giunta dot gaetano at sea-aeroportimilano dot it
18 年前
注意,当使用某些参数调用此函数时,它将生成无效的 xmlrpc 内容(该内容将被库本身愉快地解析,但不会被其他实现解析)。

xmlrpc_encode_request(null, null)
将生成没有值的响应

xmlrpc_encode_request('myfunc', array('faultCode' => 666, 'faultString' => 'hello world')
将生成一个请求,其中包含 <fault> 成员而不是 <params>
To Top