草庐IT

pretty-urls

全部标签

ruby - 检索 URL 的内容作为字符串

由于处理Hpricot的繁琐原因,我需要编写一个传递URL的函数,并将页面的全部内容作为单个字符串返回。我很接近。我知道我需要使用OpenURI,它应该看起来像这样:require'open-uri'open(url){#dosomethingmysteriousheretogetpage_string}putspage_string有人可以建议我需要添加什么吗? 最佳答案 你可以在没有OpenURI的情况下做同样的事情:require'net/http'require'uri'defopen(url)Net::HTTP.get(U

ruby - 使用 Nokogiri 提取链接时如何获取绝对 URL?

我正在使用Nokogiri从页面中提取链接,但我想获得绝对路径,即使页面上的链接是相对路径。我怎样才能做到这一点? 最佳答案 Nokogiri是无关的,除了它为您提供链接anchor这一事实。使用Ruby的URI管理路径的库:absolute_uri=URI.join(page_url,href).to_s实际可见:require'uri'#TheURLofthepagewiththelinkspage_url='http://foo.com/zee/zaw/zoom.html'#Avarietyoflinkstotest.href

ruby - 如何在 Capybara 中获取包含当前路径的完整 URL

我刚开始使用capybara编写测试,但在获取页面的当前URL时遇到了问题。我是这样写的:url=page.current_url+page.current_path它只是返回基本URL。非常感谢您的帮助。 最佳答案 试试这个:url=URI.parse(current_url) 关于ruby-如何在Capybara中获取包含当前路径的完整URL,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/que

ruby-on-rails - 在 Ruby 中获取 URL 的重定向

根据Facebook图形API,我们可以使用此请求用户个人资料图片(示例):https://graph.facebook.com/1489686594/picture但上一个链接的真实图片URL是:http://profile.ak.fbcdn.net/hprofile-ak-snc4/hs356.snc4/41721_1489686594_527_q.jpg如果您在浏览器中键入第一个链接,它会将您重定向到第二个链接。有没有什么方法可以通过Ruby/Rails只知道第一个URL来获取完整的URL(第二个链接)?(这是thisquestion的重复,但对于Ruby)

ruby - 如何安全地加入相对 url 段?

我正在尝试找到一种将部分url路径段连接在一起的可靠方法。有没有快速的方法来做到这一点?我尝试了以下方法:putsURI::join('resource/','/edit','12?option=test')我希望:resource/edit/12?option=test但是我得到了错误:`merge':bothURIarerelative(URI::BadURIError)我过去曾为此使用过File.join(),但将文件库用于url似乎有些不对。 最佳答案 URI的api不一定很好。URI::join仅当第一个作为带有协议(pr

ruby-on-rails - Rails3 设计未定义的方法 `confirmation_url'

我似乎已经为我的用户身份验证设置了Devise,并设置了:confirmable选项。当我在浏览器中运行它时,一切似乎都运行良好,我注册,转到我的railss控制台中服务器日志中显示的确认url。但是,当我尝试将以下内容添加到我的db/seed.rb时User.create!(:username=>'haar',:email=>'haar@example.com',:password=>'password',:password_confirmation=>'password')然后运行​​rakedb:setup--trace我收到以下错误:rakeaborted!undefinedm

ruby-on-rails - 在 Nokogiri 中获取属性值以提取链接 URL

我有一个看起来像这样的文档:link我无法让Nokogiri为我获取href属性的值。我想将地址作为字符串存储在Ruby变量中。 最佳答案 html=linkHTMLdoc=Nokogiri::HTML(html)doc.xpath('//div/a/@href')#=>[#]或者如果您想更具体地了解div:>>doc.xpath('//div[@id="block"]/a/@href')=>[#]>>doc.xpath('//div[@id="block"]/a/@href').first.value=>"http://googl

ruby-on-rails - 图像的 Rails 3.1 绝对 URL

我正在使用Rails3.1。我正在尝试解决这个问题,但令我惊讶的是,似乎Rails根本没有附带这种方法。也许我错了。谁能告诉我如何获得图像的完整绝对URL?我使用asset_path(image.png),它为我提供了在应用程序中使用的相对路径。我尝试执行root_url+asset_path(image.png)但这只是给了我一个带有双斜杠的http://localhost:3000//assets/image.png谁有有效的方法来做到这一点? 最佳答案 请参阅documentation中的使用Assets托管部分.您需要指定一

ruby-on-rails - 让 Rails URL 助手自动输出 https url

我正在开发一个大量混合使用http和https的网站-使链接使用正确的路由协议(protocol)的最佳/最简单方法是什么-可以在路由文件中指定吗?假设我在Rails3中有以下路线。match"/test"=>"test#index",:as=>:test,:constraints=>{:protocol=>'https'}如果我在http页面上,并且我使用test_url(),它会输出http://domain.com/test.我要https://domain.com/test相反。我知道我可以使用test_url(:secure=>true),但那是重复逻辑。我知道我可以http

ruby - 在 Ruby 中是否有打开包含下划线的 URL 的解决方法?

我正在使用open-uri打开URL。resp=open("http://sub_domain.domain.com")如果它包含下划线,我会得到一个错误:URI::InvalidURIError:theschemehttpdoesnotacceptregistrypart:sub_domain.domain.com(orbadhostname?)据我所知,这是因为根据RFC,URL只能包含字母和数字。有什么解决方法吗? 最佳答案 这看起来像是URI中的错误,而uri-open、HTTParty和许多其他gem都使用了URI.par