Mac*_*imm 6 post get ruby-on-rails http heroku
我有奇怪的情况.我有一个RoR应用程序,它提供了我从Java应用程序连接的REST API.
我正在本地开发RoR,并在Heroku环境中部署它.
无论如何(我尝试从Java APP,Mozilla REST客户端等)我尝试发送应该由api控制器中的create action处理的POST HTTP请求.在localhost上 - 一切都按预期工作.在Heroku生产环境中 - POST请求被视为正常的GET.
以下是此资源的路线:
api_v1_items GET /api/v1/items(.:format) api/v1/items#index {:format=>:json}
POST /api/v1/items(.:format) api/v1/items#create {:format=>:json}
api_v1_item GET /api/v1/items/:id(.:format) api/v1/items#show {:format=>:json}
PATCH /api/v1/items/:id(.:format) api/v1/items#update {:format=>:json}
PUT /api/v1/items/:id(.:format) api/v1/items#update {:format=>:json}
DELETE /api/v1/items/:id(.:format) api/v1/items#destroy {:format=>:json}
Run Code Online (Sandbox Code Playgroud)
所以我正在尝试POST请求/api/v1/items传递所有必要的参数.
在localhost中,响应是正确的:
Started POST "/api/v1/items?token=l4XOHrhDApPqTp1u4TxBjQ" for 127.0.0.1 at 2014-05-15 22:11:49 +0200
Processing by Api::V1::ItemsController#create as JSON
Parameters: {"height"=>10.0, "item_name"=>"Super item", "width"=>20.0, etc...
Run Code Online (Sandbox Code Playgroud)
然而,同样的请求在Heroku被解雇为GET:
2014-05-15T20:27:58.137541+00:00 app[web.1]: Started GET "/api/v1/items?token=iEdDkDLiDUlWi0mDbr6XYw" for 89.74.57.51 at 2014-05-15 20:27:58 +0000
2014-05-15T20:27:58.223620+00:00 app[web.1]: Processing by Api::V1::ItemsController#index as JSON
Run Code Online (Sandbox Code Playgroud)
任何的想法?当然两个回购都是同步的.检查几次.
这真的很奇怪......也许某种Heroku缓存魔法?
HTTP/1.1 301永久移动
301重定向不是Heroku魔法.您的DNS(或可能是您的应用)可能会将所有顶级请求(mydomain.com)转发到www子域.
使用子域是首选:
由于一个容易被忽视的错误,我在不使用自定义域时遇到了类似的错误:我使用的是 heroku.com 而不是 heroku app .com
错误:http : //my-app.heroku.com
右:http : //my-app.herokuapp.com
我怀疑它的原因与Catsby's answer 中提到的问题非常相似。
| 归档时间: |
|
| 查看次数: |
1902 次 |
| 最近记录: |