Home >Backend Development >PHP Tutorial >Discuss the use analysis of Hessian in PHP_PHP tutorial
What is Hessian
Hessian is an open source remote communication protocol provided by caucho.
Using binary RPC protocol, based on HTTP transmission, there is no need to open another firewall port on the server side.
The specification of the protocol is public and can be used in any language.
Use client/server mode.
The requester is a client, and the service provider is a server.
The client calling process sends a calling message with process parameters to the service process, and then waits for the response message.
On the server side, the process remains in sleep state until the call information arrives.
When a call message arrives, the server obtains the process parameters, calculates the result, sends a reply message, and then waits for the next call message. Finally, the client calls the process to receive the reply message,
obtains the process result, and then the call execution continues .
Hessian protocol workflow chart
Client program requests server function
1. Call the client handle and execute the transmission parameters.
2. Call the local system kernel to send network messages.
3. The message is sent to the remote host.
4. The server handle gets the message and gets the parameters.
5. Execute remote process.
The server function returns the result to the client
1. The execution process returns the result to the server handle.
2. The server handle returns the result and calls the remote system kernel.
3. The message is sent back to the local host.
4. The client handle receives messages from the kernel.
5. The client receives the data returned by the handle.
With source code explanation
1. Reference the configuration file, including the website root directory and the address of Hessian.
//Root directory
define( 'PATH' , dirname(__FILE__) . DIRECTORY_SEPARATOR );
// Hessian Url address
define( 'HESSIAN_URL' , 'http://qx.com/server.php' );
// IDE: Zend Studio 9.0
// IDE Extension: Toggle Vrapper
?>
class HessianServer
{
public function __construct() {}
/**
* Product details API interface
* @param string $title title
* @param int $price price
*/
public function goodsInfomationApi( $title , $price ) {
$price = (int) $price;
return '
$server = new HessianService( new HessianServer() );
//$server->displayInfo();
$server->handle();
// IDE: Zend Studio 9.0
// IDE Extension: Toggle Vrapper
?>
4. Encapsulate Hessian interface
/**
* @var array 存放单例模式数组
*/
private static $_objects = array();
/**
* 设置URL地址
* 实例化HessianClient类
* 参数 : (1) url地址 , 2
*
* 2.Java调用字段
* @param string $url
*/
public function __construct( $url )
{
$this->setUrl( $url );
$handler = new HessianClient ( $this->getUrl (), $this->getOptions () );
$this->setHandler ( $handler );
}
/**
* @return result $_handle 句柄
*/
public function getHandler() {
return $this->_handle;
}
/**
* 设置句柄
* @param result $_handle
*/
public function setHandler($_handle) {
$this->_handle = $_handle;
}
/**
* 获取URL地址
*/
public function getUrl() {
return $this->_url;
}
/**
* 设置URL地址
* @param string $url
*/
public function setUrl($url) {
$this->_url = $url;
}
/**
* typeMap映射Java等平台对象
* @return array
*/
public function getOptions() {
return array (
'version' => 1,
'saveRaw' => TRUE,
'typeMap' => array(
'JavaNullPointException' => 'java.lang.NullPointerException' ,
'StackTraceElement' => 'java.lang.StackTraceElement')
);
}
/**
* 记录接口调用信息
* @param string $method 调用的方法
* @param string $returnMsg 需要记入log的文字信息
*/
public function resultLog( $method , $returnMsg )
{
$logPath = PATH.'/runtime/hessian/';
if( !is_dir( $logPath ) ) {
mkdir($logPath,0777);
}
error_log(date('Ymd H:i:s', time()) . '|' . $method . '|' . $returnMsg."\n", 3, $logPath . date('Y-m-d', time()) . '.log');
}
/**
* Static factory method, generates a unique instance of a single URL
* @param string $url
*/
public static function start( $url )
{
$key = md5( $url );
if ( isset(self: ; ;
return self::$_objects[$key];
class JavaNullPointException extends Exception {}
class StackTraceElement extends Exception {}
// IDE: Zend Studio 9.0
// IDE Extension: Toggle Vrapper
?>
5. Encapsulate the client request method and inherit the HessianApi class
{
// If you call the hessian service of the java platform, you need to specify the type of parameters you pass, especially Integers and strings.
$price = (int) $price;
$result = $this->getHandler()->goodsInfomationApi( $title, $price);
$ this->resultLog( 'getGoodsInfomation' , 'Access interface, but the interface is not logically verified.');
// IDE: Zend Studio 9.0
// IDE Extension: Toggle Vrapper
?>
6. Modify index.php to request the server interface
Copy code
The code is as follows:
// Request the interface to obtain data
$goods = new Goods( HESSIAN_URL );
//Set product title and price.
$title = 'Beijing Mobile Recharge Platform';
$price = '50';
//Request Hessian protocol
$goodsInfo = $goods->getGoodsInfomation( (string) $title , (int) $price );
echo ( $goodsInfo );
// IDE Extension: Toggle Vrapper
?>