探讨Hessian在PHP中的使用分析
探讨Hessian在PHP中的使用分析
发布时间:2016-12-29 来源:查字典编辑
摘要:什么是HessianHessian是由caucho提供的一种开源的远程通讯协议。采用二进制RPC协议,基于HTTP传输,服务器端不用另开放防...

什么是Hessian

Hessian是由caucho提供的一种开源的远程通讯协议。

采用二进制 RPC 协议,基于 HTTP 传输,服务器端不用另开放防火墙端口。

协议的规范是公开的,可以用于任意语言。

采用客户机/服务器模式。

请求程序就是一个客户机,而服务提供程序就是一个服务器。

客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。

在服务器端,进程保持睡眠状态直到调用信息的到达为止。

当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息,

获得进程结果,然后调用执行继续进行。

Hessian协议工作流程图

客户端程序请求服务端函数

1.调用客户端句柄,执行传送参数。

2.调用本地系统内核发送网络消息。

3.消息传送到远程主机。

4.服务器句柄得到消息并取得参数。

5.执行远程过程。

探讨Hessian在PHP中的使用分析1

服务端函数返回结果给客户端

1.执行的过程将结果返回服务器句柄。

2.服务器句柄返回结果,调用远程系统内核。

3.消息传回本地主机。

4.客户句柄由内核接收消息。

5.客户接收句柄返回的数据。

探讨Hessian在PHP中的使用分析2

附带源码解释

1.引用配置文件,包括网站根目录,以及Hessian的地址。

复制代码 代码如下:

<?php

/**

* 文件名 : config.php

* 用途 : Hessian配置文件

*

* @package system.core.code applied to the whole site

* @copyright Copyright (c) 2012

* @since 1.0

*/

// 根目录

define( 'PATH' , dirname(__FILE__) . DIRECTORY_SEPARATOR );

// Hessian Url地址

define( 'HESSIAN_URL' , 'http://qx.com/server.php' );

// IDE : Zend Studio 9.0

// IDE Extension : Toggle Vrapper

?>

2.配置服务端。

复制代码 代码如下:

<?php

/**

* 文件名 : server.php

*

* 参考资料 :

* 1.http://hessian.caucho.com/ ( Hessian主页 )

* 2.http://hessianphp.sourceforge.net/ ( Hessian PHP )

* 3.http://sourceforge.net/projects/hessianphp/ ( Hessian PHP开源 )

* 4.http://baike.baidu.com/view/1859857.htm ( 单例模式 )

*

* @author wubaiqing <xinxiangmo@gmail.com>

* @package system.core applied to the whole site

* @copyright Copyright (c) 2012

* @since 1.0

*/

require_once ( dirname(__FILE__) . DIRECTORY_SEPARATOR . 'config.php' );

require_once ( PATH . 'extensions/HessianPHP/HessianService.php' );

class HessianServer

{

public function __construct() {}

/**

* 商品详细信息APi接口

* @param string $title 标题

* @param int $price 价格

*/

public function goodsInfomationApi( $title , $price ) {

$price = (int) $price;

return '<h1>使用Hessian协议调用远程方法.</h1> 标题:' . $title . '<br>价格:'.$price;

}

}

$server = new HessianService( new HessianServer() );

//$server->displayInfo();

$server->handle();

// IDE : Zend Studio 9.0

// IDE Extension : Toggle Vrapper

?>

3.可以通过HessianService类中的displayInfo方法去查看开启多少个通讯方法。

如果搭建服务端要使用handle方法,如出现Hessian Requires POST提示,服务端就已经搭建成功。

4.封装Hessian接口

复制代码 代码如下:

<?php

/**

* 类名 : HessianApi

*

* 参考资料 :

* 1.http://hessian.caucho.com/ ( Hessian主页 )

* 2.http://hessianphp.sourceforge.net/ ( Hessian PHP )

* 3.http://sourceforge.net/projects/hessianphp/ ( Hessian PHP开源 )

* 4.http://baike.baidu.com/view/1859857.htm ( 单例模式 )

*

* @author wubaiqing <xinxiangmo@gmail.com>

* @package system.core applied to the whole site

* @copyright Copyright (c) 2012

* @since 1.0

*/

class HessianApi

{

/**

* @var string 接口地址

*/

private $_url = NULL;

/**

* @var result 句柄

*/

private $_handle = NULL;

/**

* @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');

}

/**

* 静态工厂方法,生成单个URL的唯一实例

* @param string $url

*/

public static function start( $url )

{

$key = md5( $url );

if ( isset(self::$_objects[$key]) ) {

return self::$_objects[$key];

}

self::$_objects[$key] = new HessianApi( $url );

return self::$_objects[$key];

}

}

class JavaNullPointException extends Exception {}

class StackTraceElement extends Exception {}

// IDE : Zend Studio 9.0

// IDE Extension : Toggle Vrapper

?>

5.封装客户端请求方法,继承HessianApi类

复制代码 代码如下:

<?php

/**

* 类名 : Goods

* 继承类 : HessianApi

* 用途 : 调用server.php方法

*

* @author wubaiqing <xinxiangmo@gmail.com>

* @package system.core.code applied to the whole site

* @copyright Copyright (c) 2012

* @since 1.0

*/

class Goods extends HessianApi

{

/**

* 设置接口地址

* @param string $url

*/

public function __construct( $url ) {

parent::__construct( $url );

}

/**

* 获取商品信息

* 调用server.php文件中的goodsInfomationApi方法

* @param string $title 标题

* @param string $title 价格

*/

public function getGoodsInfomation( $title , $price )

{

// 如果调用java平台的hessian服务 需要指定你传递参数的类型,特别是整形和字符串.

$price = (int) $price;

$result = $this->getHandler()->goodsInfomationApi( $title , $price );

$this->resultLog( 'getGoodsInfomation' , '访问接口,但接口没有进行逻辑验证.');

return $result;

}

}

// IDE : Zend Studio 9.0

// IDE Extension : Toggle Vrapper

?>

6.修改index.php可以请求服务端接口

复制代码 代码如下:

<?php

/**

* 文件名 : index.php

*

* 参考资料 :

* 1.http://hessian.caucho.com/ ( Hessian主页 )

* 2.http://hessianphp.sourceforge.net/ ( Hessian PHP )

* 3.http://sourceforge.net/projects/hessianphp/ ( Hessian PHP开源 )

* 4.http://baike.baidu.com/view/1859857.htm ( 单例模式 )

*

* @author wubaiqing <xinxiangmo@gmail.com>

* @package system.core applied to the whole site

* @copyright Copyright (c) 2012

* @since 1.0

*/

require_once ( dirname(__FILE__) . DIRECTORY_SEPARATOR .'config.php' );

// Hessian 扩展及配置文件

require_once ( PATH . 'extensions/HessianPHP/HessianClient.php' );

require_once ( PATH . 'class/HessianApi.php' );

// 调用 server.php 方法

require_once ( PATH . 'class/Goods.php');

// 请求接口获取数据

$goods = new Goods( HESSIAN_URL );

// 设置商品标题 , 价格.

$title = '北京移动充值平台';

$price = '50';

// 请求Hessian协议

$goodsInfo = $goods->getGoodsInfomation( (string) $title , (int) $price );

// 打印请求结果

echo ( $goodsInfo );

// IDE : Zend Studio 9.0

// IDE Extension : Toggle Vrapper

?>

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新php教程学习
热门php教程学习
编程开发子分类