草庐IT

pretty-urls

全部标签

ruby - 如何解析 URL 并提取所需的子字符串

假设我有这样一个字符串:"http://something.example.com/directory/"我想做的是解析这个字符串,并从字符串中提取"something"。第一步,显然要检查以确保字符串包含"http://"-否则,它应该忽略该字符串。但是,我如何才能提取该字符串中的"something"?假设这将要评估的所有字符串都具有相似的结构(即我正在尝试提取URL的子域-如果正在检查的字符串确实是一个有效的URL-其中有效以"http://").谢谢。附言我知道如何检查第一部分,即我可以简单地在"http://"处拆分字符串,但这并不能解决全部问题,因为这会产生"http://

ruby - 在 Ruby/Rails 中,如何对 URL 中的特殊字符进行编码/转义?

在使用OpenURIopen(url)之前如何对URL进行编码或“转义”?我们正在使用OpenURI打开远程url并返回xml:getresult=open(url).read问题是URL包含一些包含空格和其他字符的用户输入文本,可能包括“+”、“&”、“?”等,因此我们需要安全地对URL进行转义。我在使用Net::HTTP时看到了很多示例,但没有找到任何用于OpenURI的示例。我们还需要能够对在session变量中收到的类似字符串进行反转义,因此我们需要倒数函数。 最佳答案 不要使用URI.escape,因为它已在1.9中弃用。

ruby-on-rails - 如何只测试重定向到的 URL 的一部分(使用 assert_redirected_to)?

在我的Rails应用程序的功能测试中,我想测试我被重定向到的位置。预期的URL指向外部资源(这意味着它不是我的应用程序的一部分)。URL如下所示:https://my.url.com/foo?bar1=xyz&bar2=123不幸的是我无法预测参数,因为它们是由外部资源生成的。*但是,URL的其余部分始终保持不变:https://my.url.com/foo我通常使用assert_redirected_to进行此类测试,但这需要整个URL,包括参数。谁能想出另一种方法来测试该重定向,但只检查没有参数的URL的第一部分?(该URL不在assigns哈希中)*(我对应用程序进行API调用,

ruby - Mechanize 如何获取当前 url

我有这个代码require'mechanize'@agent=Mechanize.newpage=@agent.get('http://something.com/?page=1')next_page=page.link_with(:href=>/^?page=2/).click如您所见,此代码应转到下一页。next_page应该有urlhttp://something.com/?page=2如何获取next_page的当前url? 最佳答案 next_page.uri.to_s参见http://www.rubydoc.info/g

ruby httparty 在发布后获取响应 url 或 id

如何在发布后在单独的脚本中使用httparty从Rails项目中获取响应url或id?ruby脚本:HTTParty.post('http://localhost:3000/change_logs',parameters)response.body和所有其他的不显示url和响应id 最佳答案 两年后,我找到了一种从response的request属性访问最后一个URI的方法:url="http://example.com/redirects/to/www"response=HTTParty.get(url)response.requ

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

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

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 - 将查询字符串附加到 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,或者看起来是这样。所以把它放在一个包含中是行不通的。你如何获得你的基本网址? 最佳答案