草庐IT

TypeScript的安装及简单使用

全部标签

ruby - 简单的 Ruby 输入验证库

我一直在到处寻找适用于Ruby的简单输入验证库。一切似乎都指向ActiveRecord(或类似的)。我没有使用Rails,我使用的是没有ORM的Sinatra。验证用户输入的最佳方法是什么(不直接绑定(bind)到模型层)?简单的东西,如“字符串长度”、“是数字”等。最好有一个很好的机制来声明错误消息。 最佳答案 您可以使用Rails3RC中的ActiveModel::Validations:require'active_model'#thisappearstobeabuginActiveModel-itusesthis,butdo

ruby - 无法使用 key 与 Ruby 和 net/ssh 连接

我在使用“net-ssh”gem从ruby​​通过ssh连接时遇到问题,得到Net::SSH::AuthenticationFailed。代码如下require'net/ssh'keys=["path_to_private_key"]Net::SSH.start('host','user',:keys=>keys,:verbose=>:debug)do|ssh|#sshcodeend直接从命令行使用ssh是可行的:ssh-iuser@host我的sshAPI有误吗?我已经尝试将“user@host”和“user”作为用户名,结果相同。这是调试输出:D,[2011-07-26T19:42

ruby-on-rails - 更改 bundle 安装 Ruby 版本

我是Ruby/Rails的新手,如果这是一个微不足道的问题,请原谅我。每当我运行bundleinstall时,它都会在vendor/bundle/ruby/1.8中安装所有内容,而不是vendor/bundle/ruby/1.9.1,这是我正在使用的Ruby版本。当我运行ruby-v时,我得到了正确的1.9.1版本,但是bundleinstall出于某种原因坚持使用1.8,这导致了基本Rails功能的许多错误。如何指示bundle与1.9.1一起工作(最好删除任何Ruby1.8的踪迹)?谢谢!编辑:我已经做了一切this回答说,我没有得到1.8的踪迹再次编辑:好吧,它以某种方式工作。也

ruby-on-rails - 在 Devise on Rails 中使用单独的身份验证模型

我有一个简单的解决方案,我自己使用以下对象:Account(有token字段,认证时返回并用于API调用)身份验证(具有auth_type/auth_id和对帐户的引用)我有一个单独的身份验证模型,可以连接多种登录方式(设备UUID、电子邮件/密码、twitter、facebook等)。但似乎在Devise的所有示例中,您都在User(Account)模型上使用它。那不是不够灵活吗?例如,OmniAuth模块在User模型上存储提供者和ID,如果您希望能够从Twitter和Facebook登录,会发生什么情况?只有一个提供者有空间吗?我应该在我的Account模型还是Authentic

ruby - 为什么 bundler 使用多个 gem 位置?

这发生在Puppet'sbundle。Gemfilespecifiesgem"puppet",:path=>File.dirname(__FILE__),:require=>false但是我安装在$GEM_HOME中的一个gem最终出现在$:中。$bundleexecruby-e'puts$:'.../home/puppy/puppet-git-clone/lib.../usr/lib/ruby/vendor_ruby.../home/puppy/gems/gems/puppet-3.7.5/lib...这本身并不是问题,但显然Ruby将加载Puppet3.7.5而不是我从git存储库

ruby - 安装新 Ruby gem 时 RDoc::TopLevel:Class 的未定义方法 `reset'

例如,$geminstallnetaddrFetching:netaddr-1.5.1.gem(100%)Successfullyinstallednetaddr-1.5.1ERROR:Whileexecutinggem...(NoMethodError)undefinedmethod`reset'forRDoc::TopLevel:Class当我安装任何新的gem时,NoMethodError异常不断出现。我用谷歌搜索并搜索了RDoc和RubyGemsGitHub存储库中的问题,但一无所获。我的Ruby版本是$ruby-vruby2.3.0p0(2015-12-25revision5

ruby-on-rails - 使用回形针上传多个文件

我在使用回形针上传多个文件时遇到问题,我的模型是这样的sliderhas_manyimgarraysimgarrayshas_manyimageobjectsimageobjectshave_attachment(asforpaperclip)我在接收单个图像并在我的其他模型上使用回形针保存它没有问题,但我不确定如何在多个文件上传期间处理imgarrays参数返回的数组。这是我的Rails服务器日志:StartedPOST"/slider"for127.0.0.1at2012-07-2310:14:17+0800ProcessingbySliderController#createas

ruby - 在 ruby​​ 中使用字符串插值会发生什么?

我认为ruby​​只是调用方法to_s但我无法解释它是如何工作的:classFakedefto_sselfendend"#{Fake.new}"根据逻辑,由于无限递归,这应该将堆栈级别提升得太深。但它工作正常,似乎从对象调用#to_s。=>"#"但为什么呢?已添加:classFakedefto_sFake2.newendendclassFake2defto_s"Fake2#to_s"endend此代码在两种情况下的工作方式不同:puts"#{Fake.new}"=>"#"但是:putsFake.new.to_s=>"Fake2#to_s"我觉得不正常。有人可以建议在ruby​​解释器中

ruby - 使用 Puma 的工作线程、线程和池大小

如果我有一台只有1个核心的服务器,多少个pumaworker、线程和多少数据库池大小才合适?这里的一般拇指是什么? 最佳答案 这不是一个简单的答案。信息的两个主要来源是:Pumagithubrepository(作者的观点)Heroku'swebpage(主要大用户观点)不幸的是,它们不一致主要是因为heroku具有不同的部署指标和术语。所以我最终遵循了puma存储库指南,其中写道:每个核心一个worker要根据RAM可用性和应用程序确定线程线程=连接池所以线程数多半是试探操作。 关于r

ruby - 为什么在初始化时不使用 setter 方法?

最近我一直在阅读“Ruby中的实用面向对象设计”,我注意到最佳实践之一是使用访问器方法而不是直接获取@instance_variable。例如:classFooattr_accessor:bardefinitialize(my_argument)@bar=my_argumentend#bad#deflorem_ipsum#@bar*999#end#gooddeflorem_ipsumbar*999endend让事情保持干燥是有意义的,并且,以防万一我需要在实际获取它的值之前以某种方式处理@bar。但是,我注意到initialize方法直接设置了@bar实例变量的值:classFooat