探讨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 相关文章推荐
Apache+php+mysql在windows下的安装与配置图解(最新版)
Nov 30 PHP
PHP中extract()函数的妙用分析
Jul 11 PHP
PHP中的函数-- foreach()的用法详解
Jun 24 PHP
Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存
Feb 10 PHP
php输出全球各个时区列表的方法
Mar 31 PHP
php显示时间常用方法小结
Jun 05 PHP
配置eAccelerator和XCache扩展来加速PHP程序的执行
Dec 22 PHP
今天你说520了吗?不仅有php表白书还有java表白神器
May 20 PHP
PHP defined()函数的使用图文详解
Jul 20 PHP
laravel 根据不同组织加载不同视图的实现
Oct 14 PHP
php使用Swoole实现毫秒级定时任务的方法
Sep 04 PHP
win10下 php安装seaslog扩展的详细步骤
Dec 04 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中关于抽象(abstract)类和抽象方法的问题分析
2014/01/03 PHP
php中url函数介绍及使用示例
2014/02/13 PHP
smarty自定义函数用法示例
2016/05/20 PHP
3种方法轻松处理php开发中emoji表情的问题
2016/07/18 PHP
JavaScript触发器详解
2007/03/10 Javascript
用JavaScript页面不刷新时全选择,全删除(GridView)
2009/04/14 Javascript
js自定义事件及事件交互原理概述(二)
2013/02/01 Javascript
一个JS的日期格式化算法示例
2013/07/31 Javascript
Javascript中3种实现继承的方法和代码实例
2014/08/12 Javascript
javascript学习笔记(五)原型和原型链详解
2014/10/08 Javascript
node.js中的buffer.length方法使用说明
2014/12/14 Javascript
jQuery实现新消息闪烁标题提示的方法
2015/03/11 Javascript
requirejs按需加载angularjs文件实例
2017/06/08 Javascript
vue两个组件间值的传递或修改方式
2018/07/04 Javascript
vue + typescript + video.js实现 流媒体播放 视频监控功能
2019/07/07 Javascript
解决layer 动态加载select 失效的问题
2019/09/18 Javascript
封装 axios+promise通用请求函数操作
2020/08/11 Javascript
[02:28]DOTA2 2015国际邀请赛中国区预选赛首日现场百态
2015/05/26 DOTA
以911新闻为例演示Python实现数据可视化的教程
2015/04/23 Python
从Python的源码来解析Python下的freeblock
2015/05/11 Python
python中enumerate函数遍历元素用法分析
2016/03/11 Python
python实现域名系统(DNS)正向查询的方法
2016/04/19 Python
Python 搭建Web站点之Web服务器与Web框架
2016/11/06 Python
python遍历文件夹下所有excel文件
2018/01/03 Python
Python编程pygame模块实现移动的小车示例代码
2018/01/03 Python
详解Pytorch 使用Pytorch拟合多项式(多项式回归)
2018/05/24 Python
Ubuntu16.04安装python3.6.5步骤详解
2020/01/10 Python
python通过对字典的排序,对json字段进行排序的实例
2020/02/27 Python
使用python采集Excel表中某一格数据
2020/05/14 Python
关于python3.7安装matplotlib始终无法成功的问题的解决
2020/07/28 Python
美国最大的珠宝商之一:Littman Jewelers
2016/11/13 全球购物
介绍一下代理模式(Proxy)
2014/10/17 面试题
《匆匆》教学反思
2014/02/22 职场文书
药剂专业求职信
2014/06/20 职场文书
身边的榜样活动方案
2014/08/20 职场文书
妇产科护理心得体会
2016/01/22 职场文书