我以前在一些其他领域使用过这个服务,但现在我似乎不能让它工作,也不太明白为什么。
我将以下json发布到我的Rails应用程序(使用RestClient 2.4进行测试):
{
"camp":{
"total": 100,
"number": "epw1f6e"
},
"machine":{
"serial_number": "1234567",
"token": "fONxDN"
}
}
Camp控制器:
def create
if is_it_json?
logger.debug params.inspect
machine = Machine.find_by_serial_number(params[:machine][:serial_number])
...
从记录器中,我得到的参数是:{"action"=>"create",“controller”=>“=>”}
json信息在哪里??
我的日志错误:
Started POST "/camps" for 127.0.0.1 at 2012-07-15 00:08:21 +0100
Processing by CampsController#create as JSON
WARNING: Can't verify CSRF token authenticity
{"action"=>"create", "controller"=>"camps"}
Completed 500 Internal Server Error in 2ms
NoMethodError (undefined method `[]' for nil:NilClass):
app/controllers/camps_controller.rb:24:in `create'
我可能做错了什么?
谢谢
发布于 2012-07-15 13:24:05
经过大量的阅读和提问,我找到了解决方案:
参数没有被填充,因为我缺少头(我有接受,但缺少内容类型):
Accept: application/json
Content-type: application/json
添加头部解决了这个问题。
发布于 2012-07-14 23:41:46
无法验证CSRF令牌的真实性{"action"=>"create",“=>”=>“camps”}
在2毫秒内完成500个内部服务器错误
当一个无效的(或不存在的) CSRF令牌与您的json一起发布时,就会抛出这个错误。CSRF需要附加到任何已发布数据的标头。为了进行测试,您可以通过向控制器添加以下内容来禁用CSRF令牌(对于Rails 3):
protect_from_forgery :除了=>:创建
当网站投入生产时,不要把它留在你的控制器中。CSRF令牌可防止CSRF攻击。有关更多详细信息,请参阅Ruby on Rails Security Guide。
如果成功了,请让我知道!
https://stackoverflow.com/questions/11488102
复制相似问题