メインメニュー
XAMPP アレンジ
IED
WSL2
- 
道具箱リポジトリ編フレームワーク編公開ソフトウェアメタリンク- PHP ライブラリ- PHP 言語
 slim:4:routing目次文書の過去の版を表示しています。 
 Slim4 ルーティングVersion 4.5.0 — y2sunlight 2020-09-23 関連記事 
- Slim4 ルーティング
 本章は以下のサイトの Routing のセクションを翻訳し若干の補足を加えたのもです。 
 SlimFramework のルーターは FastRoute コンポーネントの上に構築されており、非常に高速で安定しています。このコンポーネントを使用して全てのルーティングを処理している間は、アプリのコアとそれは完全に分離されており、他のルーティングライブラリを使用をすることを容易にするためにインターフェイスが設置されています。 ルートの作成方法アプリケーションルートは、 Slim\Appインスタンス上のプロキシメソッドを使用することにより定義できます。Slim Frameworkは、最も一般的なHTTPメソッドに対するメソッドを提供します。GET ルートSlimアプリケーションの get()メソッドを使用して、GETHTTPリクエストのみを処理するルートを追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->get('/books/{id}', function ($request, $response, array $args) { // Show book identified by $args['id'] }); 
 POST ルートSlimアプリケーションの post()メソッドを使用して、POSTHTTPリクエストのみを処理するルート(route)を追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->post('/books', function ($request, $response, array $args) { // Create new book }); 
 PUT ルートSlimアプリケーションの put()メソッドを使用して、PUTHTTPリクエストのみを処理するルートを追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->put('/books/{id}', function ($request, $response, array $args) { // Update book identified by $args['id'] }); 
 DELETE ルートSlimアプリケーションの delete()メソッドを使用して、DELETEHTTPリクエストのみを処理するルートを追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->delete('/books/{id}', function ($request, $response, array $args) { // Delete book identified by $args['id'] }); 
 OPTIONS ルートSlimアプリケーションの options()メソッドを使用して、OPTIONSHTTPリクエストのみを処理するルートを追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->options('/books/{id}', function ($request, $response, array $args) { // Return response headers }); 
 PATCH ルートSlimアプリケーションの patch()メソッドを使用して、PATCHHTTPリクエストのみを処理するルートを追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->patch('/books/{id}', function ($request, $response, array $args) { // Apply changes to book identified by $args['id'] }); 
 Any ルートSlimアプリケーションの any()メソッドを使用して、すべてのHTTPリクエストメソッドを処理するルートを追加できます。それは2つの引数を受け入れます:- ルートパターン(オプションで名前付きプレースホルダーを含みます)
- ルートコールバック
 $app->any('/books/[{id}]', function ($request, $response, array $args) { // Apply changes to books or book identified by $args['id'] if specified. // To check which method is used: $request->getMethod(); }); 2番目のパラメーターはコールバックであることに注意してください。Closureの代わりに __invoke() メソッドを実装するクラスを指定できます。その後、別の場所でマッピングを行うことができます。 $app->any('/user', 'MyRestfulController'); 
 Custom RouteSlimアプリケーションの map()メソッドを使用して、複数のHTTPリクエストメソッドを処理するルートを追加できます。それは次の3つの引数を受け入れます:- HTTPメソッドの配列
- ルートのパターン(オプションで名前付きプレースホルダーを含みます)
- ルートのコールバック
 $app->map(['GET', 'POST'], '/books', function ($request, $response, array $args) { // Create new book or list all books }); 
 ルートコールバック上記の各ルーティングメソッドは、最後の引数としてコールバックルーチンを受け入れます。この引数は、任意のPHP callable が可能であり、それはデフォルトでは3つの引数を受け入れます。 - Request最初の引数は、現在のHTTPリクエストを表す- Psr\Http\Message\ServerRequestInterfaceオブジェクトです。
- Response2番目の引数は、現在のHTTP応答を表す- Psr\Http\Message\ResponseInterfaceオブジェクトです。
- Arguments3番目の引数は、現在のルートの名前付きプレースホルダーの値を含む連想配列です。
 応答へのコンテンツの書き込みHTTP応答にコンテンツを書き込む方法は2つあります。まず、ルートコールバックからコンテンツを単に echo()することができます。このコンテンツは、現在のHTTP応答オブジェクトに追加されます。次に、Psr\Http\Message\ResponseInterfaceオブジェクトを返すことができます。
 クロージャバインディングルートコールバックとして、依存関係コンテナと Closureインスタンスを使用する場合、クロージャの状態はContainerインスタンスにバインドされています。これは、$thisキーワードを介して、クロージャー内のDIコンテナーインスタンスにアクセスできることを意味します:$app->get('/hello/{name}', function ($request, $response, array $args) { // Use app HTTP cookie service $this->get('cookies')->set('name', [ 'value' => $args['name'], 'expires' => '7 days' ]); }); 注意喚起
 Slimは静的クロージャーをサポートしていません。
 リダイレクトヘルパーSlimアプリケーションの redirect()メソッドを使用して、GETHTTPリクエストを別のURLにリダイレクトするルートを追加できます。それは次の3つの引数を受け入れます:- リダイレクト元fromのルートパターン(オプションで名前付きプレースホルダーを含みます)
- リダイレクト先toの場所。文字列または Psr\Http\Message\UriInterface の場合があります。
- 使用するHTTPステータスコード(オプション:設定されていない場合は302)
 $app->redirect('/books', '/library', 301); redirect()ルートは、要求されたステータスコードと、2番目の引数に設定されたLocationヘッダーで応答します。
 ルート戦略ルートコールバックのシグニチャは、ルート戦略によって決定されます。デフォルトでは、Slimは、ルートコールバックがリクエスト、レスポンス、およびルートプレースホルダー引数の配列を受け入れることを期待しています。これは、 RequestResponse戦略と呼ばれます。 ただし、別の戦略を使用するだけで、期待されるルートコールバックシグニチャを変更できます。例として、Slimは、リクエストとレスポンに加えて個々に分かれた引数として各ルートプレースホルダーを受け入れるRequestResponseArgsと呼ばれる代替戦略を提供します。この代替戦略の使用例を次に示します: <?php use Slim\Factory\AppFactory; use Slim\Handlers\Strategies\RequestResponseArgs; require __DIR__ . '/../vendor/autoload.php'; $app = AppFactory::create(); /** * Changing the default invocation strategy on the RouteCollector component * will change it for every route being defined after this change being applied */ $routeCollector = $app->getRouteCollector(); $routeCollector->setDefaultInvocationStrategy(new RequestResponseArgs()); $app->get('/hello/{name}', function ($request, $response, $name) { $response->getBody()->write($name); return $response; }); あるいは、ルートごとに異なる呼び出し戦略を設定することもできます: <?php use Slim\Factory\AppFactory; use Slim\Handlers\Strategies\RequestResponseArgs; require __DIR__ . '/../vendor/autoload.php'; $app = AppFactory::create(); $routeCollector = $app->getRouteCollector(); $route = $app->get('/hello/{name}', function ($request, $response, $name) { $response->getBody()->write($name); return $response; }); $route->setInvocationStrategy(new RequestResponseArgs()); Slim\Interfaces\InvocationStrategyInterfaceを実装することにより、独自のルート戦略を提供できます。
 ルートプレースホルダー上記の各ルーティングメソッドは、現在のHTTPリクエストURIと照合されるURLパターンを受け入れます。ルートパターンは、名前付きプレースホルダーを使用して、HTTPリクエストURIセグメントを動的に照合できます。 フォーマットルートパターンのプレースホルダーは {で始まり、プレースホルダー名が続き、}で終わります。以下は、nameという名前のプレースホルダーの例です。use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; // ... $app->get('/hello/{name}', function (ServerRequestInterface $request, ResponseInterface $response, array $args) { $name = $args['name']; $response->getBody()->write("Hello, $name"); return $response; }); 
 オプションセグメントセクションをオプションにするには、角括弧( [])で囲みます:$app->get('/users[/{id}]', function ($request, $response, array $args) { // responds to both `/users` and `/users/123` // but not to `/users/` return $response; }); ネストする事により、複数のオプションパラメータがサポートされます: $app->get('/news[/{year}[/{month}]]', function ($request, $response, array $args) { // reponds to `/news`, `/news/2016` and `/news/2016/03` // ... return $response; }); オプションパラメータが「無制限」の場合、以下のように行うことができます: $app->get('/news[/{params:.*}]', function ($request, $response, array $args) { // $params is an array of all the optional segments $params = explode('/', $args['params']); // ... return $response; }); 上の例では、URIが /news/2016/03/20の場合、['2016', '03', '20']の3つの要素を含む$params配列になります。
 正規表現マッチングデフォルトでは、プレースホルダーは {}内に記述され、任意の値を受け入れることができます。ただし、プレースホルダーは、特定の正規表現に一致するようにHTTPリクエストURIを要求することもできます。現在のHTTPリクエストURIがプレースホルダーの正規表現と一致しない場合、ルートは呼び出されません。以下は、1つ以上の数字を必要とするidという名前のプレースホルダーの例です。$app->get('/users/{id:[0-9]+}', function ($request, $response, array $args) { // Find user identified by $args['id'] // ... return $response; }); 
 ルート名アプリケーションルートには名前を付けることができます。これは、RouteParser の urlFor()メソッドを使用して特定のルートへのURLをプログラムで生成したい場合に役立ちます。上記の各ルーティングメソッドはSlim\Routeオブジェクトを返し、このオブジェクトはsetName()メソッドを公開します。$app->get('/hello/{name}', function ($request, $response, array $args) { $response->getBody()->write("Hello, " . $args['name']); return $response; })->setName('hello'); この名前付きルートのURLは、アプリケーション RouteParser の urlFor()メソッドを使用して生成できます。$routeParser = $app->getRouteCollector()->getRouteParser(); echo $routeParser->urlFor('hello', ['name' => 'Josh'], ['example' => 'name']); // Outputs "/hello/Josh?example=name" RouteParser の urlFor()メソッドは、次の3つの引数を受け入れます:- $routeNameルート名。ルートの名前は、- $route→setName('name')を介して設定できます。ルートマッピングメソッドは- Routeのインスタンスを返すため、ルートをマッピングした直後に名前を設定できます。例:- $app→get('/', function(){…})→ setName('name')
- $dataルートパターンのプレースホルダーと置換値の連想配列。
- $queryParams生成されたURLに追加されるクエリパラメータの連想配列。
 
 ルートグループルートを論理グループに整理するために、 Slim\Appにはgroup()メソッドも用意されています。各グループのルートパターンは、そのグループに含まれるルートまたはグループの前に付加され、グループパターン内のプレースホルダー引数は、最終的にネストされたルートで使用できるようになります:use Slim\Routing\RouteCollectorProxy; // ... $app->group('/users/{id:[0-9]+}', function (RouteCollectorProxy $group) { $group->map(['GET', 'DELETE', 'PATCH', 'PUT'], '', function ($request, $response, array $args) { // Find, delete, patch or replace user identified by $args['id'] // ... return $response; })->setName('user'); $group->get('/reset-password', function ($request, $response, array $args) { // Route for /users/{id:[0-9]+}/reset-password // Reset the password for user identified by $args['id'] // ... return $response; })->setName('user-password-reset'); }); グループパターンは空にすることができ、共通のパターンを共有しないルートの論理グループ化を有効にします。 use Slim\Routing\RouteCollectorProxy; // ... $app->group('', function (RouteCollectorProxy $group) { $group->get('/billing', function ($request, $response, array $args) { // Route for /billing return $response; }); $group->get('/invoice/{id:[0-9]+}', function ($request, $response, array $args) { // Route for /invoice/{id:[0-9]+} return $response; }); })->add(new GroupMiddleware()); グループクロージャー内で、Slimはクロージャーをコンテナーインスタンスにバインドすることに注意してください。 - ルートクロージャ内で、$thisはPsr\Container\ContainerInterfaceのインスタンスにバインドされます
 
 ルートミドルウェアミドルウェアを任意のルートまたはルートグループにアタッチすることもできます。 use Slim\Routing\RouteCollectorProxy; // ... $app->group('/foo', function (RouteCollectorProxy $group) { $group->get('/bar', function ($request, $response, array $args) { // ... return $response; })->add(new RouteMiddleware()); })->add(new GroupMiddleware()); 
 ルーターキャッシュRouteCollector::setCacheFile()を介してルーターキャッシュを有効にすることができます。以下の例を参照してください:<?php use Slim\Factory\AppFactory; require __DIR__ . '/../vendor/autoload.php'; $app = AppFactory::create(); /** * To generate the route cache data, you need to set the file to one that does not exist in a writable directory. * After the file is generated on first run, only read permissions for the file are required. * * You may need to generate this file in a development environment and comitting it to your project before deploying * if you don't have write permissions for the directory where the cache file resides on the server it is being deployed to */ $routeCollector = $app->getRouteCollector(); $routeCollector->setCacheFile('/path/to/cache.file'); 
 コンテナ―ソリユーションルートに対しては関数を定義することだけに限定されません。Slimでは、ルートのアクション関数を定義するいくつかの異なる方法があります。 関数に加えて、次のものを使用できます: - コンテナ―キー:メソッド
- クラス:メソッド
- __invoke()メソッドを実装するクラス
- コンテナ―キー
 この機能は、Slim の Callable Resolver Class によって有効になります。それは、文字列エントリを関数呼び出しに変換します。例: $app->get('/', '\HomeController:home'); または、PHPの ::class演算子を利用することもできます。これは、IDEのルックアップシステムで適切に機能し、同じ結果を生成します:$app->get('/', \HomeController::class . ':home'); 上記のコードでは、 /ルートを定義し、HomeControllerクラスでhome()メソッドを実行するようにSlimに指示しています。Slimは最初にコンテナ内の HomeControllerのエントリを探します。見つかった場合はそのインスタンスを使用し、そうでない場合はコンテナを最初の引数としてコンストラクタを呼び出します。クラスのインスタンスが作成されると、定義したストラテジーを使用して、指定されたメソッドが呼び出されます。
 Registering a controller with the containerCreate a controller with the homeaction method. The constructor should accept the dependencies that are required. For example:homeアクションメソッドを使用してコントローラーを作成します。コンストラクターは、必要な依存関係を受け入れる必要があります。 例えば:<?php use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Slim\Views\Twig; class HomeController { private $view; public function __construct(Twig $view) { $this->view = $view; } public function home(ServerRequestInterface $request, ResponseInterface $response, array $args): ResponseInterface { // your code here // use $this->view to render the HTML // ... return $response; } } Create a factory in the container that instantiates the controller with the dependencies: 依存関係を持つコントローラーをインスタンス化するファクトリをコンテナーに作成します。 use Psr\Container\ContainerInterface; // ... $container = $app->getContainer(); $container->set('HomeController', function (ContainerInterface $container) { // retrieve the 'view' from the container $view = $container->get('view'); return new HomeController($view); }); This allows you to leverage the container for dependency injection and so you can inject specific dependencies into the controller. これにより、依存関係の注入にコンテナーを活用できるため、特定の依存関係をコントローラーに注入できます。 
 Allow Slim to instantiate the controllerAlternatively, if the class does not have an entry in the container, then Slim will pass the container’s instance to the constructor. You can construct controllers with many actions instead of an invokable class which only handles one action. または、クラスのコンテナにエントリがない場合、Slimはコンテナのインスタンスをコンストラクタに渡します。 1つのアクションのみを処理する呼び出し可能なクラスの代わりに、多くのアクションを持つコントローラーを構築できます。 <?php use Psr\Container\ContainerInterface; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; class HomeController { private $container; // constructor receives container instance public function __construct(ContainerInterface $container) { $this->container = $container; } public function home(ServerRequestInterface $request, ResponseInterface $response, array $args): ResponseInterface { // your code to access items in the container... $this->container->get(''); return $response; } public function contact(ServerRequestInterface $request, ResponseInterface $response, array $args): ResponseInterface { // your code to access items in the container... $this->container->get(''); return $response; } } You can use your controller methods like so. このようにコントローラーメソッドを使用できます。 $app->get('/', \HomeController::class . ':home'); $app->get('/contact', \HomeController::class . ':contact'); 
 Using an invokable classYou do not have to specify a method in your route callable and can just set it to be an invokable class such as: ルート呼び出し可能メソッドでメソッドを指定する必要はなく、次のような呼び出し可能クラスに設定するだけです: <?php use Psr\Container\ContainerInterface; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; class HomeAction { private $container; public function __construct(ContainerInterface $container) { $this->container = $container; } public function __invoke(ServerRequestInterface $request, ResponseInterface $response, array $args): ResponseInterface { // your code to access items in the container... $this->container->get(''); return $response; } } You can use this class like so. このクラスはこのように使用できます。 $app->get('/', \HomeAction::class); Again, as with controllers, if you register the class name with the container, then you can create a factory and inject just the specific dependencies that you require into your action class. 繰り返しますが、コントローラーの場合と同様に、クラス名をコンテナーに登録すると、ファクトリを作成して、必要な特定の依存関係だけをアクションクラスに挿入できます。 
 slim/4/routing.1602319821.txt.gz · 最終更新: 2020/10/10 17:50 by y2sunlight
 
 
 
 





コメント
In this theme web page, you'll see the very best facts, you'll want to watch over that more impressive range of aspect. https://totomusa.com/
Regards intended for publishing a really beneficial document, When i happened onto your web log in addition to understand some write-up 토토사이트
Thank you for sharing with us, I think this website really stands out 토토사이트 추천
Fine points! I produced within your web blog and now have been studying bundled 먹튀검증
It does not take comparable effective in addition to positive shared and discover what specifically a lot of us analyze a lot of us 메이저놀이터
Staff Selection Commission will be releasing the SSC CHSL 2024 notificationhttps://bharatbhoomitimes.com/ssc-chsl/ on 2 April 2024 on the official website.
หากคุณกำลังมองหาสินค้าจากจีนที่ติดเทรนด์ ขายดี ต้นทุนต่ำ กำไรสูง แนะนำ THE ONE CARGO คาร์โก้ ผู้ช่วยมืออาชีพที่จะทำให้ทุกธุรกิจง่ายขึ้น ผู้เชี่ยวชาญการ นำเข้าสินค้าจากจีน โดยตรงเข้าใจ และเข้าถึงทุกความต้องการของธุรกิจ ช่วยคิด วางแผน คุมต้นทุน สร้างผลกำไรสูงสุด สนับสนุนทุกความสำเร็จให้กับธุรกิจของคุณ
Thanks , I have just been looking for information about this topic for ages and yours is the best I have came upon till now. **lsm99 สล็อต**
I really liked your article post. Really looking forward to read more. Great. Say, you got a nice article. Really thank you! Fantastic.I think the restaurant which you told me in the letter is very interesting. I also like to eat out and I usually go to a restaurant for dinner with my family twice a month., The food is delicious so we enjoy it very much. The service is also quick and friendly.
**lsm99 เว็บตรง**
Thank you for another excellent article. Where else could anybody get that kind of information in such an ideal means of writing? I’ve a presentation next week, and I’m at the look for such info [url=https://lsm99dna.net/]lsm99th[/url]
Thank you for another excellent article. I’ve a presentation next week, and I’m at the look for such info lsm99th
Good site you have here.. It’s hard to find high quality writing like yours nowadays. I seriously appreciate individuals like you! Take care!! **รวมโปรสล็อต**
Your insight on this topic is remarkable and refreshing. You've added a new perspective to a well-discussed subject that makes it hard to disagree with your points. Truly excellent work lsm99