草庐IT

file_or_url

全部标签

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 - Vagrant File Chef 属性

我正在尝试将我的Vagrant文件配置为具有一些Chef属性,但我一定是做错了什么,因为ChefRecipe使用的是默认值而不是我试图设置的属性。这是我的vagrant文件的配置部分:config.vm.provision:chef_solodo|chef|chef.json={:mysql=>{:server_root_password=>'password'},:nodejs=>{:version=>'0.6.14',:dir=>'/usr/local',:npm=>'1.1.13'}}chef.cookbooks_path="config/env/cookbooks"chef.a

ruby-on-rails - Ruby On Rails 应用程序中的重复任务 : Cron or other?

我目前正在编写一个从RSS源中提取新信息的应用程序,并且必须以一定的频率更新这些RSS源。目前我只在用户请求提要时拉取,但我想将该行为更改为自动定期获取。我正在编写一个与数据库交互并通过cron定期启动的shellscript-但这是很多双重努力,所以我想知道执行此操作的“RailsWay”或“RubyWay”是什么。我正在使用Ubuntu、Apache和Passenger。您能否建议甚至可能包含在应用程序中的更好的方法,这样我就可以轻松地将应用程序部署到另一台机器上,而不必与cron混在一起? 最佳答案 我建议做一些类似rake任

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

sql - 使用 SQL IN 和 SQL OR 运算符的 Rails 3 ActiveRecord 查询

我正在使用“where”语法编写一个Rails3ActiveRecord查询,它同时使用了SQLIN和SQLOR运算符,但不知道如何同时使用它们。此代码有效(在我的用户模型中):Question.where(:user_id=>self.friends.ids)#note:self.friends.idsreturnsanarrayofintegers但是这段代码Question.where(:user_id=>self.friends.idsOR:target=>self.friends.usernames)返回这个错误syntaxerror,unexpectedtCONSTANT,

ruby - 为什么 `return a or b` 在 Ruby 中是空值表达式错误?

这很好:deffooaorbend这也很好:deffooreturna||bend这将返回空值表达式:deffooreturnaorbend为什么?它甚至没有被执行;它没有通过语法检查。voidvalueexpression是什么意思? 最佳答案 returnaorb被解释为(returna)orb,因此returna的值对于计算(returna)或b的值,但由于return永远不会在原地留下一个值(因为它从那个位置转义),所以它不是为了返回有效值而设计的在原来的位置。因此,整个表达式只剩下(some_void_value)或b,并

ruby-on-rails - ruby 错误 : cannot load such file -- rest-client

我正在使用RubyonRails4。我正在努力require'rest-client'在我的Controller中,以便我可以解析从表单中获取的登录信息并将其发送到API。我可以验证gem是否已安装并且也在我的应用程序根目录下的Gemfile中。但是,当我尝试在我的Controller中请求该文件时,它仍然抛出“无法加载此类文件--rest-client”。我用谷歌搜索了这个错误,我看到的大部分答案要么是gem没有安装,要么不在Gemfile中,要么是两者兼而有之。这里的情况也不是。我的Controller是否由于某种原因无法访问rest-clientgem?我必须使用rest-cli

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