探讨Hessian在PHP中的使用分析


Posted in PHP onJune 13, 2013

什么是Hessian

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

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

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

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

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

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

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

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

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

Hessian协议工作流程图

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

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

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

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

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

5.执行远程过程。

探讨Hessian在PHP中的使用分析

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

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

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

3.消息传回本地主机。

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

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

探讨Hessian在PHP中的使用分析

附带源码解释

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 style="background-color:#036; color:#fff; font-size:16px; padding:10px 10px 10px 3px;">使用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 相关文章推荐
深入了解php4(1)--回到未来
Oct 09 PHP
PHP 第二节 数据类型之字符串类型
Apr 28 PHP
PHP register_shutdown_function函数的深入解析
Jun 03 PHP
php多文件上传实现代码
Feb 20 PHP
PHP 二维数组根据某个字段排序的具体实现
Jun 03 PHP
CodeIgniter与PHP5.6的兼容问题
Jul 16 PHP
提交表单后 PHP获取提交内容的实现方法
May 25 PHP
Yii2框架制作RESTful风格的API快速入门教程
Nov 08 PHP
Yii2中使用asset压缩js,css文件的方法
Nov 24 PHP
PHP快速推送微信模板消息
Apr 14 PHP
实例解析php的数据类型
Oct 24 PHP
PHP中命名空间的使用例子
Mar 22 PHP
深入PHP变量存储的详解
Jun 13 #PHP
深入PHP中的HashTable结构详解
Jun 13 #PHP
基于PHP输出缓存(output_buffering)的深入理解
Jun 13 #PHP
php缓冲 output_buffering的使用详解
Jun 13 #PHP
如何在PHP中使用正则表达式进行查找替换
Jun 13 #PHP
php启用zlib压缩文件的配置方法
Jun 12 #PHP
Window下PHP三种运行方式图文详解
Jun 11 #PHP
You might like
php随机输出名人名言的代码
2012/10/07 PHP
PHP实现连接设备、通讯和发送命令的方法
2015/10/13 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
Laravel学习基础之migrate的使用教程
2017/10/11 PHP
php设计模式之建造器模式分析【星际争霸游戏案例】
2020/01/23 PHP
关于PhpStorm设置点击编辑文件自动定位源文件的实现方式
2020/12/30 PHP
Git命令之分支详解
2021/03/02 PHP
js简单的表格添加行和删除行操作示例
2014/03/31 Javascript
Javascript Objects详解
2014/09/04 Javascript
JavaScript获取网页中第一个图片id的方法
2015/04/03 Javascript
js实现漂浮回顶部按钮实例
2015/05/06 Javascript
深入理解MVC中的时间js格式化
2016/05/19 Javascript
angularJS 如何读写缓冲的方法(推荐)
2016/08/06 Javascript
webix+springmvc session超时跳转登录页面
2016/10/30 Javascript
js实现短信发送倒计时功能(正则验证)
2017/02/10 Javascript
Vue.js结合bootstrap实现分页控件
2017/03/10 Javascript
基于JavaScript实现的顺序查找算法示例
2017/04/14 Javascript
解决IE7中使用jQuery动态操作name问题
2017/08/28 jQuery
vue+axios 前端实现的常用拦截的代码示例
2018/08/23 Javascript
js判断复选框是否选中的方法示例【基于jQuery】
2019/10/10 jQuery
node.js实现简单的压缩/解压缩功能示例
2019/11/05 Javascript
从零学python系列之教你如何根据图片生成字符画
2014/05/23 Python
TensorFlow模型保存/载入的两种方法
2018/03/08 Python
python画一个玫瑰和一个爱心
2020/08/18 Python
Charles & Keith欧盟:新加坡时尚品牌
2019/08/01 全球购物
Booking.com缤客中国:全球酒店在线预订网站
2020/05/03 全球购物
加拿大专业美发产品购物网站:Chatters
2021/02/28 全球购物
劳资员岗位职责
2013/11/11 职场文书
学生励志演讲稿
2014/01/06 职场文书
元旦联欢会感言
2014/03/04 职场文书
自习课吵闹检讨书范文
2014/09/26 职场文书
ktv服务员岗位职责
2015/02/09 职场文书
2015年财务部工作总结
2015/04/10 职场文书
研讨会通知
2015/04/27 职场文书
SQL基础的查询语句
2021/11/11 MySQL
SpringBoot整合minio快速入门教程(代码示例)
2022/04/03 Java/Android