Laravel Hprose RPC 服务如何实现高效跨平台远程过程调用?
- 内容介绍
- 文章标签
- 相关推荐
本文共计932个文字,预计阅读时间需要4分钟。
由Laravel教程栏目为您介绍关于Laravel Hprose RPC服务的相关知识,希望对需要的朋友有所帮助!Laravel Hprose RPC服务开源地址:[https://github.com/flc1125/laravel-hprose](https://github.com/flc1125/laravel-hprose)。该项目支持Laravel及非Laravel。
下面由laravel教程栏目给大家介绍关于 Laravel Hprose RPC 服务,希望对需要的朋友有所帮助!Laravel Hprose RPC 服务
开源地址:github.com/flc1125/laravel-hprose
该项目支持 Laravel 及非 Laravel 项目使用,支持 php >= 5.3 版本语法
注: 以下内容,默认你对 Hprose 已经有了一定了解。内容基于 Laravel 项目介绍。
安装
环境依赖 C 扩展
hprose,详见:Hprose 官网、Hprose Pecl 扩展服务端安装即可,客户端可不安装
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' => '192.168.2.67:9001/api/server', // 此处为服务端的连接地址 'async' => false, ), ), ] ];
目前版本,除客户端配置中的远程服务器地址外,其他配置默认即可
其他均为后续支持 swoole-localhost/hprose-serverHprose 路由配置
<?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' => 'localhost/server.php',
'async' => false
]
]
]
];
$client = new \Flc\Laravel\Hprose\Client($app);
print_r($client->tests->one('222').PHP_EOL);
以上就是关于 Laravel Hprose RPC 服务的详细内容,更多请关注自由互联其它相关文章!

本文共计932个文字,预计阅读时间需要4分钟。
由Laravel教程栏目为您介绍关于Laravel Hprose RPC服务的相关知识,希望对需要的朋友有所帮助!Laravel Hprose RPC服务开源地址:[https://github.com/flc1125/laravel-hprose](https://github.com/flc1125/laravel-hprose)。该项目支持Laravel及非Laravel。
下面由laravel教程栏目给大家介绍关于 Laravel Hprose RPC 服务,希望对需要的朋友有所帮助!Laravel Hprose RPC 服务
开源地址:github.com/flc1125/laravel-hprose
该项目支持 Laravel 及非 Laravel 项目使用,支持 php >= 5.3 版本语法
注: 以下内容,默认你对 Hprose 已经有了一定了解。内容基于 Laravel 项目介绍。
安装
环境依赖 C 扩展
hprose,详见:Hprose 官网、Hprose Pecl 扩展服务端安装即可,客户端可不安装
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' => '192.168.2.67:9001/api/server', // 此处为服务端的连接地址 'async' => false, ), ), ] ];
目前版本,除客户端配置中的远程服务器地址外,其他配置默认即可
其他均为后续支持 swoole-localhost/hprose-serverHprose 路由配置
<?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' => 'localhost/server.php',
'async' => false
]
]
]
];
$client = new \Flc\Laravel\Hprose\Client($app);
print_r($client->tests->one('222').PHP_EOL);
以上就是关于 Laravel Hprose RPC 服务的详细内容,更多请关注自由互联其它相关文章!


