草庐IT

HTTP_X_REQUEST_ID

全部标签

Ruby、Tor 和 Net::HTTP::Proxy

如果这是一个愚蠢的疑问,我提前道歉:我想在我的Ruby代码中使用代理来获取一些网页。我想偷偷摸摸!所以我正在使用Tor。我正在运行Tor,我可以像往常一样使用Net::HTTP.get(uri)。但我不知道如何使用Net::HTTP::Proxy来获取uri。我也无法弄清楚使用Tor将如何帮助使我的抓取匿名。非常感谢任何帮助。请不要只添加linktotheruby-docpageforNet::HTTP::Proxy.如果我明白这一点,我就不会在这里问这个了:-)另一种简单的方法是使用SOCKSify,但在这种情况下,我收到以下错误:/usr/lib/ruby/gems/1.9.2-p

ruby-on-rails - 在 Ruby Net::HTTP.start 中为服务调用设置 read_timeout

我想在我的ruby​​代码中覆盖服务调用的默认超时。我打开连接如下。res=Net::HTTP.start(@@task_url.host,@@task_url.port)do|http|http.get("/tasks/#{task_id}")end我尝试如下设置read_timeout时间,但随后我的代码中出现了NoMethodError异常。res=Net::HTTP.start(@@task_url.host,@@task_url.port)res.read_timeout=10resdo|http|http.get("/tasks/#{task_id}")end建议我应该如何

ruby - RuntimeError: :json 未在 Faraday::Request 上注册

我是ruby​​的新手,我正在尝试执行规范,但收到此错误:RuntimeError:         :jsonisnotregisteredonFaraday::Request我正在尝试使用这个gem:https://github.com/Chicago/windyMacOSX10.7.4Ruby1.9.3,使用RVM 最佳答案 我刚刚在升级Faraday时遇到了这个问题。json请求中间件在0.8中从Faraday中移除。它现在位于faraday_middlewaregem中。您应该geminstallfaraday_middl

Ruby HTTP 获取参数

如何通过ruby​​发送带参数的HTTPGET请求?我尝试了很多例子,但都失败了。 最佳答案 我知道这篇文章很旧,但是为了那些由谷歌带到这里的人,有一种更简单的方法可以以URL安全的方式对您的参数进行编码。我不确定为什么我没有在其他地方看到这个,因为该方法记录在Net::HTTP页面上。我已经看到Arsen7描述的方法也是其他几个问题的公认答案。在Net::HTTP中提到文档是URI.encode_www_form(params):#Letssaywehaveapathandparamsthatlooklikethis:path="

ruby - 在 ruby​​/ActiveRecord 中生成类似 Instagram 或 Youtube 的不可猜测的字符串 ID

在创建给定ActiveRecord模型对象的实例后,我需要生成一个简短的(6-8个字符)唯一字符串用作URL中的标识符,采用Instagram照片URL的样式(如http://instagram.com/p/P541i4ErdL/,它我只是争先恐后地成为404)或Youtube的视频网址(如http://www.youtube.com/watch?v=oHg5SJYRHA0)。执行此操作的最佳方法是什么?最简单的是createarandomstring重复直到它是唯一的?有没有一种方法可以对整数ID进行散列/洗牌,使用户无法通过更改一个字符来破解URL(就像我对上面的404'sInst

ruby-on-rails - 如何验证关联的模型 ID?

我有一个学生和一个类(class)模型。学生属于类(class),类(class)有很多学生。classStudenttruevalidates_associated:courseendclassCoursetruevalidates:courseCode,:courseYr,:uniqueness=>{:message=>"Cannotrepeatthecode"}has_many:studentsend在用于创建学生记录的表单中,我让用户输入类(class)ID。但我不知道如何验证用户输入的course_id。学生模型验证不会产生错误,即使我键入不存在的类(class)ID。如何让

ruby - 如何使用 Net::HTTP 只读取正文的 x 个字节?

在读取网页正文时,Ruby的Net::HTTP方法似乎是全有或全无。例如,我如何读取正文的前100个字节?如果请求的文件不可用,我正在尝试从内容服务器读取内容服务器,该内容服务器会在响应正文中返回一条简短的错误消息。我需要阅读足够多的正文以确定文件是否存在。文件很大,所以我不想让整个body只是为了检查文件是否可用。 最佳答案 这是一个旧线程,但根据我的研究,如何在Ruby中通过HTTP只读取文件的一部分的问题仍然是一个大部分没有答案的问题。这是我通过猴子修补Net::HTTP得到的一个解决方案:require'net/http'#

ruby - 在 Ruby 中,使用 "net/http",我们必须加入 url 并自己使用 "?"进行查询?

在下面的代码中,我们必须使用?字符加入url.path和url.query吗?有更优雅的方法吗?我必须使用net/http,因为在某些情况下我也想在用户代理的header中放置一个字符串。require'net/http'url_string='http://www.time.gov/timezone.cgi?Pacific/d/-8'url=URI.parse(url_string)response=Net::HTTP.start(url.host,url.port)do|http|http.get(url.path+'?'+url.query)endputsresponse.bod

ruby-on-rails - 未知属性 : user_id

我在执行current_user.stories.build时遇到错误unknownattribute:user_idclassUser架构.rbcreate_table"stories",:force=>truedo|t|t.string"responsible"t.string"descr"t.string"state"t.datetime"created_at",:null=>falset.datetime"updated_at",:null=>falseendcreate_table"users",:force=>truedo|t|t.string"email"t.string

ruby-on-rails - 在 Rails 4 中显示或获取 HTTP header 属性

我有一个用Rails开发的应用程序,我想查看HTTPheader中的属性。有没有办法读取这些属性?它们存储在哪里?有人提到了request.headers。这样对吗?我看不到此数组中的任何属性。 最佳答案 request.headers不返回散列,而是返回ActionDispatch::Http::Headers的实例,它是rackenv的包装器。ActionDispatch::Http::Headers实现了很多方法,比如[]和[]=,这使得它表现得像一个散列,但是它不会覆盖默认的inspect,因此您无法仅通过p或pp查看键值对