草庐IT

c++ - 修改编译后的可执行内存分配

全部标签

ruby-on-rails - 使用 constantize 在 ruby​​ 中远程执行代码

当使用contantize时,我正试图解决ruby​​/rails中的远程代码执行漏洞。我知道能够向服务器提供任何类名可能存在潜在危险,但我想知道这本身是否危险。例如,如果RailsController代码看起来像这样(即在实例化对象上执行硬编码方法):klass=params[:class].classify.constantizeklass.do_something_with_id(params[:id])ifklass.respond_to?('do_something_with_id')此代码易受攻击吗?还是只能结合指定要在类上调用的方法? 最佳答案

我可以覆盖用 C 编写的 Ruby 方法吗?

是否可以使用Ruby代码覆盖Ruby本身的一部分方法,例如rb_error_frozen,它们是用C语言编写的?背景:我想知道当卡住的对象被修改时,是否有可能让Ruby仅记录警告,而不引发异常。这样,我可以记录各种状态修改,而不是在第一次发生时停止。我主要考虑使用YARV执行此操作,但如果这样更容易,我可以使用其他实现。是的,这是一个whyday项目!不要在生产环境中尝试这个! 最佳答案 我只能代表MRI/YARV,但我会试一试。如果C函数已明确定义为Ruby对象上的方法,则只能在Ruby中覆盖源自C的函数。例如,Kernel#ex

ruby - 错误:执行 gem 时 ... (Zlib::GzipFile::Error) 不是 gzip 格式

我正在开发Senchatouch2应用程序。我一直在关注“StylingtheuserinterfaceofaSenchaTouchapplication”关于sechatouch应用程序主题的教程。它需要我安装Ruby、Compass和SASS。我使用ruby​​installer.org中的安装程序安装了Ruby。在执行以下命令时,我得到了确认正确安装的预期结果:C:\>ruby-vruby1.9.3p327(2012-11-10)[i386-mingw32]当前源是最新的:C:\>gemsources**CURRENTSOURCES**http://rubygems.org/接下

ruby - 当应用程序关闭时,我要在 Sinatra 中的什么位置放置要执行的代码?

我正在为我的网络应用程序使用Sinatra。当我的应用程序关闭时,我有一些要执行的清理代码。Sinatra中是否有针对此的Hook,还是我必须使用单独的机制? 最佳答案 看Kernel#at_exit,如果您在主应用程序文件中的某处定义这样的block,我不明白为什么它不能在Sinatra应用程序中工作。更新:根据matt的评论,您必须在要求Sinatra之前定义您的at_exit处理程序。 关于ruby-当应用程序关闭时,我要在Sinatra中的什么位置放置要执行的代码?,我们在Sta

ruby - 我怎样才能可靠地发现 Ruby 可执行文件的完整路径?

我想写一个脚本,打包成一个gem,它将修改它的参数,然后用修改后的参数exec一个新的ruby进程。换句话说,类似于修改其参数然后执行exec$SHELL$*的shell脚本。为此,我需要一种可靠的方法来发现正在执行当前脚本的ruby​​可执行文件的路径。我还需要获取传递给当前进程的完整参数——Ruby参数和脚本参数。 最佳答案 Rake源代码是这样的:RUBY=File.join(Config::CONFIG['bindir'],Config::CONFIG['ruby_install_name']).sub(/.*\s.*/m,

ruby - 为 Heroku 静态编译 pdftk。需要将 PDF 拆分为单页文件

所以我们使用heroku来托管我们的rails应用程序。我们搬到了雪松堆。此堆栈未安装pdftk库。我联系了支持人员,被告知为amd64ubuntu静态编译它并将其包含在我的应用程序中。事实证明,这比我想象的要难。最初我下载了ubuntu的包(http://packages.ubuntu.com/natty/pdftk),将其解压缩,并包含二进制文件和共享库。我收到奇怪的错误,例如:UnhandledJavaException:java.lang.NullPointerExceptionatcom.lowagie.text.pdf.PdfCopy.copyIndirect(pdftk)

ruby-on-rails - 无法分配请求的地址 - bind(2) (Errno::EADDRNOTAVAIL)

我在centos6.3服务器上使用railforteambox,实际上这只是在实际应用之前的试错。我正在使用2个运行在相同centos版本和精确副本上的虚拟机,VM2只运行远离VM1的mysql我试过mysql连接#nc并且它已连接VM1(192.168.7.201)&VM2(192.168.7.202运行MYSQL)我在my.cnf中的远程机器(VM2)上有bind-address,bind-address=192.168.7.202这是我的database.ymldevelopment:adapter:mysqlhost:192.168.7.202port:3306username

Ruby 并为 Float 实例修改自身

我想更改float实例的self值。我有以下方法:classFloatdefround_by(precision)(self*10**precision).round.to_f/10**precisionendend我想添加round_by!修改自身值的方法。classFloatdefround_by!(precision)self=self.round_by(precision)endend但是我得到一个错误,说我不能改变self的值。有什么想法吗? 最佳答案 您不能更改self的值。它总是指向当前对象,你不能让它指向别的东西。当

ruby - Ruby 中的内存流?

ruby是否有我遗漏的内存流?看起来IO仅适用于文件支持的流...我希望在.NET中使用类似于System.IO.MemoryStream的东西? 最佳答案 你在寻找像StringIO这样的东西吗?? 关于ruby-Ruby中的内存流?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/5931263/

ruby - 修改默认哈希值

这个问题在这里已经有了答案:Strange,unexpectedbehavior(disappearing/changingvalues)whenusingHashdefaultvalue,e.g.Hash.new([])(4个答案)关闭6年前。Ruby允许您定义散列的默认值:h=Hash.new(['alright'])h['meh']#=>["alright"]显示散列时会显示值的分配,但不会显示修改后的默认值。'坏'在哪里?h['good']=['fine','dandy']h['bad'].push('unhappy')h#=>{"good"=>["fine","dandy"]