本文目录一览:
wordpress 的xmlrpc.php打不开是怎么回事
xmlrpc.php
就在 WordPress 根目录下面。3.5 版本是默认开启的,你要先关闭再删除。如果不是 3.5 版本,那么关闭这个功能后直接删除就好了。
关闭方法:
来自百度经验,具体可参考参考资料。
怎么样让wordpress的xmlrpc.php文件以及XML-RPC功能更安全
方法一:通过代码关闭 XML-RPC 功能
将以下代码添加到你当前主题的 functions.php
文件中:
add_filter('xmlrpc_enabled', '__return_false');
方法二:使用插件 Control XML-RPC Publishing
在后台搜索安装插件 Control XML-RPC publishing
,安装启用插件之后默认就关闭了 XML-RPC 服务,在后台撰写中会有一个开启的开关。
方法三:关闭 XML-RPC 的 pingback 功能
如果你想使用第三方工具写博客,但又想尽量安全一些,可以单独关闭 XML-RPC 的 pingback 功能,代码如下:
add_filter( 'xmlrpc_methods', 'remove_xmlrpc_pingback_ping' );
function remove_xmlrpc_pingback_ping( $methods ) {
unset( $methods['pingback.ping'] );
return $methods;
}
php xml-rpc怎么实现,数据怎么传到服务器端的?
PHP 中集成了 XML-RPC 和 SOAP 两种协议的访问,都是集中在 xmlrpc
扩展中。另外,在 PHP 的 PEAR 中,不管是 PHP 4 还是 PHP 5,都已经默认集成了 XML-RPC 扩展,而且该扩展跟 xmlrpc
扩展无关,能够独立实现 XML-RPC 的协议交互。如果没有 xmlrpc
扩展,建议使用 PEAR::XML-RPC
扩展。
Web Service 介绍
Web Service 是为了异构系统的通信而产生的,它基本的思想就是使用基于 XML 的 HTTP 的远程调用提供一种标准的机制,而省去建立一种新协议的需求。目前进行 Web Service 通信有两种协议标准,一种是 XML-RPC,另外一种是 SOAP。XML-RPC 比较简单,出现时间比较早,SOAP 比较复杂,主要是一些需要稳定、健壮、安全并且复杂交互的时候使用。 我们这里主要是以 XML-RPC 来简单描述 Web Service 的交互过程,部分内容来自 PHP 手册,更详细内容建议参考手册。
安装 xmlrpc 扩展
Windows 平台
- 将 PHP 安装目录下的
php_xmlrpc.dll
文件复制到C:\Windows
或C:\Winnt
目录。 - 在
php.ini
文件中去掉extension=php_xmlrpc.dll
前面的分号;
。 - 重启 Web 服务器。
- 查看
phpinfo()
是否有 XML-RPC 项目,确认是否安装成功。
Unix/Linux 平台
- 重新编译 PHP。
- 在
configure
时加入--with-xmlrpc
选项。 - 查看
phpinfo()
是否正常安装 xmlrpc。
注意:以下操作都是建立在 xmlrpc 扩展正常安装前提下,请务必正确安装。
XML-RPC 工作原理
XML-RPC 大致就是整个过程就是使用 XML 来进行通信。首先构造一个 RPC 服务器端用来处理从 RPC 客户端传递过来的使用 XML 封装的请求,并且把处理结果通过 XML 的形式返回给 RPC 客户端,客户端再去分析 XML 获取自己需要的数据。 XML-RPC 的服务器端必须有现成的函数提供给客户端调用,并且客户端提交的请求中的函数和方法必须和服务器端的一致,否则将无法获取所需要的结果。
XML-RPC 实践
服务器端代码(rpc_server.php)
<?php
/**
* 函数:提供给RPC客户端调用的函数
* 参数:
* $method 客户端需要调用的函数
* $params 客户端需要调用的函数的参数数组
* 返回:返回指定调用结果
*/
function rpc_server_func($method, $params) {
$parameter = $params[0];
if ($parameter == "get") {
$return = 'This data by get method';
} else {
$return = 'Not specify method or params';
}
return $return;
}
// 产生一个XML-RPC的服务器端
$xmlrpc_server = xmlrpc_server_create();
// 注册一个服务器端调用的方法rpc_server,实际指向的是rpc_server_func函数
xmlrpc_server_register_method($xmlrpc_server, "rpc_server", "rpc_server_func");
// 接受客户端POST过来的XML数据
$request = $HTTP_RAW_POST_DATA;
// 执行调用客户端的XML请求后获取执行结果
$xmlrpc_response = xmlrpc_server_call_method($xmlrpc_server, $request, null);
// 把函数处理后的结果XML进行输出
header('Content-Type: text/xml');
echo $xmlrpc_response;
// 销毁XML-RPC服务器端资源
xmlrpc_server_destroy($xmlrpc_server);
?>
客户端代码(rpc_client.php)
<?php
/**
* 函数:提供给客户端进行连接XML-RPC服务器端的函数
* 参数:
* $host 需要连接的主机
* $port 连接主机的端口
* $rpc_server XML-RPC服务器端文件
* $request 封装的XML请求信息
* 返回:连接成功返回由服务器端返回的XML信息,失败返回false
*/
function rpc_client_call($host, $port, $rpc_server, $request) {
// 打开指定的服务器端
$fp = fsockopen($host, $port);
// 构造需要进行通信的XML-RPC服务器端的查询POST请求信息
$query = "POST $rpc_server HTTP/1.0\nUser_Agent: XML-RPC Client\nHost: ".$host."\nContent-Type: text/xml\nContent-Length: ".strlen($request)."\n\n".$request."\n";
// 把构造好的HTTP协议发送给服务器,失败返回false
if (!fputs($fp, $query, strlen($query))) {
$errstr = "Write error";
return false;
}
// 获取从服务器端返回的所有信息,包括HTTP头和XML信息
$contents = '';
while (!feof($fp)) {
$contents .= fgets($fp);
}
// 关闭连接资源后返回获取的内容
fclose($fp);
return $contents;
}
// 构造连接RPC服务器端的信息
$host = 'localhost';
$port = 80;
$rpc_server = '/~heiyeluren/rpc_server.php';
// 把需要发送的XML请求进行编码成XML,需要调用的方法是rpc_server,参数是get
$request = xmlrpc_encode_request('rpc_server', 'get');
// 调用rpc_client_call函数把所有请求发送给XML-RPC服务器端后获取信息
$response = rpc_client_call($host, $port, $rpc_server, $request);
// 分析从服务器端返回的XML,去掉HTTP头信息,并且把XML转为PHP能识别的字符串
$split = '?xml version="1.0" encoding="iso-8859-1"?';
$xml = explode($split, $response);
$xml = $split . array_pop($xml);
$response = xmlrpc_decode($xml);
// 输出从RPC服务器端获取的信息
print_r($response);
?>
服务器端返回的 XML 数据示例
<?xml version="1.0" encoding="iso-8859-1"?>
<methodResponse>
<params>
<param>
<value>
<string>This data by get method</string>
</value>
</param>
</params>
</methodResponse>
通过 xmlrpc_decode
函数把这个 XML 编码为 PHP 的字符串,我们就能够随意处理了,整个 Web Service 交互完成。