设计如何将当前用户关联到帖子?

Max*_*Max 14 ruby-on-rails devise ruby-on-rails-3

如何将我登录的当前用户与我在创建时的帖子相关联?

我的帖子模型:

before_create :owner
belongs_to :user
def owner
    self.user_id = current_user.id
end
Run Code Online (Sandbox Code Playgroud)

但是,因为我不能在模型中使用方法current_user,所以这种方法有效.

这是我的控制器:

class PostsController < ApplicationController
before_filter :authenticate_user!

  # GET /posts
  # GET /posts.xml
  def index
    @posts = Post.all

    respond_to do |format|
      format.html # index.html.erb
      format.xml  { render :xml => @posts }
    end
  end

  # GET /posts/1
  # GET /posts/1.xml
  def show
    @post = Post.find(params[:id])

    respond_to do |format|
      format.html # show.html.erb
      format.xml  { render :xml => @post }
    end
  end

  # GET /posts/new
  # GET /posts/new.xml
  def new
    @post = Post.new

    respond_to do |format|
      format.html # new.html.erb
      format.xml  { render :xml => @post }
    end
  end

  # GET /posts/1/edit
  def edit
    @post = Post.find(params[:id])
  end

  # POST /posts
  # POST /posts.xml
  def create
    @post = Post.new(params[:post])

    respond_to do |format|
      if @post.save
        format.html { redirect_to(@post, :notice => 'Post was successfully created.') }
        format.xml  { render :xml => @post, :status => :created, :location => @post }
      else
        format.html { render :action => "new" }
        format.xml  { render :xml => @post.errors, :status => :unprocessable_entity }
      end
    end
  end

  # PUT /posts/1
  # PUT /posts/1.xml
  def update
    @post = Post.find(params[:id])

    respond_to do |format|
      if @post.update_attributes(params[:post])
        format.html { redirect_to(@post, :notice => 'Post was successfully updated.') }
        format.xml  { head :ok }
      else
        format.html { render :action => "edit" }
        format.xml  { render :xml => @post.errors, :status => :unprocessable_entity }
      end
    end
  end

  # DELETE /posts/1
  # DELETE /posts/1.xml
  def destroy
    @post = Post.find(params[:id])
    @post.destroy

    respond_to do |format|
      format.html { redirect_to(posts_url) }
      format.xml  { head :ok }
    end
  end
end
Run Code Online (Sandbox Code Playgroud)

我如何建立关联?因此,post user_id coloumn被赋予current_user.id

Ser*_*nin 32

@post.user = current_user
Run Code Online (Sandbox Code Playgroud)

在您的创建操作中.

或者如果你has_many :postsUser模型上有关联:

@post = current_user.posts.new(params[:post])

if @post.save
  ...
Run Code Online (Sandbox Code Playgroud)

  • 当你通过hidde_field以表格形式进行,然后在控制器中安全 (3认同)

Pet*_*ong 22

我建议您通过用户创建帖子:

# in create
@post = current_user.posts.build(params[:post])
Run Code Online (Sandbox Code Playgroud)

这会自动user_id为你填写.

  • 无论哪种方式都很好.但是你的`show`,`edit`,`update`和`destory`方法有一点.以您当前的方式,用户A可以查看,更新或删除用户B的帖子.所以通常最好使用范围方法来检索帖子,即`show`中的`@post = current_user.posts.find(params [:id])`.当然,如果你真的希望其他用户更新彼此的帖子,你的方式很好 (3认同)