我正在构建一个基于此处的验证系统:
https://github.com/alexanderBendo/Experiments/blob/master/exp0001/mojolicious-auth-session.pl
我遇到的问题是,如果用户输入了错误的用户名或密码,服务器将返回flash消息,就像他们尝试访问页面而未登录一样。它应该显示Invalid Credentials消息。如果我第二次输入错误的凭据,我会收到无效的凭据消息。
以下是相关代码:
sub main {
my $self = shift;
if ( $self->is_user_authenticated ) {
$self->redirect_to('/main/cp');
} else {
$self->flash( message => 'You must log in to view this page' );
$self->render('login');
}
}
sub login {
my $self = shift;
my $user = $self->param('name') || q{};
my $pass = $self->param('pass') || q{};
if ( $self->authenticate( $user, $pass ) ) {
$self->redirect_to('/main/cp');
} else {
$self->flash( message => 'Invalid credentials!' );
$self->render('login');
return;
}
}
模板:
% layout 'default';
% title 'Login';
<h1>Log In</h1>
<% if (my $message = flash 'message' ) { %>
<b><%= $message %></b><br>
<% } %>
<%= form_for login => (method => 'post') => begin %>
Name: <%= text_field 'name' %>
<br>
Password: <%= password_field 'pass' %>
<br>
<%= submit_button 'Login' %>
<% end %>
感谢。
答案 0 :(得分:4)
Flash需要用于在会话中的当前和下一个查询之间保存数据。因此,flash
数据不会立即放在会话中。
因此,您必须redirect_to('login_page')
除render('login_page')
。
如果您不想进行重定向,则必须将数据保存到stash
:
sub main {
my $self = shift;
if ( $self->is_user_authenticated ) {
$self->redirect_to('/main/cp');
} else {
$self->stash( message => 'You must log in to view this page' );
$self->render('login');
}
}
模板:
% layout 'default';
% title 'Login';
<h1>Log In</h1>
<% if (my $message = stash 'message' ) { %>
<b><%= $message %></b><br>
<% } %>