您好,登录后才能下订单哦!
这篇文章主要介绍了Laravel Hprose RPC服务的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
Laravel Hprose RPC 服务
开源地址:https://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' => '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-http
、tcp
、websocket
等,做提前架设
增加一个 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
<?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); } }
服务端
<?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);
感谢你能够认真阅读完这篇文章,希望小编分享的“Laravel Hprose RPC服务的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。