メインメニュー
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セグメントを動的に照合できます。 FormatA route pattern placeholder starts with a {, followed by the placeholder name, ending with a}. This is an example placeholder namedname:ルート(route)パターンのプレースホルダーは {で始まり、プレースホルダー名が続き、}で終わります。 これは、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; }); 
 Optional segmentsTo make a section optional, simply wrap in square brackets: セクションをオプションにするには、角かっこで囲みます: $app->get('/users[/{id}]', function ($request, $response, array $args) { // responds to both `/users` and `/users/123` // but not to `/users/` return $response; }); Multiple optional parameters are supported by nesting: ネストにより、複数のオプションパラメータがサポートされます: $app->get('/news[/{year}[/{month}]]', function ($request, $response, array $args) { // reponds to `/news`, `/news/2016` and `/news/2016/03` // ... return $response; }); For “Unlimited” optional parameters, you can do this: 「無制限」のオプションパラメータの場合、これを行うことができます: $app->get('/news[/{params:.*}]', function ($request, $response, array $args) { // $params is an array of all the optional segments $params = explode('/', $args['params']); // ... return $response; }); In this example, a URI of /news/2016/03/20would result in the$paramsarray containing three elements:['2016', '03', '20'].この例では、URIが /news/2016/03/20の場合、['2016', '03', '20']の3つの要素を含む$params配列になります。
 Regular expression matchingBy default the placeholders are written inside {}and can accept any values. However, placeholders can also require the HTTP request URI to match a particular regular expression. If the current HTTP request URI does not match a placeholder regular expression, the route is not invoked. This is an example placeholder namedidthat requires one or more digits.デフォルトでは、プレースホルダーは {}内に記述され、任意の値を受け入れることができます。ただし、プレースホルダーは、特定の正規表現に一致するように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; }); 
 Route namesApplication routes can be assigned a name. This is useful if you want to programmatically generate a URL to a specific route with the RouteParser’s urlFor()method. Each routing method described above returns aSlim\Routeobject, and this object exposes asetName()method.アプリケーションルートには名前を付けることができます。これは、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'); You can generate a URL for this named route with the application RouteParser’s urlFor() method. この名前付きルートのURLは、アプリケーション RouteParser の urlFor()メソッドを使用して生成できます。$routeParser = $app->getRouteCollector()->getRouteParser(); echo $routeParser->urlFor('hello', ['name' => 'Josh'], ['example' => 'name']); // Outputs "/hello/Josh?example=name" The RouteParser’s urlFor() method accepts three arguments: RouteParser の urlFor()メソッドは、次の3つの引数を受け入れます。- $routeName The route name. A route’s name can be set via $route→setName('name'). Route mapping methods return an instance of Route so you can set the name directly after mapping the route. e.g.: $app→get('/', function () {…})→setName('name')
- $data Associative array of route pattern placeholders and replacement values.
- $queryParams Associative array of query parameters to be appended to the generated url.
 - $routeNameルート名。ルートの名前は、- $route→setName('name')を介して設定できます。ルートマッピングメソッドは- Routeのインスタンスを返すため、ルートをマッピングした直後に名前を設定できます。例:- $app→get('/', function(){…})→ setName('name')
- $dataルートパターンプレースホルダーと置換値の連想配列。
- $queryParams生成されたURLに追加されるクエリパラメータの連想配列。
 
 Route groupsTo help organize routes into logical groups, the Slim\Appalso provides agroup()method. Each group’s route pattern is prepended to the routes or groups contained within it, and any placeholder arguments in the group pattern are ultimately made available to the nested routes:ルートを論理グループに整理するために、 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'); }); The group pattern can be empty, enabling the logical grouping of routes that do not share a common pattern. グループパターンは空にすることができ、共通のパターンを共有しないルートの論理グループ化を有効にします。 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()); Note inside the group closure, Slim binds the closure to the container instance. グループクロージャー内で、Slimはクロージャーをコンテナーインスタンスにバインドすることに注意してください。 - inside route closure,$thisis bound to the instance ofPsr\Container\ContainerInterface
 - ルートクロージャ内で、$thisはPsr\Container\ContainerInterfaceのインスタンスにバインドされます
 
 Route middlewareYou can also attach middleware to any route or route group. ミドルウェアを任意のルートまたはルートグループにアタッチすることもできます。 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()); 
 Route expressions cachingIt’s possible to enable router cache via RouteCollector::setCacheFile(). See examples below: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'); 
 Container ResolutionYou are not limited to defining a function for your routes. In Slim there are a few different ways to define your route action functions. ルートの関数を定義することに限定されません。Slimでは、ルートアクション関数を定義するいくつかの異なる方法があります。 In addition to a function, you may use: 関数に加えて、次のものを使用できます: - container_key:method
- Class:method
- Class implementing__invoke()method
- container_key
 - container_key:method
- クラス:メソッド
- __invoke()メソッドを実装するクラス
- container_key
 This functionality is enabled by Slim’s Callable Resolver Class. It translates a string entry into a function call. Example: この機能は、Slim の Callable Resolver Class によって有効になります。文字列エントリを関数呼び出しに変換します。例: $app->get('/', '\HomeController:home'); Alternatively, you can take advantage of PHP’s ::classoperator which works well with IDE lookup systems and produces the same result:または、PHPの ::class演算子を利用することもできます。これは、IDEルックアップシステムで適切に機能し、同じ結果を生成します。$app->get('/', \HomeController::class . ':home'); In this code above we are defining a /route and telling Slim to execute thehome()method on theHomeControllerclass.上記のコードでは、 /ルートを定義し、HomeControllerクラスでhome()メソッドを実行するようにSlimに指示しています。Slim first looks for an entry of HomeControllerin the container, if it’s found it will use that instance otherwise it will call it’s constructor with the container as the first argument. Once an instance of the class is created it will then call the specified method using whatever Strategy you have defined.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.1602243281.txt.gz · 最終更新: 2020/10/09 20:34 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