


Four simple architectural methods and examples of webservice implementation in php, phpwebservice_PHP tutorial
Four simple architectural methods and examples of webservice implementation in php, phpwebservice
1: PHP’s own SOAP
All webservices include server and client.
To use PHP's own soap, you must first install and enable the extension. See the specific code below
First, this is the server-side implementation:
class test
{
Function show()
{
return 'the data you request!'; }
}
function getUserInfo($name)
{
Return 'fbbin';
}
//In the instantiation parameter manual, this does not use wsdl, so the first parameter is null. If wsdl is used, the first parameter is the address of the wsdl file.
$server = new SoapServer(null, array('uri' ='http://soap/','location'='http://localhost/test/server.php'));
$server->setClass('test');
//$server->addFunction('getUserInfo');
$server->handle();
?>
echo $soap->show();
//Get: 'the data you request!'
//echo $soap->getUserInfo('sss');
////////////////////////////////////////////////////// ////////////////////////////////
First, go to the official website (http://www.phprpc.org/zh_CN/) to download the latest version of phprpc. After decompression, there will be relevant files. We divide the files (server and client files) as follows:
Server file:
dhparams.php
phprpc_server.php
bigint.php
compat.php
phprpc_date.php
xxtea.php
bigint.php
compat.php
phprpc_date.php
xxtea.php
Server side:
$server = new PHPRPC_Server();
$server->add('getUser');
$server->setDebugMode(true);
$server->start();
function getUser( )
{
Return ‘the data you request!’;
}
Client side:
[code]
include_once "phprpc_client.php";
$client = new PHPRPC_Client('http://127.0.0.1/phpservice/phprpcserver/server.php');
$data = $client->getUser();
var_dump($data);
//Get: the data you request!
////////////////////////////////////////////////////// ////////////////////////////////
First, go online to download the latest version of nusoap. The latest version now is 0.9.5. After decompression, you will get a lib folder. Put this file into the server and client respectively, and then download it to the server and client. The client creates server.php and client.php files respectively as communication files.
The server file is as follows:
ini_set("soap.wsdl_cache_enabled", 0);//Turn off cache
require_once("lib/nusoap.php"); //Load nusoap file
$server = new soap_server;
$server->configureWSDL('nusoasp');//Set the name of the service and use wsdl to communicate. If wsdl is not used, it will be easier. There are many examples on the Internet
$server->register('getUserInfo', array('name'="xsd:string", 'email'="xsd:string"), array('return'="xsd:string"));
$HTTP_RAW_POST_DATA = isset($HTTP_RAW_POST_DATA) ? $HTTP_RAW_POST_DATA : '';
$server->service( $HTTP_RAW_POST_DATA );
function getUserInfo($name, $email)
{
Return ‘the data you request!’;
}
The client files are as follows:
require_once("lib/nusoap.php");
$client = new soapclient('http://localhost/phpservice/nusoapserver/server.php?wsdl');
$pagram = array('fbbin', 'fbbin@foxmail.com');
$string = $client->call('getUserInfo', $pagram);
//Get: the data you request!
////////////////////////////////////////////////// //////////////////////////////////
Four: HessianPHP
In fact, I personally think that hessian is not a webservice, it can only be said to be similar. Because it does not have the characteristics of webservice. It supports many languages. We only need to study the php version of HessianPHP now. The latest version to download is v2.0.3. After decompression, you will get a src directory, which is a core folder we need to use.
We renamed it to HessianPHP and placed it on the server and client respectively, and then created server.php and client.php files respectively.
Server side:
include_once 'HessianPHP/HessianService.php';//Load core files
class TestService
{
Public function __construct()
{
}
Public function add($numa, $numb)
{
return $numa + $numb; }
Public function check()
{
return 'fbbiin@gmail.com'; }
}
$test = new TestService();
$hessian = new HessianService( $test, array('displayInfo' => true) );
$hessian->handle();//Note that this is not the online $hessian->service(), it may be a different version, please change it! I only found out after reading the source code!
?>
$url = "http://localhost/phpservice/hessianserver/server.php";
$options = new HessianOptions();
$client = new HessianClient( $url, $options );
$num = $client->add( 3, 5 );
echo $num;//Get: 8;
echo $client->check();//Get: fbbiin@gmail.com;
The above four methods are webservice communication methods commonly used in the web development process. The most commonly used one is nusoap. Personally, I feel that phprpc is actually pretty good. This one is basically similar to nusoap in terms of performance. However, phprpc is commercially charged. There is also hessianPHP, which seems to use Java and uses a binary method to transmit data streams. In fact, each has its own merits. For more detailed information, please go to Baidu and Google.
Let's talk about generating wsdl file.
The most commonly used and relatively safe method for us to communicate on webservice is to use wsdl. This kind of file can be written by yourself, but it does not seem to be possible for some experts to write it, so we need to use a tool zend studio to do it. Generate wsdl file.
Next we will generate a WSDL file, File->New—>Other—>Web Service—>WSDL, so that we can create a new WSDL file, as shown in the figure.
Then we will modify the WSDL file. zeng studio provides us with visual operations. Of course, if you are good at it, you can of course change the file code. In fact, there are only a few things. If you understand it, it will not be too difficult.
After completing this step, the WSDL file is basically usable, but there are two issues that need to be paid attention to:
If you achieve this step, the test may fail, possibly because there is no binding. This sometimes needs to be done manually. Just right-click on the binding and select Generate Binding Content (it is the small box in the middle of the two large boxes).
The second thing to note is PHP's WSDL cache. When testing, you generally need to turn off the WSDL cache, otherwise you may be using the original WSDL file instead of the updated one. There are two ways to turn off the cache. The first is to directly set soap.wsdl_cache_enabled = 0 in php.ini; the second is to add a statement in the php file, ini_set("soap.wsdl_cache_enabled", "0");
After doing this, you can safely test and call your server program.
That’s it, OK!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c
