您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。