rails3 paperclip 添加水印

本文介绍如何在Rails应用中使用Paperclip gem为上传的图片添加水印效果。通过自定义处理器并配置数据库迁移,实现了不同尺寸的图片带有指定位置的水印。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[url]https://gist.github.com/784445[/url]

rails new example -d=mysql


cd example


Gemfile 添加
gem 'paperclip'


bundle install


新建文件/lib/paperclip_processors/watermark.rb
module Paperclip
class Watermark < Thumbnail
def initialize(file, options = {}, attachment = nil)
super
@watermark_path = options[:watermark_path]
@position = options[:position].nil? ? "SouthEast" : options[:position]
end

def make
src = @file
dst = Tempfile.new([@basename].compact.join("."))
dst.binmode

return super unless @watermark_path

params = "-gravity #{@position} #{transformation_command.join(" ")} #{@watermark_path} :source :dest"

begin
success = Paperclip.run("composite", params, :source => "#{File.expand_path(src.path)}[0]", :dest => File.expand_path(dst.path))
rescue PaperclipCommandLineError
raise PaperclipError, "There was an error processing the watermark for #{@basename}" if @whiny
end

dst
end
end
end


rails g scaffold image title:string


rails g paperclip image image


rake db:create && rake db:migrate


app/models/image.rb
require 'paperclip_processors/watermark'
class Image < ActiveRecord::Base
has_attached_file :image,
:processors => [:watermark],
:styles => {
:medium => {
:geometry => "300x300>",
:watermark_path => "#{Rails.root}/public/images/rails.png"
},
:thumb => "100x100>",
}
end


app/views/images/_form.html.erb
<%= form_for(@image,:html => {:multipart => true}) do |f| %>
<% if @image.errors.any? %>
<div id="error_explanation">
<h2><%= pluralize(@image.errors.count, "error") %> prohibited this image from being saved:</h2>

<ul>
<% @image.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div>
<%= f.label :title %>
<%= f.text_field :title %>
</div>
<div>
<%= f.label :image %>
<%= f.file_field :image %>
</div>

<div class="actions">
<%= f.submit %>
</div>
<% end %>


app/views/show.html.erb
<p id="notice"><%= notice %></p>

<p>medium:</p>
<%= image_tag(@image.image.url(:medium)) %>
<%= link_to 'Edit', edit_image_path(@image) %> |
<%= link_to 'Back', images_path %>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值