首頁 php教程 php手册 一个soap传输webservice框架(服务端)

一个soap传输webservice框架(服务端)

Jun 06, 2016 pm 07:32 PM
soap webservice 傳輸 服務 框架 需要

需要手动在common文件夹下建立一个configure.wsdl文件 api文件夹是webservice接口。 common文件夹是常用方法、以及类库。 user/admin.php里面设置登录密码 server.php是服务端 目前wsdl在程序中自动生成 无 ?phpdate_default_timezone_set ( 'PRC' );$functio

需要手动在common文件夹下建立一个configure.wsdl文件
api文件夹是webservice接口。
common文件夹是常用方法、以及类库。
user/admin.php里面设置登录密码
server.php是服务端

目前wsdl在程序中自动生成
<?php
date_default_timezone_set ( 'PRC' );
$function = array();

require_once 'common/db.php';
require_once 'user/admin.php';
require_once 'api/Example.php';
require_once 'common/function.php';

//自动生成wsdl文件
$wsdl = "<?xml version='1.0' encoding='utf-8'?><definitions name=\"configure\" targetNamespace=\"urn:configure\" xmlns:typens=\"urn:configure\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:soap=\"http://schemas.xmlsoap.org/wsdl/soap/\" xmlns:soapenc=\"http://schemas.xmlsoap.org/soap/encoding/\" xmlns:wsdl=\"http://schemas.xmlsoap.org/wsdl/\" xmlns=\"http://schemas.xmlsoap.org/wsdl/\"><!--注册服务端请求、响应的函数和参数-->";
$message = "";
$port = "<portType name=\"serverPortType\">";
$binding = "<binding name=\"serverBinding\" type=\"typens:serverPortType\"><soap:binding style=\"rpc\" transport=\"http://schemas.xmlsoap.org/soap/http\"/>";

foreach ($function as $name => $parts){
        $message .= "<message name=\"".$name."\"><!--参数名称与类型-->";
        foreach ($parts as $part => $type){
                $message .= "<part name=\"".$part."\" type=\"xsd:".$type."\"/>";
        }
        $message .= "</message><message name=\"".$name."Response\"><part name=\"".$name."Return\" type=\"xsd:string\"/></message>";
        $port .= "<operation name=\"".$name."\"><input message=\"typens:".$name."\"/><output message=\"typens:".$name."Response\"/></operation>";
        $binding .= "<operation name=\"".$name."\"><soap:operation soapAction=\"urn:serverAction\"/><input><soap:body namespace=\"urn:configure\" use=\"encoded\" encodingStyle=\"http://schemas.xmlsoap.org/soap/encoding/\"/></input><output><soap:body namespace=\"urn:configure\" use=\"encoded\" encodingStyle=\"http://schemas.xmlsoap.org/soap/encoding/\"/></output></operation>";
        $functions[] = $name;
}
$port .= "</portType>";
$binding .= "</binding>";
$wsdl .= $message.$port.$binding."<service name=\"configureService\"><port name=\"serverPort\" binding=\"typens:serverBinding\"><soap:address location=\"http://localhost/webservice/server.php\"/></port></service></definitions>";

$file = fopen("common/configure.wsdl","w");
fwrite($file, $wsdl);
fclose($file);

$db = new db();
$service = new SoapServer('common/configure.wsdl');
$service->addFunction($functions);
$service->handle();
登入後複製
<?php
$function['admin'] = array('user' => 'string', 'pwd' => 'string');
function admin($user, $pwd){
        if ($user === 'root' && $pwd =='123456') {
                return '1';
        }else {
                return '0';
        }
}
登入後複製
<?php
defined ( 'HOST' ) || define ( 'HOST', 'localhost' );
defined ( 'USER' ) || define ( 'USER', 'XXX' );
defined ( 'PASSWORD' ) || define ( 'PASSWORD', 'XXX' );
defined ( 'DB' ) || define ( 'DB', 'XXX' );

class db{
        
        public static $_mysqli;
        public static $_stmt;
        
        /**
         * 构造函数
         */
        function __construct(){
                self::$_mysqli = new mysqli(HOST, USER, PASSWORD, DB);
                self::$_mysqli->query("set names utf8");
        }
        
        /**
         * 
         * @return boolean
         */
        function ping(){
                return self::$_mysqli->ping();
        }
        
        /**
         * 
         * @param 需要插入或者更新的参数键值对 $args
         * @return 一个字符串,需要插入或者更新的字段
         */
        private function getFields($args){
                $fields = '';
                foreach ($args as $k=>$v){
                        if ($v === '') {
                                continue;
                        }
                        $fields .= "`". $k ."`='". $v ."', ";
                }
                return substr($fields, 0, -2);
        }
        
        /**
         * 执行一条sql语句
         */
        function query($sql){
                return self::$_mysqli->query($sql);
        }
        
