ASP.NET动态添加水印类
WaterMarke.cs 类 code
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;
/// <summary>
/// WaterMarker 的摘要说明
/// </summary>
public class WaterMarker : IHttpHandler
{
public WaterMarker()
{
//
// TODO: 在此处添加构造函数逻辑
//
}
public bool IsReusable
{
get { return true; }
}
public void ProcessRequest(HttpContext context)
{
//获取请求的物理路径
string imagePath = context.Request.PhysicalPath;
System.Drawing.Image image = null;
//判断指定的物理路径是否存在
if (File.Exists(imagePath))
{
//定义水印文字
string text = "本图片来自夏楚枫的博客";
//定义水印文字字体的大小
int fontSize = 12;
//水印文字字体
Font font = new Font("宋体", fontSize);
//根据图片的物理路径加载图片
image = System.Drawing.Image.FromFile(imagePath);
Graphics g = Graphics.FromImage(image);
//获取要绘制水印文字所需要区域的大小
SizeF size = g.MeasureString(text, font);
if (size.Width > image.Width || size.Height > image.Height)
{
//如果要显示图片的尺寸都不足以显示按照指定文字字体来添加水印
//可以减小的字体的大小或者不添加水印(太小了没办法添加嘛)
}
else
{
//添加水印文字
Brush br = Brushes.Red;
g.DrawString(text, font, br, image.Width - size.Width, image.Height - size.Height);
g.Dispose();
}
}
else //如果不存在指定一个默认的图片进行显示
{
imagePath = context.Server.MapPath("~/image/default.jpg");
image = System.Drawing.Image.FromFile(imagePath);
}
image.Save(context.Response.OutputStream, ImageFormat.Jpeg);//将添加水印的图片输出
}
}
webconfig 中的配置
方法一:在所在文件夹添加一个webconfig文件,然后再在
<system.web>节点中添加下面的代码
<httpHandlers>
<!--对jpg文件添加水印-->
<add path="*" verb="*.jpg" type="WaterMarker"/>
<!--对bmp文件添加水印-->
<add verb="*" path="*.bmp" type="WaterMarker"/>
</httpHandlers>
方法二: 不在图片所在的文件夹下添加webconfig 而是直接在根目录下的webconfig中的配置
不用自动生成的那个<System.web>中配置 而是在<configuration>节点中添加如下代码
<location path="image">
<system.web>
<httpHandlers>
<!--对jpg文件添加水印-->
<add path="*" verb="*.jpg" type="WaterMarker"/>
<!--对bmp文件添加水印-->
<add verb="*" path="*.bmp" type="WaterMarker"/>
</httpHandlers>
</system.web>
</location>