草庐IT

preix_author_url

全部标签

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 - 使用 declarative_authorization 保护敏感属性

使用declarative_authorization按角色保护属性的好方法是什么??例如,用户可以编辑他的联系信息,但不能编辑他的角色。我的第一个想法是为不同的场景创建多个Controller操作。我很快意识到随着protected属性数量的增加,这会变得多么笨拙。为用户角色执行此操作是一回事,但我可以想象多个protected属性。添加很多Controller操作和路由感觉不对。我的第二个倾向是围绕特定的敏感属性创建权限,然后使用declarative_authorizations提供的Viewhepers包装表单元素。但是,在我看来,模型和Controller这方面有点模糊。建议

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 - CanCan load_and_authorize_resource 触发 Forbidden Attributes

我有一个使用强参数的标准RESTfulController。classUsersController在我的config/initializers中,我有文件strong_parameters.rbActiveRecord::Base.send(:include,ActiveModel::ForbiddenAttributesProtection)当我向CanCan的load_and_authorize_resource添加一个简单的调用时,我得到了1)UsersControllerPOSTcreatewithinvalidparamsre-rendersthe'new'template

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