        /**
         * 
         * @param unknown $sql
         * @return unknown
         */
        function select($sql){
                self::$_stmt = $this->query($sql);
                if (self::$_stmt && self::$_stmt->num_rows>0) {
                        while (@$row = self::$_stmt->fetch_assoc()){
                                $res[] = $row;
                        }
                }
                self::$_stmt->free();
                return $res;
        }
        
        function get($table, $field, $where){
                $sql = "select ".$field." from ".$table." where ".$where;
                return $this->select($sql);
        }
        
        function getRow($table, $field, $where){
                $sql = "select ".$field." from ".$table." where ".$where;
                $result = $this->select($sql);
                return $result[0];
        }
        
        /**
         * 进行多条sql查询
         * @param unknown $query
         * @return mixed
         */
        function multi_query($query){
                if (self::$_mysqli->multi_query($query)){
                        do {
                                if (self::$_stmt = self::$_mysqli->store_result()) {
                                        while (@$row = self::$_stmt->fetch_row()) {
                                                $res[] = $row;
                                        }
                                        self::$_stmt->free();
                                }
                        }while (self::$_mysqli->next_result());
                }
                return $res;
        }
        
        /**
         * 向一张表插入单条记录
         * @param 即将执行插入操作的表 $table
         * @param 插入字段名和字段值的键值对 $args
         * @param 如果设置,sql语句
         * @return 插入结果
         */
        function add($table, $types, $args, $flag=false){
                if (self::$_stmt) {
                        $this->emptystmt();
                }
                $fields = "";
                $values = "";
                $bind = 'self::$_stmt->bind_param('.$types;
                foreach ($args as $k=>$v){
                        $fields .= $k.", ";
                        $values .= "?,";
                        $bind .= ' , $'.$k;
                        $$k = $v;
                }
                $bind .= ');';
                $fields = substr($fields, 0, -2);
                $values = substr($values, 0, -1);
                $sql = "insert into ".$table." (".$fields.") values (".$values.")";
                self::$_stmt = self::$_mysqli->prepare($sql);
                echo $cId;
                self::$_stmt->bind_param(iis , $cId , $pId , $createDate);
                //eval($bind);
                $res = self::$_stmt->execute();
                if ($flag) {
                        $this->emptystmt();
                }
                return $res;
        }
        
        /**
         * 向一张表删除符合条件的记录
         * @param 执行删除操作的表名 $table
         * @param 符合要求的条件 $where
         * @return 删除结果
         */
        function del($table, $where, $flag = false){
                if (self::$_stmt) {
                        $this->emptystmt();
                }
                $sql = "delete from ".$table." where ".$where;
                self::$_stmt = self::$_mysqli->prepare($sql);
                $res = self::$_stmt->execute();
                if ($flag) {
                        $this->emptystmt();
                }
                return $res;
        }
        
        /**
         * 向一张表进行更新操作
         * @param 执行更新操作的表名 $table
         * @param 插入字段名和字段值的键值对 $args
         * @param 符合要求的条件 $where
         * @return 更新结果
         */
        function update($table, $types, $args, $where, $flag = false){
                if (self::$_stmt) {
                        $this->emptystmt();
                }
                $fields = "";
                $values = "";
                $bind = 'self::$_stmt->bind_param(\''.$types.'\'';
                foreach ($args as $k=>$v){
                        $fields .= $k."=?, ";
                        $bind .= ' , $'.$k;
                        $$k = $v;
                }
                $bind .= ');';
                $fields = substr($fields, 0, -2);
                $values = substr($values, 0, -1);
                $sql = "update ".$table." set ".$fields." where ".$where;
                self::$_stmt = self::$_mysqli->prepare($sql);
                if (eval($bind)){
                        $res = self::$_stmt->execute();
                }
                if ($flag) {
                        $this->emptystmt();
                }
                return $res;
        }
        
        function bind($types, $args, $flag = false){
                if (self::$_stmt) {
                        $bind = 'self::$_stmt->bind_param('.$types;
                        foreach ($args as $k => $v){
                                $bind .= ' , $'.$k;
                                $$k = $v;
                        }
                        $bind .= ');';
                        if (eval($bind)){
                                $res = self::$_stmt->execute();
                        }
                        if ($flag) {
                                $this->emptystmt();
                        }
                        return $res;
                }
                return false;
        }
        
        /**
         * 关闭与准备语句
         */
        function emptystmt(){
                self::$_stmt->close();
        }
        
        /**
         * 析构函数
         */
        function __destruct(){
               self::$_mysqli->close();
        }
        
}
登入後複製
<?php
$function['Example'] = array('param0' => 'string', 'param1' => 'int');
function Example($param0, $param1){
        global $db;
        $info = array ($param0, $param1);
        return json_encode($info);
}
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1318
25
PHP教程
1269
29
C# 教程
1248
24
如何評估Java框架商業支援的性價比 如何評估Java框架商業支援的性價比 Jun 05, 2024 pm 05:25 PM

