草庐IT

php - 尝试优化像素读取和输出功能

全部标签

ruby - 读取 400 响应的正文?

我正在尝试使用rest-clientgem读取400响应的主体。问题是rest-client通过将其作为错误抛出来响应400,因此我想不出任何方法来获取正文。这是一个激励人心的例子。考虑对facebook图形API的调用:JSON.parse(RestClient.get("https://graph.facebook.com/me?fields=id,email,first_name,last_name&access_token=#{access_token}"))如果access_token过期或无效,facebook会做两件事:返回400BadRequestHTTP响应在响应正文

ruby-on-rails - 在 Rails 中添加 created_at DESC 功能

我有一个带有帖子和评论模型的应用程序。在我的索引操作/View中,我遍历帖子并从最近创建时间到最早创建时间显示它们。我的评论嵌套在我的帖子中,因此在我的帖子显示操作/View中,我想遍历评论并让它们显示从最近创建到最早创建的时间。如果我在我的post.rb文件中创建一个方法,我似乎只能让它工作。我有这个:post.rb:defnewest_commentsself.comments.order("created_atDESC")end在我的帖子展示View中,我可以遍历帖子评论并且效果很好:但我想在Controller层设置此功能,但我不知道如何设置。这是我在我的帖子Controlle

ruby-on-rails - 尝试在 RoR 应用程序中发送电子邮件时遇到 SMTP 错误

我一直在拼命尝试使用RoR中的ActionMailer类发送电子邮件,即使终端显示正在发送消息,它仍会返回此错误:et::SMTPAuthenticationError:534-5.7.14这是我的邮件程序类在app/mailers/my_mailer.rb中的样子:classMyMailer这是我的config/application.rb文件的样子:config.action_mailer.delivery_method=:smtpconfig.action_mailer.smtp_settings={address:'smtp.gmail.com',port:587,#domai

ruby - 使用 Mechanize 读取本地 HTML 文件

我正在构建一个爬虫,我知道如何使用ruby​​mechanize使用以下代码从网上读取页面:require'mechanize'agent=Mechanize.newagent.get"http://google.com"但是我可以使用Mechanize从文件系统中读取HTML文件吗?怎么办? 最佳答案 仅使用file://协议(protocol)对我来说效果很好:html_dir=File.dirname(__FILE__)page=agent.get("file:///#{html_dir}/example-file.html"

ruby-on-rails - 尝试获取哈希值时的 `try` 方法

我试图在从可能有也可能没有值的散列中提取时避免出现错误消息。我要么希望它返回值,要么返回nil。我认为try方法可以做到这一点,但我仍然遇到错误。keynotfound:"en"我的散列是一个名为content的hstore列...content['en']等content={"es"=>"Thisisanamazingevent!!!!!","pl"=>"Gonnabecrap!"}尝试方法@object.content.try(:fetch,'en')#shouldreturnnil,buterrorsevenwithtrymethod我认为这行得通,但行不通。我还能如何返回nil

Ruby 在 1 行代码中读取/写入文件

我是Ruby的新手,我正在练习一些套路,但我遇到了这个愚蠢的问题。我需要用1行代码将1个文件的内容复制到一个新文件第一次尝试:File.open(out,'w').write(File.open(in).read)很好,但是我需要关闭文件是错误的:File.open(out,'w'){|outf|outf.write(File.open(in).read)}然后当然是关闭阅读:File.open(out,'w'){|outf|File.open(in){|inf|outf.write(outf.read))}}这是我想出的,但对我来说它不像1行代码:(想法?问候,

ruby - SSL_connect SYSCALL returned=5 errno=0 state=SSLv2/v3 读取服务器 hello A

我有一个使用IMAP和SSL连接到交换服务器的ruby​​客户端。我使用RubyNet::IMAP库(在幕后使用openssl)进行连接。它已经工作了几个月。交换服务器管理员从godaddy安装了新证书,现在我收到此错误:SSL_connectSYSCALLreturned=5errno=0state=SSLv2/v3readserverhelloA有谁知道这个错误是什么意思?(我试过谷歌搜索)我怀疑新证书有问题导致了这个问题,但我不知道如何解决它。另外我知道您可以在使用NET:HTTP时禁用证书验证:http.verify_mode=OpenSSL::SSL::VERIFY_NONE

ruby-on-rails - 开始对 Ruby Rails 网站进行单元和功能测试的最佳方法是什么?

我正在测试一个RubyRails网站,想开始进行单元和功能测试。 最佳答案 Cucumber和RSpec值得一看。他们鼓励在behaviour-driven中进行测试,基于示例的样式。RSpec是一个用于单元级测试的库:describe"hello_world"it"shouldsayhellototheworld"do#RSpeccomeswithitsownmock-objectframeworkbuiltin,#thoughitletsyouuseothersifyoupreferworld=mock("World",:pop

ruby - RSpec 较短的测试失败回溯输出

我正在使用RSpec(最新版本2.12.2)来测试我正在处理的一个小型Rub​​y类。我的问题是,当RSpec测试失败时,测试输出看起来非常冗长,并显示了一个巨大的错误消息列表,几乎是一个完整的回溯。这意味着我必须向上滚动才能看到实际的错误消息和跟踪的顶部。我相信默认情况下RSpec应该这样做,但它似乎并没有为我做这件事。例如,如果我运行rspecspec/my_spec.rb:132(只运行一个在L132上的测试),我得到这个输出:Failure/Error:@f.has_changed?("test").shouldbe_trueexpected:truevaluegot:fals

ruby - 尝试使用 ruby​​ Mechanize POST

我使用firefox插件LiveHTTPheaders捕获了登录HTTPheader。我找到了以下url和变量。POST/loginemail=myemail%40gmail.com&password=something&remember=1&loginSubmit=Login这是我正在运行的代码:require'rubygems'require'mechanize'browser=Mechanize.newbrowser.post('http://www.mysite.com/login',[["email","myemail%40gmail.com"],["password","s