ファルコン-クッキー管理
としても知られているクッキー browser cookiesブラウザに保存されている小さなテキストファイルです。ユーザーIDに関連するすべての情報を保存します。この情報は、ユーザーがさまざまなページを閲覧したときにユーザーを検証するために使用されます。
クッキーには2つの異なるタイプがあります-
Session Cookies−これらのタイプのCookieはブラウザに残り、ブラウザが閉じられるまで情報を保持します。ブラウザを開くとすぐに、同じユーザーの新しいセッションとして扱われます。
Persistent Cookies−規定の有効期間が含まれ、指定された有効期間内にブラウザに残ります。永続的なCookieを使用するWebサイトは、ユーザーがブラウザーを閉じている場合でも、すべてのユーザーを追跡します。
ここで、PhalconでCookieがどのように機能するかについて説明します。
ファルコンのクッキー
ファルコンは Phalcon\Http\Response\Cookiesクッキーのグローバルストレージとして。サーバーにリクエストを送信している間、CookieはPhalconに保存されます。
以下は、Cookieを設定するための構文です-
$this->cookies->set(
"<cookie-name>",
"<cookie-value>",
time
);
次の例を考えてみましょう。次のコードを使用して、ユーザーがWebアプリケーションにログインしたときにユーザーのCookieを作成します。
<?php
class UsersController extends \Phalcon\Mvc\Controller {
public function indexAction() {
if ($this->cookies->has("login-action")) {
// Get the cookie
$loginCookie = $this->cookies->get("login-action");
// Get the cookie's value
$value = $loginCookie->getValue();
echo($value);
}
$this->cookies->set(
"login-action",
"abc",
time() + 15 * 86400
);
}
}
暗号化されたCookieが出力として表示されます。
説明
名前の付いたクッキー “loginAction” 価値を持って作成されました “abc”。
メソッド “indexAction” Cookieが存在するかどうかを確認し、それに応じて値を出力します。
クッキーの暗号化
PhalconのCookieは、リクエストとしてサーバーに送信される前に暗号化され、サーバーから適切な応答を受け取るとすぐに復号化されます。これにより、許可されたユーザーのセキュリティが保証されます。
暗号化と復号化の機能にもかかわらず、機密データをCookieに保存しないことを常にお勧めします。Cookieの暗号化の構成はに含まれていますservices.php ファイル。
/**
* Enable encryption key for setting values of cookies
*/
$di->set(
"cookies", function () {
$cookies = new Cookies();
$cookies->useEncryption(false);
return $cookies;
}
);
/**
* Set encryption key
*/
$di->set(
"crypt", function () {
$crypt = new Crypt();
$crypt->setKey('AED@!sft56$'); // Use a unique Key!
return $crypt;
}
);
Note −
サーバーにCookieを送信するときは、暗号化を使用することを常にお勧めします。
暗号化を使用しない場合、すべての内部アプリケーションが攻撃者にさらされます。
小さなデータとリテラルをCookieに保存することもお勧めします。