探讨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 相关文章推荐
用PHP连接Oracle数据库
Oct 09 PHP
模仿OSO的论坛(一)
Oct 09 PHP
php的POSIX 函数以及进程测试的深入分析
Jun 03 PHP
使用PHP下载CSS文件中的图片的代码
Sep 24 PHP
Laravel 5 框架入门(四)完结篇
Apr 09 PHP
10个超级有用的PHP代码片段果断收藏
Sep 23 PHP
php实现的简单数据库操作Model类
Nov 16 PHP
php技巧小结【推荐】
Jan 19 PHP
php使用GD2绘制几何图形示例
Feb 15 PHP
PHP基于ORM方式操作MySQL数据库实例
Jun 21 PHP
php判断电子邮件是否正确方法
Dec 04 PHP
thinkphp5.1框架实现格式化mysql时间戳为日期的方式小结
Oct 10 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采集时被封ip的解决方法
2010/08/29 PHP
WIN8.1下搭建PHP5.6环境
2015/04/29 PHP
php生成txt文件实例代码介绍
2016/04/28 PHP
Yii2中如何使用modal弹窗(基本使用)
2016/05/30 PHP
php上传excel表格并获取数据
2017/04/27 PHP
thinkphp 抓取网站的内容并且保存到本地的实例详解
2017/08/25 PHP
laravel 执行迁移回滚示例
2019/10/23 PHP
Firefox和IE浏览器兼容JS脚本写法小结
2008/07/07 Javascript
JavaScript数组常用操作技巧汇总
2014/11/17 Javascript
JavaScript数组各种常见用法实例分析
2015/08/04 Javascript
详解使用vue-router进行页面切换时滚动条位置与滚动监听事件
2017/03/08 Javascript
React之PureComponent的使用作用
2018/07/10 Javascript
逐行分析鸿蒙系统的 JavaScript 框架(推荐)
2020/09/17 Javascript
python flask实现分页效果
2017/06/27 Python
Python微信企业号开发之回调模式接收微信端客户端发送消息及被动返回消息示例
2017/08/21 Python
Window10+Python3.5安装opencv的教程推荐
2018/04/02 Python
使用pandas read_table读取csv文件的方法
2018/07/04 Python
python dataframe向下向上填充,fillna和ffill的方法
2018/11/28 Python
对django 模型 unique together的示例讲解
2019/08/06 Python
pycharm运行程序时看不到任何结果显示的解决
2020/02/21 Python
jupyter notebook 使用过程中python莫名崩溃的原因及解决方式
2020/04/10 Python
python 制作网站小说下载器
2021/02/20 Python
来自世界各地的饮料:Flavourly
2019/05/06 全球购物
一家专门经营包包的英国网站:MyBag
2019/09/08 全球购物
几道Web/Ajax的面试题
2016/11/05 面试题
什么是继承
2013/12/07 面试题
车间班组长的职责
2013/12/13 职场文书
开会迟到检讨书
2014/01/08 职场文书
红旗团支部事迹材料
2014/01/27 职场文书
培训主管岗位职责
2014/02/01 职场文书
会计核算科岗位职责
2014/03/19 职场文书
网站美工岗位职责
2014/04/02 职场文书
爱祖国演讲稿
2014/05/04 职场文书
社区法制宣传日活动总结
2015/05/05 职场文书
2016年大学生暑期社会实践方案
2015/11/26 职场文书
解决Tkinter中button按钮未按却主动执行command函数的问题
2021/05/23 Python