Slim Framework for PHP v3 を学ぶ (1)
会社のプロジェクトで Slim Framework を使用しているので、それを学びたいと思っています。同社では Slim2 バージョンを使用していますが、現在公式 Web サイトは Slim3 バージョンに達しています。公式ウェブサイトのアドレス: http://www.cnblogs.com/lmenglliren89php/。
まず、公式 Web サイトのチュートリアルに従って、Slim をインストールします。
1.curl -sS https://getcomposer.org/installer sudo php -- --install-dir= /usr/local /bin --filename=composer
2.composer require Slim/slim "^3.0"
このようにして、Slimがインストールされます。 Apache の DirectDocumentroot 設定もあります: AllowOverride All。
同時に、フォルダーの場所を調整するだけで、付属のサンプルを実行することもできます。
フレームワークを理解するにはどうすればよいでしょうか?使いやすいですか?それともそのプロセスを段階的にたどりますか?
私のアイデアはこれです。この例を自分のプロジェクトに変更しましたが、その後、どうすればよいかわかりません時間が来たらさらに深く掘り下げます。このロジックが正しいかどうかはわかりませんので、とりあえず実行します。
プロジェクトのロジック要件は次のとおりです。ページはデータを送信します --->> データをデータベースに保存します ---> > ログを記録 --->>書き込み成功を返す
データを受信するルート:
$app->get('/replace/', function ($request, $response, $args) { Example\Module\Replace::instance()->setBody($request, $response); });
言いたいのは、Slim はすべてのリクエストを異なるルートに転送し、各ルートが機能を完了するという概念に基づいているということです。リクエストが完了したことを設定します。 get メソッドはルートを設定するもので、後続の「replace」はそのクロージャー関数と一致します。 このルートはどこに配置されていますか? APP.php にコンテナーがあります。このコンテナは何ですか? コードを見てみましょう:
<span style="color: #0000ff;">public</span> <span style="color: #0000ff;">function</span> __construct(<span style="color: #800080;">$container</span> =<span style="color: #000000;"> []){ </span><span style="color: #0000ff;">if</span> (<span style="color: #008080;">is_array</span>(<span style="color: #800080;">$container</span><span style="color: #000000;">)) { </span><span style="color: #800080;">$container</span> = <span style="color: #0000ff;">new</span> Container(<span style="color: #800080;">$container</span><span style="color: #000000;">); } </span><span style="color: #0000ff;">if</span> (!<span style="color: #800080;">$container</span><span style="color: #000000;"> instanceof ContainerInterface) { </span><span style="color: #0000ff;">throw</span> <span style="color: #0000ff;">new</span> InvalidArgumentException('Expected a ContainerInterface'<span style="color: #000000;">); } </span><span style="color: #800080;">$this</span>->container = <span style="color: #800080;">$container</span><span style="color: #000000;">;}</span>
public function __construct(array $values = []){ parent::__construct($values); $userSettings = isset($values['settings']) ? $values['settings'] : []; $this->registerDefaultServices($userSettings);}private function registerDefaultServices($userSettings){ $defaultSettings = $this->defaultSettings; /** * This service MUST return an array or an * instance of \ArrayAccess. * * @return array|\ArrayAccess */ $this['settings'] = function () use ($userSettings, $defaultSettings) { return new Collection(array_merge($defaultSettings, $userSettings)); }; if (!isset($this['environment'])) { /** * This service MUST return a shared instance * of \Slim\Interfaces\Http\EnvironmentInterface. * * @return EnvironmentInterface */ $this['environment'] = function () { return new Environment($_SERVER); }; } if (!isset($this['request'])) { /** * PSR-7 Request object * * @param Container $c * * @return ServerRequestInterface */ $this['request'] = function ($c) { return Request::createFromEnvironment($c->get('environment')); }; } if (!isset($this['response'])) { /** * PSR-7 Response object * * @param Container $c * * @return ResponseInterface */ $this['response'] = function ($c) { $headers = new Headers(['Content-Type' => 'text/html; charset=UTF-8']); $response = new Response(200, $headers); return $response->withProtocolVersion($c->get('settings')['httpVersion']); }; } if (!isset($this['router'])) { /** * This service MUST return a SHARED instance * of \Slim\Interfaces\RouterInterface. * * @return RouterInterface */ $this['router'] = function () { return new Router; }; } if (!isset($this['foundHandler'])) { /** * This service MUST return a SHARED instance * of \Slim\Interfaces\InvocationStrategyInterface. * * @return InvocationStrategyInterface */ $this['foundHandler'] = function () { return new RequestResponse; }; } if (!isset($this['errorHandler'])) { /** * This service MUST return a callable * that accepts three arguments: * * 1. Instance of \Psr\Http\Message\ServerRequestInterface * 2. Instance of \Psr\Http\Message\ResponseInterface * 3. Instance of \Exception * * The callable MUST return an instance of * \Psr\Http\Message\ResponseInterface. * * @param Container $c * * @return callable */ $this['errorHandler'] = function ($c) { return new Error($c->get('settings')['displayErrorDetails']); }; } if (!isset($this['notFoundHandler'])) { /** * This service MUST return a callable * that accepts two arguments: * * 1. Instance of \Psr\Http\Message\ServerRequestInterface * 2. Instance of \Psr\Http\Message\ResponseInterface * * The callable MUST return an instance of * \Psr\Http\Message\ResponseInterface. * * @return callable */ $this['notFoundHandler'] = function () { return new NotFound; }; } if (!isset($this['notAllowedHandler'])) { /** * This service MUST return a callable * that accepts three arguments: * * 1. Instance of \Psr\Http\Message\ServerRequestInterface * 2. Instance of \Psr\Http\Message\ResponseInterface * 3. Array of allowed HTTP methods * * The callable MUST return an instance of * \Psr\Http\Message\ResponseInterface. * * @return callable */ $this['notAllowedHandler'] = function () { return new NotAllowed; }; } if (!isset($this['callableResolver'])) { /** * Instance of \Slim\Interfaces\CallableResolverInterface * * @param Container $c * * @return CallableResolverInterface */ $this['callableResolver'] = function ($c) { return new CallableResolver($c); }; }}
<strong> $this['router'] = function () { return new Router; };<br /> <br /> </strong> 只是能不加入自己的Key呢?<strong><br /></strong>