我一定是做错了。我有一个简单的搜索,在开发中使用(使用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
答案 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'。编码是否在您的页面上正确设置?