Laravel Hprose RPC 服务

开源地址:https://github.com/flc1125/laravel-hprose

该项目支持 Laravel 及非 Laravel 项目使用,支持 php >= 5.3 版本语法

注: 以下内容,默认你对 Hprose 已经有了一定了解。内容基于 Laravel 项目介绍。

安装

服务端安装即可,客户端可不安装

pecl install hprose
  • 安装扩展包
composer require flc/laravel-hprose

配置

服务提供者与门面

Laravel >= 5.5 已增加包自动发现。旧版本,请手动设置

  • config/app.php 文件下加入服务提供者
'providers' => [

    ...

    Flc\Laravel\Hprose\HproseServiceProvider::class,
]
  • config/app.php 文件下加入门面
'aliases' => [

    ...

    'HproseRoute' => Flc\Laravel\Hprose\Facades\HproseRoute::class,
    'HproseServer' => Flc\Laravel\Hprose\Facades\HproseServer::class,
    'HproseClient' => Flc\Laravel\Hprose\Facades\HproseClient::class,
]

初始化文件

php artisan hprose:generator

执行完成后,会分别生成以下文件:

  • 路由服务提供者:app/Providers/HproseRouteServiceProvider.php
  • 路由文件:routes/hprose.php (该路由文件非 Laravel 路由,下文简称 Hprose 路由

    Hprose 路由控制器根目录默认在:app/Http/Controllers/Hprose 目录下,可自行在 app/Providers/HproseRouteServiceProvider.php 调整

config/app.php 文件下加入默认的 Hprose 路由服务提供者

'providers' => [

    ...

    app\Providers\HproseRouteServiceProvider::class,
]

发布配置

php artisan vendor:publish --provider="Flc\Laravel\Hprose\HproseServiceProvider"

执行后,会生成配置文件路径:/config/hprose.php

使用

配置说明

配置文件路径:/config/hprose.php

<?php

return [
    'server' => [
        'default'     => 'http',
        'connections' => [
            'http' => [
                'protocol' => 'http',
            ],
        ],
    ],

    'client' => [
        'default'     => 'http',
        'connections' => array(
            'http' => array(
                'protocol' => 'http',
                'uri'      => 'http://192.168.2.67:9001/api/server',  // 此处为服务端的连接地址
                'async'    => false,
            ),
        ),
    ]
];

目前版本,除客户端配置中的远程服务器地址外,其他配置默认即可

其他均为后续支持 swoole-httptcpwebsocket 等,做提前架设

服务端

增加一个 Laravel 路由,用于启动 Http 服务,如:

<?php

Route::any('hprose-server', 'HproseController@server');

对应控制器:

<?php

namespace App\Http\Controllers;

use HproseServer;
use HproseRoute;

class HproseController
{
    public function server()
    {
        HproseServer::setRouter(HproseRoute::getRouter())->start();
    }
}

访问:http://localhost/hprose-server

Hprose 路由配置

<?php

HproseRoute::add('tests', 'Controller@tests');
HproseRoute::add('tests_one', 'Controller@tests')->option(['...']);

Controller@tests 的方法自行定义

客户端

<?php

namespace App\Http\Controllers;

use HproseClient;

class HproseController
{
    public function client()
    {
        $result = HproseClient::tests('tests');
        $result = HproseClient::connection('other')->tests('tests');  // 其他连接
        $result = HproseClient::connection()->tests->one('tests');

        print_r($result);
    }
}

非 Laravel 项目使用

服务端

<?php

$router = new \Flc\Laravel\Hprose\Routing\Router;
$router->group(['prefix' => 'tests', 'namespace' => 'App\\Controllers'], function ($router) {
    $router->add('one', 'Controller@one');
    $router->add('two', 'Controller@two')->option(['...']);

    $router->group(['prefix' => 'group'], function ($router) {
        $router->add('one', 'Controller@group_one');

        ...

    });
});

$app = [
    'config' => [
        'hprose.server.default' => 'http',
        'hprose.server.connections' => [
            'http' => [
                'protocol' => 'http',
            ],
        ],
    ],
];

$server = new \Flc\Laravel\Hprose\Server($app);
$server->setRouter($router)->start();

客户端

<?php
$app = [
    'config' => [
        'hprose.client.default' => 'http',
        'hprose.client.connections' => [
            'http' => [
                'protocol' => 'http',
                'uri'      => 'http://localhost/server.php',
                'async'    => false
            ]
        ]
    ]
];

$client = new \Flc\Laravel\Hprose\Client($app);

print_r($client->tests->one('222').PHP_EOL);

捐赠

如果你觉得本扩展对你有帮助,请捐赠以表支持,谢谢~~

wechat.jpg

微信

alipay.jpg

支付宝

License

MIT

本作品采用《CC 协议》,转载必须注明作者和本文链接
个人主页:flc.io
flc1125
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!