評估Java框架商業支援的性價比涉及以下步驟:確定所需的保障等級和服務等級協定(SLA)保證。研究支持團隊的經驗和專業知識。考慮附加服務,如昇級、故障排除和效能最佳化。權衡商業支援成本與風險緩解和提高效率。

PHP 框架的學習曲線與其他語言框架相比如何? PHP 框架的學習曲線與其他語言框架相比如何? Jun 06, 2024 pm 12:41 PM

PHP框架的學習曲線取決於語言熟練度、框架複雜性、文件品質和社群支援。與Python框架相比,PHP框架的學習曲線較高,而與Ruby框架相比,則較低。與Java框架相比,PHP框架的學習曲線中等,但入門時間較短。

清華光學 AI 登 Nature!物理神經網絡,反向傳播不需要了 清華光學 AI 登 Nature!物理神經網絡,反向傳播不需要了 Aug 10, 2024 pm 10:15 PM

用光訓練神經網絡,清華成果最新登上了Nature!無法應用反向傳播演算法怎麼辦?他們提出了一種全前向模式(FullyForwardMode,FFM)的訓練方法,在實體光學系統中直接執行訓練過程,克服了傳統基於數位電腦模擬的限制。簡單點說,以前需要對物理系統進行詳細建模,然後在電腦上模擬這些模型來訓練網路。而FFM方法省去了建模過程,讓系統直接使用實驗數據進行學習和最佳化。這也意味著,訓練不需要再從後向前檢查每一層(反向傳播),而是可以直接從前向後更新網路的參數。打個比方,就像拼圖一樣,反向傳播

PHP 框架的輕量級選項如何影響應用程式效能? PHP 框架的輕量級選項如何影響應用程式效能? Jun 06, 2024 am 10:53 AM

輕量級PHP框架透過小體積和低資源消耗提升應用程式效能。其特點包括:體積小,啟動快,記憶體佔用低提升響應速度和吞吐量,降低資源消耗實戰案例:SlimFramework創建RESTAPI,僅500KB,高響應性、高吞吐量

golang框架文件最佳實踐 golang框架文件最佳實踐 Jun 04, 2024 pm 05:00 PM

編寫清晰全面的文件對於Golang框架至關重要。最佳實踐包括:遵循既定文件風格,例如Google的Go程式設計風格指南。使用清晰的組織結構,包括標題、子標題和列表,並提供導覽。提供全面且準確的信息,包括入門指南、API參考和概念。使用程式碼範例說明概念和使用方法。保持文件更新,追蹤變更並記錄新功能。提供支援和社群資源,例如GitHub問題和論壇。建立實際案例,如API文件。

如何為不同的應用場景選擇最佳的golang框架 如何為不同的應用場景選擇最佳的golang框架 Jun 05, 2024 pm 04:05 PM

根據應用場景選擇最佳Go框架:考慮應用類型、語言特性、效能需求、生態系統。常見Go框架:Gin(Web應用)、Echo(Web服務)、Fiber(高吞吐量)、gorm(ORM)、fasthttp(速度)。實戰案例:建構RESTAPI(Fiber),與資料庫互動(gorm)。選擇框架:效能關鍵選fasthttp,靈活Web應用選Gin/Echo,資料庫互動選gorm。

華為8月服務日來了:手機免費貼膜、維修免人工費 華為8月服務日來了:手機免費貼膜、維修免人工費 Aug 07, 2024 pm 07:24 PM

8月3日消息,根據華為官方介紹,華為7月服務日已正式開啟,時間為8月3日至8月4日。據了解,華為的服務日為每月第一個連續的週五至週日(如遇週末跨月,則順延至下一個週末)。華為用戶於活動期間到店可享免費貼膜、維修免人工費等六大專屬權益。具體來看:華為手機:免費貼膜、清潔、保養、系統升級服務華為平板、筆記型電腦、穿戴、指定型號耳機、智慧眼鏡:免費外觀清潔、保養服務此外,用戶在活動期間:到店維修設備不收取人工費到店購買華為品牌配件、延長服務寶、個性貼膜產品:享建議零售價9折優惠維修設備未能當日修復,到

Java框架學習路線圖:不同領域中的最佳實踐 Java框架學習路線圖:不同領域中的最佳實踐 Jun 05, 2024 pm 08:53 PM

針對不同領域的Java框架學習路線圖:Web開發:SpringBoot和PlayFramework。持久層:Hibernate和JPA。服務端響應式程式設計:ReactorCore和SpringWebFlux。即時計算:ApacheStorm和ApacheSpark。雲端運算:AWSSDKforJava和GoogleCloudJava。

See all articles