poplary / lumen-hprose by poplary

Hprose for Lumen
97
2
1
Package Data
Maintainer Username: poplary
Package Create Date: 2020-08-13
Package Last Update: 2020-12-17
Language: PHP
License: MIT
Last Refreshed: 2024-04-19 15:15:31
Package Statistics
Total Downloads: 97
Monthly Downloads: 0
Daily Downloads: 0
Total Stars: 2
Total Watchers: 1
Total Forks: 0
Total Open Issues: 0

Lumen-hprose

安装

直接使用

composer require poplary/lumen-hprose

使用lumen配置

  1. 在 bootstrap/app.php 注册 ServiceProvider

    $app->register(\Poplary\LumenHprose\ServiceProvider::class);
    
  2. 配置.env文件

    // 服务的名称
    HPROSE_SERVICE=product
    
    // 是否开启 debug
    HPROSE_DEBUG=true
    
    // Hprose 服务启用方式,可选 socket 和 swoole,选择 swoole 时需要安装 swoole 扩展
    HPROSE_SERVER=socket
    
    // 监听的 TCP 端口
    HPROSE_URI=tcp://0.0.0.0:8889
    
  3. 创建配置路由文件:

    cp ./vendor/poplary/lumen-hprose/config/hprose.php ./config/hprose.php
    cp ./vendor/poplary/lumen-hprose/routes/hprose.php ./routes/hprose.php
    

使用

路由

路由文件

routes/hprose.php

添加路由方法

use Poplary\LumenHprose\Facades\Router;

Router::add(string $name, string|callable $action, array $options = []);
  • string $name 可供客户端远程调用的方法名
  • string|callable $action 类方法,格式:App\Controllers\User@update
  • array $options 是一个关联数组,它里面包含了一些对该服务函数的特殊设置,详情请参考hprose-php官方文档介绍 链接

发布远程调用方法 getUserByNameupdate

Router::add('getServiceName', 'Poplary\LumenHprose\Controllers\DemoController@getServiceName');

控制器

<?php

namespace Poplary\LumenHprose\Controllers;

/**
 * Class DemoController.
 */
class DemoController
{
    /**
     * @return string
     */
    public function getServiceName(): string
    {
        return config('hprose.service');
    }
}

客户端调用 客户端可以只安装 Hprose

$client = new \Hprose\Socket\Client('tcp://127.0.0.1:8889', false);
echo $client->getServiceName();

路由组

Router::group(array $attributes, callable $callback);
  • array $attributes 属性 ['namespace' => '', 'prefix' => '']
  • callable $callback 回调函数
Router::group(['namespace' => 'Poplary\LumenHprose\Controllers'], function ($route) {    
    $route->add('getServiceName', 'DemoController@getServiceName');
});

客户端调用

echo $client->getServiceName();

前缀

Router::group(['namespace' => 'Poplary\LumenHprose\Controllers', 'prefix' => 'demo'], function ($route) {
    $route->add('getServiceName', 'DemoController@getServiceName');
});

客户端调用

echo $client->demo->getServiceName();
// 或者
echo $client->demo_getServiceName();

如果服务端出现 Exception ,因为 Hprose 没有返回 code,需要将code 合并到message用json方式包裹返回

try{
    $client->user->getServiceName();
}catch(\Exception $e){
    $info = json_decode($e->getMessage(),true);
    $message = $info['message'];
    $code = $info['code'];
}

启动服务

php artisan hprose:server

更新了路由后需要重新启动服务

Demo 测试

php artisan hprose:client:demo