溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么PHP中使用Hessian

發(fā)布時(shí)間:2020-12-22 15:02:53 來源:億速云 閱讀:160 作者:Leah 欄目:開發(fā)技術(shù)

怎么PHP中使用Hessian?很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

什么是Hessian
  Hessian是由caucho提供的一種開源的遠(yuǎn)程通訊協(xié)議。
  采用二進(jìn)制 RPC 協(xié)議,基于 HTTP 傳輸,服務(wù)器端不用另開放防火墻端口。
  協(xié)議的規(guī)范是公開的,可以用于任意語言。
  采用客戶機(jī)/服務(wù)器模式。
  請求程序就是一個(gè)客戶機(jī),而服務(wù)提供程序就是一個(gè)服務(wù)器。
  客戶機(jī)調(diào)用進(jìn)程發(fā)送一個(gè)有進(jìn)程參數(shù)的調(diào)用信息到服務(wù)進(jìn)程,然后等待應(yīng)答信息。
  在服務(wù)器端,進(jìn)程保持睡眠狀態(tài)直到調(diào)用信息的到達(dá)為止。
  當(dāng)一個(gè)調(diào)用信息到達(dá),服務(wù)器獲得進(jìn)程參數(shù),計(jì)算結(jié)果,發(fā)送答復(fù)信息,然后等待下一個(gè)調(diào)用信息,最后,客戶端調(diào)用進(jìn)程接收答復(fù)信息,
  獲得進(jìn)程結(jié)果,然后調(diào)用執(zhí)行繼續(xù)進(jìn)行。

Hessian協(xié)議工作流程圖
  客戶端程序請求服務(wù)端函數(shù) 
  1.調(diào)用客戶端句柄,執(zhí)行傳送參數(shù)。
  2.調(diào)用本地系統(tǒng)內(nèi)核發(fā)送網(wǎng)絡(luò)消息。
  3.消息傳送到遠(yuǎn)程主機(jī)。
  4.服務(wù)器句柄得到消息并取得參數(shù)。
  5.執(zhí)行遠(yuǎn)程過程。

怎么PHP中使用Hessian

服務(wù)端函數(shù)返回結(jié)果給客戶端
  1.執(zhí)行的過程將結(jié)果返回服務(wù)器句柄。
  2.服務(wù)器句柄返回結(jié)果,調(diào)用遠(yuǎn)程系統(tǒng)內(nèi)核。
  3.消息傳回本地主機(jī)。
  4.客戶句柄由內(nèi)核接收消息。
  5.客戶接收句柄返回的數(shù)據(jù)。

怎么PHP中使用Hessian

附帶源碼解釋

1.引用配置文件,包括網(wǎng)站根目錄,以及Hessian的地址。

復(fù)制代碼 代碼如下:


<?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.配置服務(wù)端。

復(fù)制代碼 代碼如下:


<?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() {}
    /**
     * 商品詳細(xì)信息APi接口
     * @param string $title 標(biāo)題
     * @param int $price 價(jià)格
     */
    public function goodsInfomationApi( $title , $price ) {
        $price = (int) $price;
        return '<h2 >使用Hessian協(xié)議調(diào)用遠(yuǎn)程方法.</h2> 標(biāo)題:' . $title . '<br>價(jià)格:'.$price;
    }
}

$server = new HessianService( new HessianServer() );
//$server->displayInfo();
$server->handle();

// IDE : Zend Studio 9.0
// IDE Extension : Toggle Vrapper
?>

3.可以通過HessianService類中的displayInfo方法去查看開啟多少個(gè)通訊方法。
如果搭建服務(wù)端要使用handle方法,如出現(xiàn)Hessian Requires POST提示,服務(wù)端就已經(jīng)搭建成功。

4.封裝Hessian接口

復(fù)制代碼 代碼如下:


<?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 存放單例模式數(shù)組
     */
    private static $_objects = array();

    /**
     * 設(shè)置URL地址
     * 實(shí)例化HessianClient類
     * 參數(shù)    : (1) url地址 , 2
     *
     * 2.Java調(diào)用字段
     * @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;
    }

    /**
     * 設(shè)置句柄
     * @param result $_handle
     */
    public function setHandler($_handle) {
        $this->_handle = $_handle;
    }

    /**
     * 獲取URL地址
     */
    public function getUrl() {
        return $this->_url;
    }

    /**
     * 設(shè)置URL地址
     * @param string $url
     */
    public function setUrl($url) {
        $this->_url = $url;
    }

    /**
     * typeMap映射Java等平臺(tái)對象
     * @return array
     */
    public function getOptions() {
        return array (
      'version' => 1,
      'saveRaw' => TRUE,
      'typeMap' => array(
        'JavaNullPointException' => 'java.lang.NullPointerException' ,
        'StackTraceElement' => 'java.lang.StackTraceElement')
     );
    }

    /**
     * 記錄接口調(diào)用信息
     * @param string $method 調(diào)用的方法
     * @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');
    }

    /**
     * 靜態(tài)工廠方法,生成單個(gè)URL的唯一實(shí)例
     * @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類

復(fù)制代碼 代碼如下:


<?php
/**
 * 類名        : Goods
 * 繼承類        : HessianApi
 * 用途        : 調(diào)用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
{
    /**
     * 設(shè)置接口地址
     * @param string $url
     */
    public function __construct( $url ) {
        parent::__construct( $url );
    }

    /**
     * 獲取商品信息
     * 調(diào)用server.php文件中的goodsInfomationApi方法
     * @param string $title 標(biāo)題
     * @param string $title 價(jià)格
     */
    public function getGoodsInfomation( $title , $price )
    {
        // 如果調(diào)用java平臺(tái)的hessian服務(wù) 需要指定你傳遞參數(shù)的類型,特別是整形和字符串.
        $price = (int) $price;

        $result = $this->getHandler()->goodsInfomationApi( $title , $price );
        $this->resultLog( 'getGoodsInfomation' , '訪問接口,但接口沒有進(jìn)行邏輯驗(yàn)證.');
        return $result;
    }
}

// IDE : Zend Studio 9.0
// IDE Extension : Toggle Vrapper
?>

6.修改index.php可以請求服務(wù)端接口

復(fù)制代碼 代碼如下:


<?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 擴(kuò)展及配置文件
require_once ( PATH . 'extensions/HessianPHP/HessianClient.php' );
require_once ( PATH . 'class/HessianApi.php' );


// 調(diào)用 server.php 方法
require_once ( PATH . 'class/Goods.php');

// 請求接口獲取數(shù)據(jù)
$goods = new Goods( HESSIAN_URL );

// 設(shè)置商品標(biāo)題 , 價(jià)格.
$title = '北京移動(dòng)充值平臺(tái)';
$price = '50';

// 請求Hessian協(xié)議
$goodsInfo = $goods->getGoodsInfomation( (string) $title , (int) $price );

// 打印請求結(jié)果
echo ( $goodsInfo );

// IDE : Zend Studio 9.0
// IDE Extension : Toggle Vrapper

?>
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI