Rails how to redirect if record is not found

前端 未结 5 1033
时光说笑
时光说笑 2021-02-05 05:42

I am trying to redirect if the record is not found. The page is not redirect and I get the error record not found.

My controller:

def index
@link = Link.         


        
相关标签:
5条回答
  • 2021-02-05 06:22

    error is generated by Link.find - it raises exception if object was not found

    you can simplify your code quite a bit:

    def index
      @link = Link.find_by_id(params[:id])
    
      redirect_to(root_url, :notice => 'Record not found') unless @link
    
      respond_to do |format|
        format.html
      end
    end
    
    0 讨论(0)
  • 2021-02-05 06:25

    Very tricky one ... I found a simple solution for this.... This solution works for me

    @link = Link.where(:id => params[:id]).first

    I am using .first because .where will return an array.Yes, of-course this array has only one element. So, When there is no record with such id, it will return an empty array, assign a blank element to @link ... Now check @link is either blank or not....

    Conclusion: No need to provide exception handling for a simple check It is problem with .find it throws exception when no record exist ... Use .where it will return an empty array

    And Sorry for my Bad English

    0 讨论(0)
  • 2021-02-05 06:30

    You are on the right track, just capture the RecordNotFound exception:

    def index
      @link = Link.find(params[:id])
      # should render index.html.erb by default
    rescue ActiveRecord::RecordNotFound
      redirect_to(root_url, :notice => 'Record not found')
    end
    
    0 讨论(0)
  • 2021-02-05 06:39

    What I've been doing is putting this at the end of the method:

    rescue ActiveRecord::RecordNotFound
      redirect_to root_url, :flash => { :error => "Record not found." }
    

    Even better, put it as an around_filter for your controller:

    around_filter :catch_not_found
    
    private
    
    def catch_not_found
      yield
    rescue ActiveRecord::RecordNotFound
      redirect_to root_url, :flash => { :error => "Record not found." }
    end
    
    0 讨论(0)
  • 2021-02-05 06:41

    I would prefer to use find_by. find_by will find the first record matching the specified conditions. If the record is not found it will return nil, but does not raise exception, so that you can redirect to other page.

    
    def index
      @link = Link.find_by(id: params[:id])
    
      redirect_to(root_url, :notice => 'Record not found') unless @link
    end
    
    0 讨论(0)
提交回复
热议问题