如果验证未通过,则在URL中传递参数,然后使用“新”操作呈现错误

时间:2012-10-15 12:01:57

标签: ruby-on-rails parameters routing render

我遇到了一个问题,我怀疑这个问题并不难解决,只是我缺乏经验使得它变得困难。

我的路线

match '(/:client_id)/signup',   to: 'users#new'

现在,如果客户端发送链接到www.myappurl.com/123/signup,用户将注册,他的用户模型将接收client_id作为参数(我稍后需要)。

控制器:

def new
  @user = User.new
  if signed_in?
    redirect_to root_path
  end
end

def create
  @user = User.new(params[:user])

  if @user.save
    sign_in @user
    flash[:success] = t("users.new.welcome")
    redirect_to @user
  else
    render 'new' #and this is the problem
  end
end

问题是,当用户提交他的应用程序时,他提供的信息没有通过验证,然后呈现“新”操作,但我放弃了这个:client_id参数,因此他与客户之间的关联。

我尝试过redirect_to并传递params。这样可以,但不会显示错误消息。

任何想法如何解决?

修改

在提交无效信息之前

我的调试:

controller: users
action: new
locale: en
client_id: '2'

之后:

!binary "dXRmOA==": ✓
!binary "YXV0aGVudGljaXR5X3Rva2Vu": ldtdjuWAWHB052qY3ASoH1Mv3XYtrdRcL56DgSaYC0Q=
!binary "dXNlcg==": !ruby/hash:ActiveSupport::HashWithIndifferentAccess
!binary "Zmlyc3RfbmFtZQ==": ''
!binary "bGFzdF9uYW1l": ''
!binary "ZW1haWw=": ''
!binary "Y2xpZW50X2lk": '2'
!binary "cGFzc3dvcmQ=": ''
!binary "cGFzc3dvcmRfY29uZmlybWF0aW9u": ''
!binary "Y29tbWl0": Create my account
action: create
controller: users
locale: en

服务器日志

Started POST "/en/users" for 127.0.0.1 at 2012-10-16 07:10:31 +0800
Processing by UsersController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"ldtdjuWAWHB052qY3ASoXYtrdRcL56DgSaYC0Q=", "user"=>{"first_name"=>"", "last_name"=>"", "email"=>"", "client_id"=>"2", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Create my account", "locale"=>"en"}
(0.4ms) BEGIN
User Exists (2.5ms)  SELECT 1 AS one FROM "users" WHERE LOWER("users"."email") = LOWER('') LIMIT 1
(0.1ms)  ROLLBACK
Rendered shared/_error_messages.html.erb (18.6ms)
Rendered users/_fields_for_registration_no_verification.html.erb (36.9ms)
Rendered users/_password_fields.html.erb (3.6ms)
Rendered users/new.html.erb within layouts/application (77.5ms)
Rendered layouts/_shim.html.erb (0.0ms)
Rendered layouts/_google_tracking_code (0.0ms)
User Load (2.4ms)  SELECT "users".* FROM "users" WHERE "users"."remember_token" IS NULL  LIMIT 1
Rendered layouts/_header.html.erb (8.7ms)
Rendered layouts/_footer.html.erb (1.5ms)
Completed 200 OK in 437ms (Views: 213.4ms | ActiveRecord: 14.9ms)

修改

我找到了问题的真正来源(与下面的答案不同)。问题是,当我在我的表单中使用隐藏字段时,我使用以下代码:

<%= f.hidden_field :client_id, { :value => params[:client_id]} %>

事实证明,一旦我删除{ :value => params[:client_id]}部分,一切都在注册失败后开始按预期工作。从来没有感谢你的帮助。

1 个答案:

答案 0 :(得分:2)

这是因为当验证失败并呈现新内容时,:cliend_id对象中的@user将丢失。

def new
  if params[:client_id]
    @user = User.new(:client_id => params[:client_id])
  else
    @user = User.new
  end 
  if signed_in?
    redirect_to root_path
  end
end

users/new.html.haml视图中,请确保您拥有:client_id的隐藏字段。

=form_for @user do |u|
  =f.hidden_field :client_id  #This will prevent your client_id from getting lost when validation fails.

更清洁的方法是将before_filter用于您的新操作。希望你明白这一点。