Rails 3 Metasearch问题,但仅限于生产

时间:2011-05-26 19:32:31

标签: ruby-on-rails ruby-on-rails-3

我一定是做错了。我有一个简单的搜索,在开发中使用(使用sqlite3 DB)但在生产中没有(使用MYSQL DB)。不知道如何调试。

以下是详细信息:

控制器:

def index
  @search = Individual.search(params[:search])
  @individuals = @search.all
  # @individuals = @search.order(:lastname).page params[:page]
end

查看:

= form_for @search, :url => individuals_path, :html => {:method => :get} do |f|
  %fieldset
    %strong
      = f.label :firstname_like, "First Name?"
    = f.text_field :firstname_like
    %strong
      = f.label :lastname_like, "Last Name?"
    = f.text_field :lastname_like
    = f.submit "Search"

在生产环境中使用控制台没有问题:

Individual.search :lastname_like => 'Smith', :firstname_like => ''
=> #<MetaSearch::Searches::Individual:0blahblah....

只是无法通过浏览器工作。我得到每个人回来了。 (没有错误)

我想知道这是否与URL编码有关?

Started GET "/individuals/?utf8=%25E2%259C%2593&search%255Bfirstname_like%255D=& search%255Blastname_like%255D=hermans&commit=Search" for 68.87.23.92 at Thu May 26 09:22:31 -0700 2011
  Processing by IndividualsController#index as HTML
  Parameters: {"commit"=>"Search", "search%5Bfirstname_like%5D"=>"", "utf8"=>"%E2%9C%93", "search%5Blastname_like%5D"=>"smith"}

有什么想法吗?或者至少如何调试?

Rails 3.0.7 Metasearch 1.0.3

2 个答案:

答案 0 :(得分:0)

如果您在控制台上获得输出,那么您的功能正常运行。要在每一步调试尝试记录信息并查看它出错的地方,例如打印传递给搜索功能的参数,搜索返回的输出等等,看看事情哪里好奇。您还可以查看在production.log中触发的db查询,并尝试从终端手动运行它并查看结果。

您甚至可以尝试在生产服务器上以开发模式运行应用程序,更改database.yml以使用生产db和mysql来查看它是否是特定于环境的问题。

答案 1 :(得分:0)

是的,我会说这是网址的内容。据我所知,它应该是这样的:

/individuals/?utf8=%E2%9C%93&search%5Bfirstname_like%5D=&search%5Blastname_like%5D=hermans&commit=Search

我不使用haml,所以我不能说发生了什么,但是你的表单有问题。它在每个编码字符中添加了'25'。编码是否在您的页面上正确设置?