我做错了什么。
我什么都没改变,但现在是2011年,这个电话不像以前那样有效。
使用Active Resource,我可以进行以下调用:
>> Member.find(:all, :params => {:code => "1stb48024957856464d436e79ad9d7bc0c2d46d5a02"}) GET http://localhost:3000/members.xml?code=1stb48024957856464d436e79ad9d7bc0c2d46d5a02 --> 500 Internal Server Error (1601 371ms) ActiveResource::ServerError: Failed with 500 Internal Server Error
如您所见,我收到500错误。所以我去我的服务器,我正在打电话。
代码在控制器中:
def index
@store = Store.first
@members = @store.members.find_by_code(params[:code])
respond_to do |format|
format.html # index.html.erb
format.xml { render @members.to_xml } # i also tried :xml => @members but that screws up too the same way.
end
end
但下面是堆栈跟踪。它正在解释为什么这只是停止工作。
Started GET "/members.xml?code=1stb48024957856464d436e79ad9d7bc0c2d46d5a02" for 127.0.0.1 at 2011-01-21 13:58:00 -0500
Processing by MembersController#index as XML
Parameters: {"code"=>"1stb48024957856464d436e79ad9d7bc0c2d46d5a02"}
SQL (0.8ms) SHOW TABLES
Store Load (0.4ms) SELECT `stores`.* FROM `stores` LIMIT 1
Member Load (0.8ms) SELECT `members`.* FROM `members` WHERE (`members`.store_id = 1) AND (`members`.`code` = '1stb48024957856464d436e79ad9d7bc0c2d46d5a02') LIMIT 1
Completed in 268ms
ActionView::MissingTemplate (Missing template
4
1stb48024957856464d436e79ad9d7bc0c2d46d5a02
2010-12-02T20:14:54Z
3
70.2
10
http://fnd.nu/7
1
2010-12-09T15:37:42Z
with {:handlers=>[:erb, :rjs, :builder, :rhtml, :rxml], :formats=>[:xml], :locale=>[:en, :en]} in view paths "/Users/nerb/current_project/fund/app/views", "/Users/nerb/.rvm/gems/ruby-1.9.2-p0/gems/devise-1.1.3/app/views", "/Users/nerb/current_project/fund", "/"):
app/controllers/members_controller.rb:16:in `block (2 levels) in index'
app/controllers/members_controller.rb:14:in `index'
Rendered /Users/nerb/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.1/lib/action_dispatch/middleware/templates/rescues/missing_template.erb within rescues/layout (31.6ms)
任何想法都表示赞赏。我以为xml格式是免于渲染?何塞在lighthouse ticket中说了很多,但我找不到他在说什么。
更新:
作为服务器工作的Andy似乎正在发送200,所以谢谢,但现在我收到了这个错误:
Member.find(:all, :params => {:code => "1stb48024957856464d436e79ad9d7bc0c2d46d5a02"}) GET http://localhost:3000/members.xml?code=1stb48024957856464d436e79ad9d7bc0c2d46d5a02 --> 200 OK (472 399ms) NoMethodError: undefined method `collect!' for # from /Users/nerb/.rvm/gems/ruby-1.8.7-p249/gems/activeresource-2.3.5/lib/active_resource/base.rb:662:in `instantiate_collection' from /Users/nerb/.rvm/gems/ruby-1.8.7-p249/gems/activeresource-2.3.5/lib/active_resource/base.rb:639:in `find_every' from /Users/nerb/.rvm/gems/ruby-1.8.7-p249/gems/activeresource-2.3.5/lib/active_resource/base.rb:582:in `find' from (irb):1
思考?它应该只是一个阵列回来,即使它是一个记录?
答案 0 :(得分:1)
render :xml => @members
是要走的路。
确保在生产中进行此更改后重新加载/重新启动服务器。