我已经通过10.4.1节完成了示例应用程序教程。我所有的测试都是绿色的。在完成10.4.1之前,一切都按预期工作。但是,在编辑_user.html.erb partial以添加删除链接时,登录功能不起作用。没有识别现有用户的密码。如果我创建新用户,则注册过程有效。然后,我可以使用该新用户的电子邮件和密码注销并登录,但之前创建的帐户无法访问。不知道该怎么做。
_user.html.erb:
<li>
<%= gravatar_for user, size: 50 %>
<%= link_to user.name, user %>
<% if current_user.admin? && !current_user?(user) %>
| <%= link_to 'delete', user, method: :delete,
data: { confirm: 'You sure?' } %>
<% end %>
</li>
users_controller.rb
class UsersController < ApplicationController
before_action :logged_in_user, only: [:index, :edit, :update]
before_action :correct_user, only: [:edit, :update]
def index
@users = User.paginate(page: params[:page])
end
def show
@user = User.find(params[:id])
end
def new
@user = User.new
end
def create
@user = User.new(user_params)
if @user.save
log_in @user
flash[:success] = "Welcome to the Sample App!"
redirect_to @user
else
render 'new'
end
end
def edit
@user= User.find(params[:id])
end
def update
#@user = User.find(params[:id])
if @user.update_attributes(user_params)
#sign_in @user
flash[:success] = "Profile updated"
redirect_to @user
else
render 'edit'
end
end
def destroy
User.find(params[:id]).destroy
flash[:success] = "User destroyed"
redirect_to users_path
end
private
def user_params
params.require(:user).permit(:name, :email, :password, :password_confirmation)
end
# Before filters
# Confirms a logged-in user
def logged_in_user
unless logged_in?
store_location
flash[:danger] = "Please log in."
redirect_to login_url
end
end
# Confirms the correct user.
def correct_user
@user = User.find(params[:id])
redirect_to(root_url) unless current_user?(@user)
end
end
来自rails服务器控制台的错误消息。
答案 0 :(得分:1)
甚至比那更愚蠢。我已经编辑了第一个用户的密码作为练习的一部分,但随后数据库在稍后重置。不得不使用初始默认密码,而不是我更改的密码。此刻感到非常羞怯。
答案 1 :(得分:0)
使用&#34; rails c&#34;在终端中运行rails控制台命令。然后输入u = Users.all 请参阅数据库中有多少现有用户。也许那个你正在谈论的用户并不存在。也许这是您创建该用户时的临时会话。