一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

探討Hessian在PHP中的使用分析

什么是Hessian
  Hessian是由caucho提供的一種開源的遠程通訊協議。
  采用二進制 RPC 協議,基于 HTTP 傳輸,服務器端不用另開放防火墻端口。
  協議的規范是公開的,可以用于任意語言。
  采用客戶機/服務器模式。
  請求程序就是一個客戶機,而服務提供程序就是一個服務器
  客戶機調用進程發送一個有進程參數的調用信息到服務進程,然后等待應答信息。
  在服務器端,進程保持睡眠狀態直到調用信息的到達為止。
  當一個調用信息到達,服務器獲得進程參數,計算結果,發送答復信息,然后等待下一個調用信息,最后,客戶端調用進程接收答復信息,
  獲得進程結果,然后調用執行繼續進行。

Hessian協議工作流程圖
  客戶端程序請求服務端函數 
  1.調用客戶端句柄,執行傳送參數。
  2.調用本地系統內核發送網絡消息。
  3.消息傳送到遠程主機。
  4.服務器句柄得到消息并取得參數。
  5.執行遠程過程。



服務端函數返回結果給客戶端
  1.執行的過程將結果返回服務器句柄。
  2.服務器句柄返回結果,調用遠程系統內核。
  3.消息傳回本地主機。
  4.客戶句柄由內核接收消息。
  5.客戶接收句柄返回的數據。

附帶源碼解釋

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技術探討Hessian在PHP中的使用分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产福利午夜自产拍视频在线 | 精彩视频一区二区三区 | 91在线高清 | 中国一级特黄真人毛片免 | 欧美91在线| 国产精品麻豆久久99 | 国产99久久精品 | 国产成人久久精品推最新 | 色播视频在线播放 | 天天色天天| 日本在线视频www色 日本在线视频免费观看 | 狠狠伊人| 91精品国产91久久久久 | 国产成人一区二区三区影院免费 | 不卡一区二区三区四区 | 99久久精品国产麻豆 | 精品一区精品二区 | 2020国产精品视频免费 | 免费在线看黄 | 免费一级毛片不卡不收费 | 手机在线色视频 | 亚州一二区 | 久久精品久久精品久久精品 | 婷婷六月激情在线综合激情 | 日韩中文字幕精品免费一区 | 免费看污成人午夜网站 | 香蕉成人在线视频 | 久久精品全国免费观看国产 | 亚洲国产精品日韩高清秒播 | 日本一二三高清 | 国产亚洲福利 | 一本色道久久综合亚洲精品高清 | 九一色视频 | 国产在线麻豆自在拍91精品 | 一色屋成人免费精品网 | 婷婷激情四月 | 欧美一区二区三区综合色视频 | 国产精品亚洲欧美日韩久久 | 久久国产一区二区三区 | 国产精品成人嫩妇 | 国产午夜视频高清 |