HPROSE 是 High Performance Remote Object Service Engine
的缩写,翻译成中文就是 “高性能远程对象服务引擎”。
Hprose是一个先进的轻量级的跨语言跨平台面向对象的高性能远程动态通讯中间件。它不仅简单易用,而且功能强大。它支持众多语言,例如nodeJs, C++, .NET, Java, Delphi, Objective-C, ActionScript, JavaScript, ASP, PHP, Python, Ruby, Perl, Golang 等语言,通过 Hprose 可以在这些语言之间实现方便且高效的互通。
步骤1 引入hprose
在你的 laravel目录中的 composer.json 文件中,添加这部分::
{
"require": {
"hprose/hprose": ">=2.0.0"
}
}
然后在你的根目录使用composer update 命令下载 hprose 扩展包
步骤2 创建服务端
在你的app目录下 创建一个Services目录(可手动创建)
在目录下面创建UserService.php作为服务端,内容如下:
<?php
namespace App\Services;
use Hprose\Http\Server;
class UserService{
public function init(){
$server=new Server();
$server->addMethod('test',$this);
$server->start();
}
public function test(){
return 'hello';
}
}
步骤3 创建服务端路由
简单的服务端的代码就完成了,现在我们在api.php设置一下路由:
Route::post('service', function (Request $request) {//服务端一定用post不然会报错
$server = new \App\Services\UserService();
$server->init(); //开启服务
})->middleware('api');
测试:访问http://localhost/api/service,如果出现“Fa1{s5”test”}z”就表示方法是成功添加到服务了。
猜测这个序列化结果的含义:
F表示function;a表示List/Array;1表示List/Array的长度;{和}是分隔符,便于解析;s表示String;4表示后接string的长度;z表示end。
步骤4 创建客户端
这边我还是以laravel框架创建客户端为例。
还是在Service目录下面新建文件UserClien.php作为客户端,内容如下:
<?php
namespace App\Services;
use Hprose\Http\Client;
class UserClien
{
public function index($request){
//服务端路由在api路由中配置,则此处路由应加上api/test
//实例化可选参数 加上false 即创建创建一个同步的 HTTP 客户端
//不写false 为创建一个异步的 HTTP 客户端
$user =new Client('http://localhost/api/test',false);
$res=$user->test();
dd($res);
}
}
步骤5 创建客户端路由
在web.php中添加
Route::post('Clien', function () {
$server = new \App\Services\UserClien();
$server->index();
});
测试:访问http://localhost/clien,如果输出“hello”就表示简单的分布式应用就开发好了。
作者:赵客缦胡缨v吴钩霜雪明
链接:https://www.jianshu.com/p/f028c230174c
来源:简书
基于 hprose/hprose-php 开发的Laravel扩展:laravel-hprose
Laravel >= 5.2
```composer require "zhuqipeng/laravel-hprose:v1.0-alpha"
```
或者编辑composer.json
"require": {
"zhuqipeng/laravel-hprose": "v1.0-alpha"
}
在 config/app.php 注册 ServiceProvider 和 Facade (Laravel 5.5 无需手动注册)
'providers' => [
// ...
Zhuqipeng\LaravelHprose\ServiceProvider::class,
]
配置.env文件
监听地址列表,字符串json格式数组
HPROSE_URIS=["tcp://0.0.0.0:1314"]
是否启用demo方法,true开启 false关闭,开启后将自动对外发布一个远程调用方法 demo
客户端可调用:$client->demo()
HPROSE_DEMO=true // true or false
创建配置
和路由
文件:
```php artisan vendor:publish --provider="Zhuqipeng\LaravelHprose\ServiceProvider"
```
应用根目录下的
config
目录下会自动生成新文件hprose.php
应用根目录下的
routes
目录下会自动生成新文件rpc.php
和
laravel
路由的用法相似,基于 dingo/api 的路由代码上做了简单修改
路由文件
routes/rpc.php
添加路由方法
\LaravelHproseRouter::add(string $name, string|callable $action, array $options = []);
发布远程调用方法 getUserByName
和 update
<?php
\LaravelHproseRouter::add('getUserByName', function ($name) {
return 'name: ' . $name;
});
\LaravelHproseRouter::add('userUpdate', 'App\Controllers\User@update', ['model' => \Hprose\ResultMode::Normal]);
tips:使用idea的同学可以使用 php artisan ide-helper:generate 生成代码提示
控制器
<?php
namespace App\Controllers;
class User
{
public function update($name)
{
return 'update name: ' . $name;
}
}
客户端调用
$client->getUserByName('zhuqipeng');
$client->userUpdate('zhuqipeng');
路由组
\LaravelHproseRouter::group(array $attributes, callable $callback);
\LaravelHproseRouter::group(['namespace' => 'App\Controllers'], function ($route) {
$route->add('getUserByName', function ($name) {
return 'name: ' . $name;
});
$route->add('userUpdate', 'User@update');
});
客户端调用
$client->getUserByName('zhuqipeng');
$client->userUpdate('zhuqipeng');
前缀
\LaravelHproseRouter::group(['namespace' => 'App\Controllers', 'prefix' => 'user'], function ($route) {
$route->add('getByName', function ($name) {
return 'name: ' . $name;
});
$route->add('update', 'User@update');
});
客户端调用
$client->user->getByName('zhuqipeng');
$client->user->update('zhuqipeng');
// 或者
$client->user_getByName('zhuqipeng');
$client->user_update('zhuqipeng');
```php artisan hprose:socket_server
```
github地址:https://github.com/hprose/hprose-php