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

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

Jun 06, 2016 pm 07:32 PM
soap webservice penularan Hidangkan bingkai perlukan

需要手动在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();
Salin selepas log masuk
<?php
$function['admin'] = array('user' => 'string', 'pwd' => 'string');
function admin($user, $pwd){
        if ($user === 'root' && $pwd =='123456') {
                return '1';
        }else {
                return '0';
        }
}
Salin selepas log masuk
<?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();
        }
        
}
Salin selepas log masuk
<?php
$function['Example'] = array('param0' => 'string', 'param1' => 'int');
function Example($param0, $param1){
        global $db;
        $info = array ($param0, $param1);
        return json_encode($info);
}
Salin selepas log masuk
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

Repo: Cara menghidupkan semula rakan sepasukan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menilai keberkesanan kos sokongan komersial untuk rangka kerja Java Bagaimana untuk menilai keberkesanan kos sokongan komersial untuk rangka kerja Java Jun 05, 2024 pm 05:25 PM

Menilai kos/prestasi sokongan komersial untuk rangka kerja Java melibatkan langkah-langkah berikut: Tentukan tahap jaminan yang diperlukan dan jaminan perjanjian tahap perkhidmatan (SLA). Pengalaman dan kepakaran pasukan sokongan penyelidikan. Pertimbangkan perkhidmatan tambahan seperti peningkatan, penyelesaian masalah dan pengoptimuman prestasi. Timbang kos sokongan perniagaan terhadap pengurangan risiko dan peningkatan kecekapan.

Bagaimanakah pilihan rangka kerja PHP yang ringan mempengaruhi prestasi aplikasi? Bagaimanakah pilihan rangka kerja PHP yang ringan mempengaruhi prestasi aplikasi? Jun 06, 2024 am 10:53 AM

Rangka kerja PHP yang ringan meningkatkan prestasi aplikasi melalui saiz kecil dan penggunaan sumber yang rendah. Ciri-cirinya termasuk: saiz kecil, permulaan pantas, penggunaan memori yang rendah, kelajuan dan daya tindak balas yang dipertingkatkan, dan penggunaan sumber yang dikurangkan: SlimFramework mencipta API REST, hanya 500KB, responsif yang tinggi dan daya pemprosesan yang tinggi.

Amalan terbaik dokumentasi rangka kerja Golang Amalan terbaik dokumentasi rangka kerja Golang Jun 04, 2024 pm 05:00 PM

Menulis dokumentasi yang jelas dan komprehensif adalah penting untuk rangka kerja Golang. Amalan terbaik termasuk mengikut gaya dokumentasi yang ditetapkan, seperti Panduan Gaya Pengekodan Google. Gunakan struktur organisasi yang jelas, termasuk tajuk, subtajuk dan senarai, serta sediakan navigasi. Menyediakan maklumat yang komprehensif dan tepat, termasuk panduan permulaan, rujukan API dan konsep. Gunakan contoh kod untuk menggambarkan konsep dan penggunaan. Pastikan dokumentasi dikemas kini, jejak perubahan dan dokumen ciri baharu. Sediakan sokongan dan sumber komuniti seperti isu dan forum GitHub. Buat contoh praktikal, seperti dokumentasi API.

Tsinghua Optik AI muncul dalam Alam Semula Jadi! Rangkaian saraf fizikal, perambatan belakang tidak lagi diperlukan Tsinghua Optik AI muncul dalam Alam Semula Jadi! Rangkaian saraf fizikal, perambatan belakang tidak lagi diperlukan Aug 10, 2024 pm 10:15 PM

