我正在使用 Ruby 2 在 Rails 4 中重写我的 Rails 应用程序之一。我最初的应用程序使用的是 Michael Hartl 的 Ruby on Rails 教程的 3.2 版本。我正在将我的应用程序的 3.2 版本复制到我的新 Rails 4 版本。似乎 current_user 设置不正确。每个使用 current_user 的路由都会因缺少 id 和语言环境而中止,即使记录被正确访问并且用户已登录并且语言环境已设置。在不包括使用 current_user 的路线的登录页面上,我可以更改语言环境并为所选语言环境显示正确的文本和图像。不幸的是,主站点的标题部分包含一个 edit_user_path(current_user) 引用,这意味着我无法在我的网站上显示任何页面,除了登录页面和与用户无关的网站的另一个部分。
这是我尝试显示显示操作时的示例。每当我尝试访问引用 current_user 的路由时,都会遇到类似的错误。
No route matches {:controller=>"users", :action=>"show", :locale=>#<User id: 3, first_name: "first_name", last_name: "last_name", username: "username", email: "myemail@company.com", password_digest: "$2a$10$y73jlk0hQYKLClmXQI5iHe/fqXO66hJD3muWjDg5ziCD...", city: "MyCity", state_id: 3521, country_id: 233, remember_token: "8cce0e523a879e179dd5b23df04acc8d1cf3108e", password_reset_token: "nU1FbWD2nuXx23jnOmOkAQ", password_reset_sent_at: "2013-10-20 22:36:44", bio: "Here is my bio info...", active_user: "3", age_group: "3", gender: "F", admin: true, visible: true, created_at: "2012-08-28 19:43:27", updated_at: "2013-10-21 22:36:43", state_province: "MyState", broadcaster: true, language_id: 1, admin_localize: false, sos_student: false, send_newsletter: false, special_newsletter: true, temp_broadcaster: false, media_creator_id: 46, bad_email: false, banned: false, notify_resp_me: true, saved_micropost_id: 1, saved_topic_id: 56, saved_discussion_id: 1, notify_reply_me: true, on_profile_page: false, notify_new_disc: true>, :id=>nil, :format=>nil} missing required keys: [:locale, :id]
看来 current_user 为零。我认为我的 remember_token 逻辑可能是罪魁祸首。在过去的几个小时里,我查看了 session_helper.rb,但无法弄清楚我做错了什么。
这是我的 session_helper.rb 代码。注意:在我的 login(user) 方法中,我允许用户决定是要永久保存 cookie 还是仅将其用于会话。本教程创建了一个永久 cookie,用户必须注销才能删除 cookie。
def current_user
remember_token = User.encrypt(cookies[:remember_token])
@current_user ||= User.find_by(remember_token: remember_token)
end
def current_user?(user)
user == current_user
end
def login(user)
remember_token = User.new_token
if params[:remember_me]
cookies.permanent[:remember_token] = remember_token
else
cookies[:remember_token] = remember_token
end
user.update_attribute(:remember_token, User.encrypt(remember_token))
self.current_user = user
end
def logged_in?
!current_user.nil?
end
def logged_in_user
unless logged_in?
store_location
redirect_to login_path, notice: "#{t :must_login}"
end
end
def logout
self.current_user = nil
cookies.delete(:remember_token)
flash[:success] = "#{t :logout}"
end
def current_user=(user)
@current_user = user
end
def redirect_back_or(default)
redirect_to(session[:return_to] || default)
session.delete(:return_to)
end
def store_location
session[:return_to] = request.url if request.get?
end
这是我的 session_controller.rb 逻辑。注意:我允许人们使用电子邮件地址或用户名登录。逻辑基于教程。但是我显示另一个路径而不是重定向到@user。这种差异不会改变最终结果。
def create
user = User.find_by_email(params[:session][:email_user])
if user && user.authenticate(params[:session][:password])
if user.active_user == "1"
flash[:error] = "#{t :flash_sessions_error1}"
else
flash[:success] = "#{t :flash_sessions_success}"
login user
end
redirect_back_or home_path
else
user = User.find_by_username(params[:session][:email_user])
if user && user.authenticate(params[:session][:password])
if user.active_user == "1"
flash[:error] = "#{t :flash_sessions_error1}"
else
flash[:success] = "#{t :flash_sessions_success}"
login user
end
redirect_back_or home_path
else
flash.now[:error] = "#{t :flash_sessions_error2}"
render "new"
end
end
end
这是我在 user.rb 中的代码。
before_create :create_remember_token
def User.encrypt(token)
Digest::SHA1.hexdigest(token.to_s)
end
def User.new_token
SecureRandom.urlsafe_base64
end
private
def create_remember_token
self.remember_token = User.encrypt(User.new_token)
end
这是我在 users_controller.rb 中的显示操作。
def show
@user = User.find(params[:id])
@microposts = @user.microposts.order("created_at DESC").first(20)
@discussions = @user.discussions.order("created_at DESC").first(20)
end
这是我为用户提供的所有路由的 rake 路由输出:
following_user GET /:locale/users/:id/following(.:format) users#following {:locale=>/en|es|fr|pt/}
followers_user GET /:locale/users/:id/followers(.:format) users#followers {:locale=>/en|es|fr|pt/}
users GET /:locale/users(.:format) users#index {:locale=>/en|es|fr|pt/}
POST /:locale/users(.:format) users#create {:locale=>/en|es|fr|pt/}
new_user GET /:locale/users/new(.:format) users#new {:locale=>/en|es|fr|pt/}
edit_user GET /:locale/users/:id/edit(.:format) users#edit {:locale=>/en|es|fr|pt/}
user GET /:locale/users/:id(.:format) users#show {:locale=>/en|es|fr|pt/}
PATCH /:locale/users/:id(.:format) users#update {:locale=>/en|es|fr|pt/}
PUT /:locale/users/:id(.:format) users#update {:locale=>/en|es|fr|pt/}
DELETE /:locale/users/:id(.:format) users#destroy {:locale=>/en|es|fr|pt/}
我会继续关注这个,但现在我没有看到我做错了什么。
任何帮助,将不胜感激。