使用Devise/Rails获取当前用户的UserID

ais*_*q11 8 ruby ruby-on-rails devise

所以我,一个铁杆新手,我正在尝试从当前的Devise会话中获取用户ID,而且我遇到了一些麻烦.

我现在在控制器中有这个:

def index
  @currentUser = current_user.id
end
Run Code Online (Sandbox Code Playgroud)

我想制作一个简单的if语句来显示/隐藏表单中的字段.

<% if @currentUser === @product.user_id %>
          <%= link_to "Back", products_path %>
          <%= link_to "Edit", edit_product_path(@product) %>
          <%= link_to "Delete", product_path(@product), method: :delete, data: { confirm: "Are you sure?"} %>
      <% else %>
          <span></span>
<% end %>
Run Code Online (Sandbox Code Playgroud)

我有一种感觉,我在定义currentUser变量时的语法很糟糕,但我不知道如何解决这个问题.Stack上有一些类似的问题,但没有一个真正适用于我或帮助过我.

提前致谢!

Ken*_*Dev 10

我在这看到一些问题

def index
  @currentUser = current_user.id
end
Run Code Online (Sandbox Code Playgroud)

除了@HolyMoly已经评论过的内容之外,你应该使用下划线而不是camelcase,如果current_user这里是nil,.id则会失败,导致异常.

其次,你通过比较id的值检查"能力",我会改变你的代码来做到这一点

<% if allow_product_delete?(@product) %>
Run Code Online (Sandbox Code Playgroud)

在帮手

def allow_product_delete?(product)
  return false unless current_user
  @product.user_id == current_user.id
end
Run Code Online (Sandbox Code Playgroud)

如果您current_user在控制器和视图中使用了devise ,则不需要将其定义为实例变量,它已经被定义为所有操作的控制器方法(默认情况下).所以通过调用current_user你的观点,你就完成了.

如果用户未登录,current_user则为零,您必须为此做好准备并防范它.

最后,我会研究能力宝石(cancan或cancancan),那些提供了一个非常好的DSL来处理你在这里尝试的东西.