Menggunakan cahaya untuk melatih rangkaian saraf, keputusan Universiti Tsinghua diterbitkan baru-baru ini dalam Nature! Apakah yang perlu saya lakukan jika saya tidak boleh menggunakan algoritma perambatan balik? Mereka mencadangkan kaedah latihan Mod Hadapan Penuh (FFM) yang secara langsung melaksanakan proses latihan dalam sistem optik fizikal, mengatasi batasan simulasi komputer digital tradisional. Ringkasnya, dahulunya adalah perlu untuk memodelkan sistem fizikal secara terperinci dan kemudian mensimulasikan model ini pada komputer untuk melatih rangkaian. Kaedah FFM menghapuskan proses pemodelan dan membenarkan sistem menggunakan data percubaan secara langsung untuk pembelajaran dan pengoptimuman. Ini juga bermakna latihan tidak lagi perlu menyemak setiap lapisan dari belakang ke hadapan (backpropagation), tetapi boleh terus mengemas kini parameter rangkaian dari hadapan ke belakang. Untuk menggunakan analogi, seperti teka-teki, penyebaran belakang

Bagaimanakah keluk pembelajaran rangka kerja PHP berbanding rangka kerja bahasa lain? Bagaimanakah keluk pembelajaran rangka kerja PHP berbanding rangka kerja bahasa lain? Jun 06, 2024 pm 12:41 PM

Keluk pembelajaran rangka kerja PHP bergantung pada kecekapan bahasa, kerumitan rangka kerja, kualiti dokumentasi dan sokongan komuniti. Keluk pembelajaran rangka kerja PHP adalah lebih tinggi jika dibandingkan dengan rangka kerja Python dan lebih rendah jika dibandingkan dengan rangka kerja Ruby. Berbanding dengan rangka kerja Java, rangka kerja PHP mempunyai keluk pembelajaran yang sederhana tetapi masa yang lebih singkat untuk bermula.

Bagaimana untuk memilih rangka kerja golang terbaik untuk senario aplikasi yang berbeza Bagaimana untuk memilih rangka kerja golang terbaik untuk senario aplikasi yang berbeza Jun 05, 2024 pm 04:05 PM

Pilih rangka kerja Go terbaik berdasarkan senario aplikasi: pertimbangkan jenis aplikasi, ciri bahasa, keperluan prestasi dan ekosistem. Rangka kerja Common Go: Gin (aplikasi Web), Echo (Perkhidmatan Web), Fiber (daya pemprosesan tinggi), gorm (ORM), fasthttp (kelajuan). Kes praktikal: membina REST API (Fiber) dan berinteraksi dengan pangkalan data (gorm). Pilih rangka kerja: pilih fasthttp untuk prestasi utama, Gin/Echo untuk aplikasi web yang fleksibel, dan gorm untuk interaksi pangkalan data.

Penjelasan praktikal terperinci pembangunan rangka kerja golang: Soalan dan Jawapan Penjelasan praktikal terperinci pembangunan rangka kerja golang: Soalan dan Jawapan Jun 06, 2024 am 10:57 AM

Dalam pembangunan rangka kerja Go, cabaran biasa dan penyelesaiannya ialah: Pengendalian ralat: Gunakan pakej ralat untuk pengurusan dan gunakan perisian tengah untuk mengendalikan ralat secara berpusat. Pengesahan dan kebenaran: Sepadukan perpustakaan pihak ketiga dan cipta perisian tengah tersuai untuk menyemak bukti kelayakan. Pemprosesan serentak: Gunakan goroutine, mutex dan saluran untuk mengawal akses sumber. Ujian unit: Gunakan pakej, olok-olok dan stub untuk pengasingan dan alat liputan kod untuk memastikan kecukupan. Penerapan dan pemantauan: Gunakan bekas Docker untuk membungkus penggunaan, menyediakan sandaran data dan menjejak prestasi dan ralat dengan alat pengelogan dan pemantauan.

Perbandingan prestasi rangka kerja Golang: metrik untuk membuat pilihan bijak Perbandingan prestasi rangka kerja Golang: metrik untuk membuat pilihan bijak Jun 05, 2024 pm 10:02 PM

Apabila memilih rangka kerja Go, penunjuk prestasi utama (KPI) termasuk: masa tindak balas, pemprosesan, konkurensi dan penggunaan sumber. Dengan menanda aras dan membandingkan KPI rangka kerja, pembangun boleh membuat pilihan termaklum berdasarkan keperluan aplikasi, dengan mengambil kira beban yang dijangkakan, bahagian kritikal prestasi dan kekangan sumber.

See all articles