这篇文章主要为大家展示了“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继承IHttpHandler接口如何实现给网站图片添加水印功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。