探讨Hessian在PHP中的使用分析

2015-01-24信息快讯网

本篇文章是对Hessian在PHP中的使用进行了详细的分析介绍, 需要的朋友参考下

什么是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 <[email protected]>
 * @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 <[email protected]>
 * @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 <[email protected]>
 * @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 <[email protected]>
* @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-perl哈希算法实现(times33哈希算法)
PHP数据库链接类(PDO+Access)实例分享
wordpress自定义url参数实现路由功能的代码示例
PHP上传文件时文件过大$_FILES为空的解决方法
CodeIgniter生成网站sitemap地图的方法
PHP生成sitemap.xml地图函数
PHP反射类ReflectionClass和ReflectionObject的使用方法
php生成EAN_13标准条形码实例
php5.3 不支持 session_register() 此函数已启用的解决方法
session在php5.3中的变化 session_is_registered() is deprecated in
PHP set_error_handler()函数使用详解(示例)
php session劫持和防范的方法
php中的boolean(布尔)类型详解
php中OR与|| AND与&&的区别总结
完美解决PHP中的Cannot modify header information 问题
eAccelerator的安装与使用详解
深入PHP变量存储的详解
coreseek 搜索英文的问题详解
使用session判断用户登录用户权限(超简单)
探讨如何使用SimpleXML函数来加载和解析XML文档
探讨如何把session存入数据库
PHP使用DES进行加密与解密的方法详解
深入PHP empty(),isset(),is_null()的实例测试详解
基于session_unset与session_destroy的区别详解
php的POSIX 函数以及进程测试的深入分析
基于wordpress主题制作的具体实现步骤
setcookie中Cannot modify header information-headers already sent by错误的解决方法详解
php笔记之:php函数range() round()和list()的使用说明
CI框架源码阅读,系统常量文件constants.php的配置
PHP中函数rand和mt_rand的区别比较
Erlang的运算符(比较运算符,数值运算符,移位运算符,逻辑运算符)
©2014-2025 dbsqp.com