草庐IT

图像安全

全部标签

ruby-on-rails - Carrierwave - 将图像调整为固定宽度

我正在使用RMagick并希望将我的图像调整为100像素的固定宽度,并按比例缩放高度。例如,如果用户要上传300x900像素,我希望将其缩放为100x300像素。 最佳答案 只需将其放入您的上传文件中即可:classImageUploader[100,10000]endend此处的文档和示例:http://www.imagemagick.org/RMagick/doc/image3.html#resize_to_fit请记住,如果图片小于100像素,resize_to_fit会放大图片。如果您不希望它这样做,请将其替换为resize

ruby - 如何安全地加入相对 url 段?

我正在尝试找到一种将部分url路径段连接在一起的可靠方法。有没有快速的方法来做到这一点?我尝试了以下方法:putsURI::join('resource/','/edit','12?option=test')我希望:resource/edit/12?option=test但是我得到了错误:`merge':bothURIarerelative(URI::BadURIError)我过去曾为此使用过File.join(),但将文件库用于url似乎有些不对。 最佳答案 URI的api不一定很好。URI::join仅当第一个作为带有协议(pr

ruby - Ruby 的 stdlib Logger 类是线程安全的吗?

简单来说就是标准库LoggerRuby中的线程安全类?Google发现的唯一有用信息是论坛上有人说它“似乎”是线程安全的。而且我不想花时间测试记录器来弄清楚它是否正确。目前我正在使用log4r这是线程安全的,但如果标准库已经做到了,那就太过分了。 最佳答案 快速查看logger.rb会发现如下代码:defwrite(message)@mutex.synchronizedoif@shift_ageand@dev.respond_to?(:stat)begincheck_shift_logrescueraiseLogger::Shift

Ruby/Sinatra - 提供 css、javascript 或图像文件

通过Sinatra路由您的请求的正确方法是什么,以便它在不进行任何处理的情况下提供文件?我正在寻找人们在Sinatra框架中执行此操作的最常见方式?我通常将所有静态内容放在“内容”路径中。例子:/内容/CSS/内容/图片/内容/js如何使用通配符提供内容下的所有内容?我很惊讶这里没有这样的真实例子:http://sinatra-book.gittr.com/ 最佳答案 Sinatra和Rails对静态内容使用路径public-例如,./public/javascripts/。这些路径中的所有文件随后将由Web服务器(例如Thin、P

ruby-on-rails - 图像的 Rails 3.1 绝对 URL

我正在使用Rails3.1。我正在尝试解决这个问题,但令我惊讶的是,似乎Rails根本没有附带这种方法。也许我错了。谁能告诉我如何获得图像的完整绝对URL?我使用asset_path(image.png),它为我提供了在应用程序中使用的相对路径。我尝试执行root_url+asset_path(image.png)但这只是给了我一个带有双斜杠的http://localhost:3000//assets/image.png谁有有效的方法来做到这一点? 最佳答案 请参阅documentation中的使用Assets托管部分.您需要指定一

ruby - 创建一个线程安全的临时文件名

当使用Tempfile时,Ruby正在创建一个具有线程安全和进程间安全名称的文件。这样我只需要一个文件名。我想知道是否有比以下更直接的方法:t=Tempfile.new(['fleischwurst','.png'])temp_path=t.patht.closet.unlink 最佳答案 Dir::Tmpname.create您可以使用Dir::Tmpname.create。它找出要使用的临时目录(除非您向它传递一个目录)。考虑到它需要一个block,使用起来有点难看:require'tmpdir'#=>trueDir::Tmpn

ruby - 为什么安全导航比在 Rails 中使用 try 更好?

我正在阅读this.使用它有什么好处:user&.address&.state结束user.try(:address).try(:state)我还是不明白。 最佳答案 (1)&.一般比try(...)短根据具体情况,这可以使您的代码更具可读性。(2)&.是标准的Ruby,与try相对try方法不是在Ruby核心库中定义的,而是在Rails库中定义的。当您不是在开发RoR网络应用程序而是在编写例如小助手脚本,这将很快变得相关。(例如,我更喜欢Ruby而不是Bash。)(3)&.让调试更简单如果调用不存在的方法,安全遍历运算符将抛出错误

ruby - 有没有一种简单的方法可以在 Ruby 中获取图像尺寸?

我正在寻找一种无需使用ImageMagick或ImageScience(运行SnowLeapard)即可在Ruby中获取图像文件的宽度和高度尺寸的简单方法。 最佳答案 截至2012年6月,FastImage其中“通过根据需要尽可能少地获取给定uri来找到图像的大小或类型”是一个不错的选择。它适用于本地镜像和远程服务器上的图像。自述文件中的IRB示例:require'fastimage'FastImage.size("http://stephensykes.com/images/ss.com_x.gif")=>[266,56]#wid

网络安全入门书籍推荐

计算机网络网络安全,计算机网络肯定是非常重要的存在。作为基础阶段,这一小节主要从宏观上学习计算机网络,而不是死扣某一个协议的某些字段意义。首先从局域网出发,了解计算机通信的基本网络——以太网,局域网内是如何通信的?集线器、交换机有什么区别?MAC地址、IP地址、子网、子网掩码分别是做什么用的?​随后引出更大的广域网、互联网,什么是网络通信协议,通信协议分层的问题,通过七层和四层模型快速建立起计算机网络的基础概念,各层协议的作用,分别有哪些协议,这些协议在当今的互联网中具体是怎么应用的。Web基础网络渗透中非常重要的一个组成部分就是Web安全,要学习Web安全,得先从Web前端基础开始入手。这一

ruby - 线程安全 : Class Variables in Ruby

在Ruby中对类变量执行写入/读取操作不是线程安全的。对实例变量执行写入/读取似乎是线程安全的。也就是说,对类或元类对象的实例变量执行写入/读取是否线程安全?这三个(人为的)示例在线程安全方面有何区别?示例1:相互排斥classBestUser#(singletonclass)@@instance_lock=Mutex.new#Memoizeinstancedefself.instance@@instance_lock.synchronizedo@@instance||=bestendendend示例2:实例变量存储classBestUser#(singletonclass)#Memo