草庐IT

ios - 网络请求被保存在内存中?

全部标签

ruby-on-rails - 通过 Ruby 的 HTTP post 请求

我是ruby​​的新手,正在尝试一些基本的东西。当我使用以下命令向服务器发送HTTP请求时:curl-v-H"Content-Type:application/json"-XGET-d"{"myrequest":"myTest","reqid":"44","data":{"name":"test"}}"localhost:8099我的服务器将JSON数据视为"{myrequest:myTest,reqid:44,data:{name:test}}"但是当我使用以下ruby​​代码发送请求时:require'net/http'@host='localhost'@port='8099'@p

ruby-on-rails - Rails 上的 Pubsubhubbub。如何从 POST 请求中提取原始 POST 正文内容?

我在使用Rails设置支持pubsub的订阅者应用程序时遇到问题。我目前已经订阅了开放式集线器pubsubhubbub.appspot.com,并且正在接收到我的应用程序端点的ping。(截至目前,我已经创建了一个计数器,每次对端点执行ping操作时该计数器都会递增)。但我无法理解如何从POST中提取原始POST正文内容。我是pubsub的新手,很想尝试一下。我看到了这篇博文,但它不是特定于语言的。资料来源:JosephSmarr:实现PubSubHubbub订户支持:分步指南。http://josephsmarr.com/2010/03/01/implementing-pubsubh

ruby - 有没有人想出一种方法来在多个浏览器/网络驱动程序上运行相同的 cucumber 场景?

我正在使用Cucumber+capybara进行一些网络自动化测试。我希望能够连接我自己的标签(类似于场景之前的@all_browsers)并让它针对我设置的网络驱动程序列表运行(celerity,firefox上的selenium,ie和chrome)。我不想在前面用4个不同的标签写4次不同的场景。我已经研究过尝试使用我通过以下方式注册的新驱动程序来执行此操作:Capybara.register_driver:all_browsersdo|app|#Whatwouldevenworkinhere?Idon'tthinkanythingwill.end然后跟进:Before('@all

ruby - 如何在请求范围之外访问 Sinatra 的记录器

似乎Sinatra的记录器只能在请求处理程序中使用(参见https://github.com/sinatra/sinatra#logging),但是如果我想在其他地方使用记录器怎么办,例如在辅助方法或配置Hook中?Sinatra记录器是否可以通过其他方式使用? 最佳答案 Thedocs给出一些关于范围的示例,但是您可以在helperblock中定义的方法中看到logger帮助程序,因为帮助程序block具有Application范围。在configure中它不可用,但我倾向于做的是设置我自己的日志记录,在rackup文件中作为常量

ruby-on-rails - 限制对 Ruby on Rails API 的请求

尝试在Google上搜索一个Rails插件,该插件将允许限制消耗特定资源的请求量。Django的Piston为此有一些开源代码。是否有Rails开箱即用的东西,或者是否可以安全地假设查看Piston的工作原理并将其移植为Rails插件是可以处理的? 最佳答案 这里有一些机架中间件可以完成您所追求的:http://github.com/dambalah/api-throttling这是一篇关于该中间件开发的博文:http://blog.messagepub.com/2009/05/05/how-to-rack-middleware-f

ruby - 如何解析 CSV 文件,更新字段,然后保存

我需要读取一个CSV文件,更新一个字段,然后保存更改。除了将我的更改保存到我正在更新的字段外,我一切正常:require'csv'@parsed_file=CSV::Reader.parse(File.open("#{RAILS_ROOT}/doc/some.csv"))@parsed_file.each_with_indexdo|row,x|address=row[5]l=Location.address_find(address)ifl!=nilputs"#{l.name}at#{l.address}"row[14]=l.store_codeputsrow[14]elseputs"

ruby - 如何在具有通配符的 RSpec 中请求(GET/POST)路由

我在Rails中有这条(公认的丑陋的)路线:scope'/software'dopost'/:software_id/:attachment_id/event/*event'=>'software#post_event',as:'post_event'end(如果不是遗留API,我会更改它)我正在为它编写一个RSpec测试。rakeroutes给我:post_eventPOST/software/:software_id/:attachment_id/event/*event(.:format)api/version1301/software#post_event我的测试是这样的:de

ruby-on-rails - ruby rails - 重定向到原始请求 url

这是我重定向到默认url(myapp_url)的方法。但我想更改重定向以转到用户在身份验证后输入的请求url。我怎么做?我在这里搜索了几个选项,比如:back。但是不行。用户输入一个url,如果未通过身份验证则被重定向到登录页面,然后登录后用户将被重定向到原始请求url。defcreateuser=User.Authenticate(params[:user_id],params[:password])ifusersession[:user_id]=user.idredirect_tomyapp_url,:notice=>"Loggedin!"elseflash.now.alert="

ruby-on-rails - 如何处理 Rails REST API 中的错误或错误请求?

我有一个包含JSONAPI接口(interface)的Rails应用程序。正确指定值后,Controller会很好地处理快乐路径,并将JSON呈现为输出。但是,如果输入有问题,则会引发异常并呈现rescues中的一些模板。我真的只是想沿着{"error":{"msg":"badrequest","params":...}}和适当的HTTP行返回一个JSON错误状态代码(例如,如果未通过身份验证,则为403)。但我只希望这适用于针对example.com/api/...中任何内容的请求。我该怎么做? 最佳答案 我有一个类似的案例,但我

ruby - 保存并重新使用 block 以进行方法调用

我调用RestClient::Resource#get(additional_headers={},&block)方法多次使用相同的block但在不同的资源上,我想知道是否有一种方法可以将block保存到变量中,或者将其保存到Proc中,每次都将其转换为block。编辑:我做了以下事情:resource=RestClient::Resource.new('https://foo.com')redirect=lambdado|response,request,result,&block|if[301,302,307].include?response.coderesponse.follo