草庐IT

count-post

全部标签

Ruby:net/http 可以同时发起 GET 和 POST 请求吗?

是否可以同时传递GET和POST参数?uri=URI.parse("http://www.example.com/post.php?a=1&b=2")req=Net::HTTP::Post.new(uri.path,{'Referer'=>"http://www.example.com/referer",'User-Agent'=>"Mozilla/4.0(compatible;MSIE7.0;WindowsNT5.1)",'Cookie'=>$cookie})req.set_form_data({'foo'=>'bar','bar'=>'foo'})http=Net::HTTP.ne

ruby-on-rails - Rails API 的 POST 请求为强参数返回 ParameterMissing

找到了一些相关的帖子,但没有一个能帮助我解决我的问题。所以我使用Rails创建了一个简单的产品API:classAPI::V1::ProductsController我正在尝试发送POST请求以使用RESTClient创建产品。当我尝试使用以下内容填写POST请求正文时:{"product"=>{"name":"AcousticGuitar2","category":"Instrument","price":600.0,"release_date":"2012-01-10"}}或{"name":"AcousticGuitar2","category":"Instrument","pri

ruby-on-rails - 尝试编辑时,Rails form_for 结果为 POST 而不是 PUT

我正在使用Rails4并遇到以下错误。RoutingErrorNoroutematches[POST]"/logs/1/meals/13/edit我正在使用:meal传递模型对象的form_for,并且编辑页面正确呈现。但是,Rails似乎并没有检查膳食对象是否已经保存,因此它一直尝试将表单发送到#create操作并尝试发出POST请求,而不是将表单发送到更新操作并进行当我点击提交时一个PUT请求。我如何让form_for识别我正在尝试更新现有对象并且需要PUT而不是POST?其他一切正常,我已经运行了所有迁移。我是Rails的新手,几乎一整天都在尝试自己解决这个问题。请帮忙!请注意,

ruby-on-rails - Rails 中的 Post Redirect Get 模式

如何在Rails中实现PRG?我在Rails中使用了PRG,但我并不完全相信它是正确的。我想知道在Rails中是否有更好的方法来处理它? 最佳答案 我不知道PRG模式有多流行以及为什么人们必须虔诚地坚持它的失败方面的“重定向”(实际上,一个很好的理由是有时你不想处理“设置”的复杂性制造失败并保持干燥)。您基本上需要的是将:user的参数传输到new。我认为上面@Hitesh的解决方案非常接近。classUsersController:newendendend 关于ruby-on-rail

ruby - 在 Jekyll 中过滤 site.related_posts

我对Jekyll和Ruby很陌生(但是,非常兴奋)。在不使用插件的情况下,我试图找到一种方法来过滤site.related_posts。例如,我正在阅读标题为Foo且类别为A、B的帖子。该站点总共包含3个帖子:Foo(类别:A、B)条形图(类别:A、C、D)动物园(类别:B、F)默认情况下,在Jekyll中我们这样做:{%forpostinsite.related_postslimit:5%}{%endfor%}但是,上面的代码返回所有(3)个帖子。一个帖子包含很多类别,所以类别应该是一个数组。如何修改代码并仅返回类别与当前帖子类别相交的类别?(在此示例中,我希望代码仅返回Foo和Zo

ruby-on-rails - 删除 rspec 中的测试 - 更改(模型,:count) failing - Why is reload needed?

TLDR:App.count需要重新加载才能看到创建的记录。为什么?我找到了很多关于测试DELETE方法的引用资料,如下所示:expect{delete_request}.tochange(App,:count).by(-1)这是有道理的,并且适用于一些类似的场景。但是,我在测试不应该执行的删除时遇到了一个问题,例如当没有用户登录时。我从这里开始,用两种方法来测试同一件事:require'rails_helper'RSpec.describeV1::AppsController,type::controllerdolet(:user){create(:user)}let(:app){c

sql - 如何模拟ActiveRecord Model.count.to_sql

我想显示一个计数中使用的SQL。但是,Model.count.to_sql将不起作用,因为count返回一个没有to_sql方法的FixNum。我认为最简单的解决方案是这样做:Model.where(nil).to_sql.sub(/SELECT.*FROM/,"SELECTCOUNT(*)FROM")这会创建与Model.count中使用的SQL相同的SQL,但它是否会导致进一步的问题?例如,如果我添加一个复杂的where子句和一些连接。有更好的方法吗? 最佳答案 你可以试试Model.select("count(*)asmode

ruby-on-rails - 为什么 Array.count 在开发模式下可用但在生产模式下不可用?

对于最近的一个项目,我有几个View是这样的代码:这在开发模式下工作得很好......我将它推出到生产模式并且它爆炸了,说count不是Array的有效方法。我将每个实例都改为使用Array#length,它似​​乎可以正常工作。1)这种行为差异的原因是什么?2)我应该注意开发模式和生产模式之间的任何其他令人兴奋的差异吗?道德:确保您的生产托管环境使用与本地开发环境相同的Ruby版本。:)谢谢汤姆 最佳答案 count方法仅在Ruby1.9及更高版本中可用。我建议您使用与服务器相同版本的Ruby以避免此类问题-1.9中发生了很多变化

ruby - 如何在 Sinatra 代码中发出 POST 请求?

单击表单中的按钮将发送一个POST请求,由以下代码处理。post'/register'do#sendpostrequesttohttp://www.randomsite.com#parseresponse#dosomethingwithit@user=User.first(:name=>params['regUsername'])if@user==nil@user=User.create(:name=>params['regUsername'],:pass=>Password.create(params['regPassword']),:email=>params['regEmail'

ruby-on-rails - rails : Prevent will_paginate from calling #count of ActiveRelation

当我向will_paginate传递一个ActiveRelation时,它总是调用它的#count方法并访问数据库以找出项目的总数。但是这个操作需要时间,而且我已经缓存并准备好了总数。我可以将这个预先计算的计数传递给will_paginate并阻止它访问数据库吗?我尝试了:count选项,但它作为选项传递给了ActiveRecord:active_relation.paginate(page:2,per_page:100,count:total_count)谢谢!:) 最佳答案 通过:total_entries传递缓存计数解决了问题