expires()
またはに与える有効期限の値に関係なくexpires_delta()
、Cookie の有効期限は常に 1 時間です。セッションと Cookie の有効期限が一致するように変更するにはどうすればよいですか?
質問する
542 次
1 に答える
3
私は vti の作品が好きですが、そのディストリビューションは時代遅れに見え、過去に置き換えられました。今日、セッションの有効期限を設定する標準的な方法はMojolicious::Sessionsで説明されています:
default_expiration
my $time = $sessions->default_expiration; $sessions = $sessions->default_expiration(3600);
セッションが期限切れになるまでのデフォルトの時間 (秒単位) 。デフォルトは
3600
です。有効期限のタイムアウトは、リクエストごとに更新されます。値を 0 に設定すると、ブラウザ ウィンドウが閉じられるまでセッションが持続されますが、これにはセキュリティ上の影響があります。さらに制御するには、expiration
とexpires
セッションの値を使用することもできます。# Expiration date in epoch seconds from now (persists between requests) $c->session(expiration => 604800); # Expiration date as absolute epoch time (only valid for one request) $c->session(expires => time + 604800); # Delete whole session by setting an expiration date in the past $c->session(expires => 1);
動作することを確認するために、小さなテスト スクリプトを作成しました。
#!/usr/bin/env perl
use Mojolicious::Lite;
use Time::Local 'timegm';
# set some session variable
get '/test' => sub {
my $self = shift;
$self->session(
expires => timegm(0, 0, 0, 4, 4, 142), # star wars day '42
foo => 42,
);
$self->render_text('foo is set');
};
use Test::More;
use Test::Mojo;
use Mojo::Cookie::Response;
my $t = Test::Mojo->new;
$t->get_ok('/test')->status_is(200)->content_is('foo is set');
my $cookies = Mojo::Cookie::Response->parse($t->tx->res->headers->set_cookie);
is $cookies->[0]->expires, 'Sun, 04 May 2042 00:00:00 GMT', 'right expire time';
done_testing;
出力:
ok 1 - get /test
ok 2 - 200 OK
ok 3 - exact match for content
ok 4 - right expire time
1..4
于 2012-12-14T00:02:07.693 に答える