国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - PHP采用XML-RPC構造Web Service實例教程

PHP采用XML-RPC構造Web Service實例教程

2020-07-18 14:27PHP教程網 PHP教程

這篇文章主要介紹了PHP采用XML-RPC構造Web Service,需要的朋友可以參考下

一、概述:

目前進行Web Service通信有兩種協議標準,一種是XML-RPC,另外一種是SOAP。XML-RPC比較簡單,出現時間比較早,SOAP比較復雜,主要是一些需要穩定、健壯、安全并且復雜交互的時候使用。

PHP自身就集成了XML-RPC和SOAP兩種協議的訪問,都是集中在xmlrpc擴展當中。另外,在PHP的PEAR中,不管是PHP 4還是PHP 5,都已經默認集成了XML-RPC擴展,而且該擴展跟xmlrpc擴展無關,能夠獨立實現XML-RPC的協議交互,如果沒有xmlrpc擴展,建議使用PEAR::XML-RPC擴展。

我們這里主要是以XML-RPC來簡單描述Web Service的交互過程,部分內容來自PHP手冊,更詳細的內容,讀者可以參考手冊。

二、安裝xmlrpc擴展:

如果你的系統中沒有安裝xmlrpc的php擴展,那么請正確安裝。

在Windows平臺下,首先把PHP安裝目錄下的擴展php_xmlrpc.dll放到C:\Windows或者C:\Winnt目錄下,(PHP4的擴展在C:\php\extensions目錄中,PHP5的擴展在C:\php\ext目錄中。dll擴展文件的具體安裝目錄視你的php安裝目錄而定,此處僅為示例說明),同時在C:\Windows\php.ini或者C:\Winnt\php.ini中把extension=php_xmlrpc.dll前面的分號";"去掉,然后重啟Web服務器后查看phpinfo()有沒有XML-RPC項目就能夠確定是否已經正確安裝xmlrpc擴展。

在Unix/Linux平臺下,如果沒有安裝xmlrpc擴展,請在重新編譯PHP,在configure的時候請加入 --with-xmlrpc 選項,然后查看phpinfo()看是否正常安裝xmlrpc。

(注意:以下操作都是建立在xmlrpc擴張正常安裝前提下,請務必正確安裝。)

三、XML-RPC工作原理:

XML-RPC大致就是整個過程就是使用XML來進行通信。首先構造一個RPC 服務器端用來出來從RPC客戶端傳遞過來的使用XML封裝的請求,并且把處理結果通過XML的形式返回給RPC客戶端,客戶端就去分析XML獲取自己需要的數據。

XML-RPC的服務器端必須有現成的函數提供給客戶端調用,并且客戶端提交的請求中的函數和方法必須和服務器端的一致,否則將無法獲取所需要的結果。

下面我進行簡單的代碼來描述整個過程。

四、XML-RPC實踐:

服務器端使用xmlrpc_server_create函數產生一個服務器端,然后把需要需要暴露的RPC調用接口進行注冊,接受RPC客戶端POST過來的XML數據,然后進行處理,處理結果通過XML的形式顯示給客戶端。

rpc_server.php文件代碼如下:

?
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
/**
* 函數:提供給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客戶端。客戶端大致通過Socket訪問XML-RPC服務器端的80端口,然后把需要調用的RPC接口封裝到XML里,通過POST請求提交給RPC服務器端,最后獲取服務器端返回結果。

rpc_client.php文件代碼如下:

?
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
/**
* 函數:提供給客戶端進行連接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 = explode($split, $response);
$xml = $split . array_pop($xml);
$response = xmlrpc_decode($xml);
 
//輸出從RPC服務器端獲取的信息
print_r($response);

大致我們上面的例子就是提交一個叫做rpc_server的方法過去,參數是get,然后獲取服務器端的返回,服務器端返回的XML數據是:

?
1
2
3
4
5
6
7
8
9
10
<?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交互完成。

五、總結:

不管是XML-RPC也好,SOAP也罷,只要能夠讓我們穩定、安全的進行遠程過程的調用,完成我們的項目,那么就算整個Web Service就是成功的。另外,如果可以的話,也可以嘗試使用PEAR中的XML-RPC來實現上面類似的操作,說不定會更簡單,更適合你使用。有興趣的讀者可以嘗試去完成。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久久久久av | 国内激情自拍 | 狠狠人人| 成人亚洲网 | 国产伦精品一区二区三区四区视频 | 亚洲午夜一区 | 无码一区二区三区视频 | 成人免费看黄色 | 国产精品亲子伦av一区二区三区 | 三级黄色片在线免费观看 | 亚洲精品国产一区 | 91久久夜色精品国产网站 | 成人做爰69片免费 | 91精品国产综合久久福利 | 亚洲一区二区三区在线 | 黄色片免费在线观看视频 | 中文字幕av一区二区三区 | 69日影院| 中文字幕成人影院 | 久久九| 国产精品美女视频 | 日韩一区二区在线观看 | 奇米成人| 久久逼逼 | 天堂av中文字幕 | 日本亚洲最大的色成网站www | 国产免费一级特黄录像 | а天堂中文最新一区二区三区 | 国产精品久久天天躁 | 免费三片在线观看网站 | 99福利视频 | 一级视频在线播放 | 国产精品三级久久久久久电影 | 国产精品久久精品 | 国产一区二区三区在线 | 亚洲视频欧美视频 | 成人国产精品一区二区免费麻豆 | 精品美女久久久 | 亚洲日本va在线观看 | 欧美成人激情 | 国产偷亚洲偷欧美偷精品 |