【发布时间】:2015-08-18 11:31:04
【问题描述】:
我正在开发一个需要同时具有网站和 api 的应用程序,并且我正在为此实施通用的 Devise 身份验证。为了实现这个要求,我重写了设计注册控制器来响应 html 和 json。对于 json 我希望控制器返回用户数据并且我能够实现这一点,但对于 html 我想使用登录和重定向到根路径的原始设计行为。
注册控制器的代码是:
class RegistrationsController < Devise::RegistrationsController
def create
@user = User.create(user_params)
respond_to do |format|
format.html {
@user.save ? (super) : (render :new)
}
format.json {
@user.save ? (render :json => {:state => {:code => 0}, :data => @user }) :
(render :json => {:state => {:code => 1, :messages => @user.errors.full_messages} })
}
end
end
private
def user_params
params.require(:user).permit(:email, :password)
end
end
使用这个控制器我得到一个验证错误电子邮件已经被接受但是当我检查我的日志时它显示用户已经创建。
谁能告诉我我在做什么错误?我只是希望我的控制器在 html 请求的情况下回退到原始设计功能。
【问题讨论】:
-
请分享您的型号代码。
-
加你为合作者请查收
标签: ruby-on-rails devise