草庐IT

ruby - 在 ruby​​ 中散列 url 的最佳方法是什么?

我正在编写一个指向外部链接的网络应用程序。我希望为我可以在URL中使用的每个文档创建一个非连续的、不可猜测的ID。我做了一件显而易见的事情:将url视为字符串并在其上添加str#crypt,但这似乎会阻塞任何非字母数字字符,例如斜杠、点和下划线。关于解决这个问题的最佳方法有什么建议吗?谢谢! 最佳答案 根据您想要的字符串长度,您可以使用一些替代方案:require'digest'Digest.hexencode('http://foo-bar.com/yay/?foo=bar&a=22')#"687474703a2f2f666f6f

ruby-on-rails - 如何在 Rails 中使用 "_blank"或 "_new"

在HTML中,如果我想在新窗口中打开链接,我会采用target="_blank",如下所示:如何将"_blank"添加到rails?这是我到目前为止的链接代码(但它当前在同一选项卡/窗口中打开): 最佳答案 我觉得是这样的参见http://api.rubyonrails.org/classes/ActionView/Helpers/UrlHelper.html#method-i-link_to 关于ruby-on-rails-如何在Rails中使用"_blank"或"_new",我们在S

ruby - 在 Ruby 中,为什么等于 nil ("Date.new == nil") 返回 nil?

今天写一些rspec时,我遇到了一些意外的行为,将日期(和时间)实例与nil进行比较。这是一个使用原始ruby​​的示例(没有Rails或其他库):user@MacBook-Work~$ruby-vruby1.8.7(2008-08-11patchlevel72)[universal-darwin10.0]user@MacBook-Work~$irb>>1==nil=>false>>"string"==nil=>false>>:sym==nil=>false>>false==nil=>false>>[]==nil=>false>>{}==nil=>false>>Proc.new{}==

ruby - 使用 Ruby 重定向后如何获取最终 URL?

如果http://foo.com重定向到1.2.3.4然后再重定向到http://finalurl.com,如何我可以使用Ruby找出登陆URL“http://finalurl.com”吗? 最佳答案 这里有两种方法,同时使用HTTPClient和Open-URI:require'httpclient'require'open-uri'URL='http://www.example.org'httpc=HTTPClient.newresp=httpc.get(URL)putsresp.header['Location']>>http

ruby-on-rails - 如何在 Ruby 2 中为 Net::HTTP::Post.new 请求指定读取超时

我有一个帖子发生在一个ruby​​脚本的rails应用程序上。该脚本创建一个变量请求作为request=Net::HTTP::Post.new(url.path)然后按如下方式使用request.content_type="application/json"request.body=JSON.generate(params)response=Net::HTTP.start(url.host,url.port){|http|http.request(request)}服务器端发生了相当多的处理,我收到了一个Net::ReadTimeout错误我尝试指定超时时间request.read_t

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?

ruby-on-rails - 如何在不下载文件的情况下使用其 URL 检查文件是否存在?

我需要编写代码,通过检查文件的URL来确定文件是否存在。目前我实现了这个:error_code=400;response=Net::HTTP.get_response(URI(url));returnresponse.code.to_i但是,它不能正常工作,因为每次它都下载文件,如果我有大文件或很多文件,这真的很慢。如何在不下载文件的情况下判断远端是否存在文件? 最佳答案 如果你想使用Rubys包含的Net::HTTP那么你可以这样做:uri=URI(url)request=Net::HTTP.newuri.hostresponse

ruby - 在 sinatra 中获取绝对(基本)url

现在,我做一个get'/'doset:base_url,"#{request.env['rack.url_scheme']}://#{request.env['HTTP_HOST']}"#...haml:indexend能够在HAMLindex.haml中使用options.base_url。但我确信有一种更好的、更干的方法可以做到这一点。然而我看不见,也找不到。(我是Sinatra的新手:))不知何故,在get之外,我没有可用的request.env,或者看起来是这样。所以把它放在一个包含中是行不通的。你如何获得你的基本网址? 最佳答案

ruby-on-rails - 如何在 Rails 测试中轻松解析带参数的 URL?

我有一些代码将return_toURL嵌入到我要测试的重定向(如OpenID)中:deftest_uses_referrer_for_return_toexpected_return_to='http://test.com/foo'@request.env['HTTP_REFERER']=expected_return_toget:fazbot#@response.redirected_tolookslikehttp://service.com?...&return_to=[URI-encodedversionofURLabove]&...encoded_return_to=(some

ruby - 如何从文本中提取 URL

如何从Ruby中的纯文本文件中提取所有URL?我尝试了一些库,但在某些情况下它们会失败。什么是最好的方法? 最佳答案 如果您喜欢使用Ruby中已经为您提供的功能:require"uri"URI.extract("textherehttp://foo.example.org/blaandheremailto:test@example.comandherealso.")#=>["http://foo.example.org/bla","mailto:test@example.com"]阅读更多:http://railsapi.com/d