ホームページ >PHPフレームワーク >Laravel >hprose/hprose-php に基づいて開発された Laravel 拡張機能: laravel-hprosed の紹介

hprose/hprose-php に基づいて開発された Laravel 拡張機能: laravel-hprosed の紹介

不言
不言オリジナル
2018-08-28 17:01:043108ブラウズ

この記事の内容は hprose/hprose-php をベースに開発された Laravel 拡張機能に関するものです。laravel-hprosed の導入は参考になると思います。

hprose/hprose-phpに基づいて開発されたLaravel拡張機能: laravel-hprose

バージョン要件

Laravel>=5.3

インストール

composer require "zhuqipeng/laravel-hprose:v1.0-alpha"

またはcomposer.jsonを編集

"require": {
    "zhuqipeng/laravel-hprose": "v1.0-alpha"
}

設定

  1. config/app.phpにServiceProviderを登録し、ファサード (Laravel 5.5 手動登録は不要)

'providers' => [
    // ...

    Zhuqipeng\LaravelHprose\ServiceProvider::class,
]
'aliases' => [
    // ...

    'LaravelHproseMethodManage' => Zhuqipeng\LaravelHprose\Facades\HproseMethodManage::class,
]
  1. Configuration.env ファイル

リスニングアドレスリスト、文字列 json 形式の配列

HPROSE_URIS=["tcp://0.0.0.0:1314"]

デモメソッドを有効にするかどうか、有効にする場合は true、閉じる場合は false、有効にすると、自動的に外部に公開されます リモート呼び出しメソッド demo を公開しますdemo

客户端可调用:$client->demo()

HPROSE_DEMO=true // true or false
  1. 创建配置路由文件:

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 = []);
  • string $name 可供客户端远程调用的方法名

  • string|callable $action 类方法,格式:AppControllersUser@update

  • array $options 是一个关联数组,它里面包含了一些对该服务函数的特殊设置,详情请参考hprose-php官方文档介绍 链接

发布远程调用方法 getUserByNameupdate

クライアントは次を呼び出すことができます: $client->demo()

\LaravelHproseRouter::add('getUserByName', function ($name) {
    return 'name: ' . $name;
});

\LaravelHproseRouter::add('userUpdate', 'App\Controllers\User@update', ['model' => \Hprose\ResultMode::Normal]);

configuration を作成しますroute ファイル:

    <?php
    
    namespace App\Controllers;
    
    class User
    {
        public function update($name)
        {
            return &#39;update name: &#39; . $name;
        }
    }
  • 新しいファイル hprose.phpconfig ディレクトリに自動的に生成されます。アプリケーション ルート ディレクトリ

    routesrpc.php が /code> ディレクトリに自動的に生成されます
  • routing の使用方法
は laravel ルーティング、dingo/api のルーティング コードに基づいています 簡単な変更を行いました

ルーティング ファイル

$client->getUserByName(&#39;zhuqipeng&#39;);
$client->userUpdate(&#39;zhuqipeng&#39;);

ルーティング メソッドを追加しました

\LaravelHproseRouter::group(array $attributes, callable $callback);

string $name によってリモートで呼び出すことができるメソッド名client

string|呼び出し可能な $action クラス メソッド、形式: AppControllersUser@update

array $options はサービス関数の特別な設定を含む連想配列です。詳細については、hprose-php を参照してください。公式ドキュメント紹介リンク

🎜リモート呼び出しメソッドgetUserByNameupdateを公開🎜
\LaravelHproseRouter::group([&#39;namespace&#39; => &#39;App\Controllers&#39;], function ($route) {
    $route->add(&#39;getUserByName&#39;, function ($name) {
        return &#39;name: &#39; . $name;
    });

    $route->add(&#39;userUpdate&#39;, &#39;User@update&#39;);
});
🎜Controller🎜
$client->getUserByName(&#39;zhuqipeng&#39;);
$client->userUpdate(&#39;zhuqipeng&#39;);
🎜クライアント呼び出し🎜
\LaravelHproseRouter::group([&#39;namespace&#39; => &#39;App\Controllers&#39;, &#39;prefix&#39; => &#39;user&#39;], function ($route) {
    $route->add(&#39;getByName&#39;, function ($name) {
        return &#39;name: &#39; . $name;
    });

    $route->add(&#39;update&#39;, &#39;User@update&#39;);
});
🎜ルーティンググループ🎜
$client->user->getByName(&#39;zhuqipeng&#39;);
$client->user->update(&#39;zhuqipeng&#39;);
// 或者
$client->user_getByName(&#39;zhuqipeng&#39;);
$client->user_update(&#39;zhuqipeng&#39;);
🎜🎜🎜array $attributes 属性 ['namespace' => '', 'prefix' => ' ']🎜🎜🎜🎜呼び出し可能な $callback コールバック関数🎜🎜🎜
php artisan hprose:socket_server
🎜クライアント呼び出し🎜rrreee🎜プレフィックス🎜rrreee🎜クライアント呼び出し🎜rrreee🎜サービスの開始🎜rrreee🎜 関連する推奨事項: 🎜🎜🎜Laravel フレームワークのルーティング構成の概要、設定 スキルのコレクション、laravel フレームワーク 🎜🎜🎜🎜🎜 laravel フレームワークで関数を拡張し、カスタム クラスを拡張するメソッド、laravel フレームワーク 🎜🎜

以上がhprose/hprose-php に基づいて開発された Laravel 拡張機能: laravel-hprosed の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。