asp.net继承IHttpHandler接口实现给网站图片添加水印功能实例

发布时间:2022-04-16 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了asp.net继承IHttpHandler接口实现给网站图片添加水印功能实例脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了asp.net继承IHttpHandler接口实现给网站图片添加水印功能。分享给大家供大家参考,具体如下:

先展示图片效果:

1. 在App_Code下添加类文件,命名为ImageSY 文件内容如下

public class ImageSY : IHttpHandler
{
  public ImageSY()
  {
    //
    //TODO: 在此处添加构造函数逻辑
    //
  }
  #region IHttpHandler 成员
  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 = 22;
      //水印文字字体
      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 brush = Brushes.red;
        g.DrawString(text, font, brush, image.Width - size.Width, image.Height - size.Height);
        g.Dispose();
      }
    }
    else
    {
    }
    image.Save(context.Response.OutputStream, ImageFormat.JPEg);
  }
  #endregion
}

2. 配置Webconfig,添加Location新节点

<location path="images">
 <system.web>
  <httpHandlers>
  <!---对jpg文件添加水印-->
  <add verb="*" type="ImageSY" path="*.jpg"/>
  <add verb="*" type="ImageSY" path="*.gif"/>
  <add verb="*" type="ImageSY" path="*.bmp"/>
  </httpHandlers>
 </system.web>
 </location>

3. 测试,新建aspx页面,显示图片,水印就会自动加上了

更多关于asp.net相关内容感兴趣的读者可查看本站专题:《asp.net操作json技巧总结》、《asp.net字符串操作技巧汇总》、《asp.net操作XML技巧总结》、《asp.net文件操作技巧汇总》、《asp.net ajax技巧总结专题》及《asp.net缓存操作技巧总结》。

希望本文所述对大家asp.net程序设计有所帮助。

脚本宝典总结

以上是脚本宝典为你收集整理的asp.net继承IHttpHandler接口实现给网站图片添加水印功能实例全部内容,希望文章能够帮你解决asp.net继承IHttpHandler接口实现给网站图片添加水印功能实例所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。