Ūdenszīmes ir paredzētas, lai neļautu mums nozagt mūsu attēlus.
Divi veidi, kā sasniegt ūdenszīmes efektu
1) Ūdenszīmi var pievienot, kad lietotājs augšupielādē.
a) Priekšrocības: Salīdzinot ar 2 metodēm, serveris nosūta šo attēlu tieši klientam katru reizi, kad lietotājs to lasa.
b) Mīnusi: Iznīcina oriģinālo attēlu.
2) Izmantojot globālo vispārējās apstrādes programmu, kad lietotājs pieprasa šo attēlu, pievienojiet ūdenszīmi.
a) Ieguvumi: oriģinālais attēls netiek iznīcināts
b) Trūkumi: Lietotājiem katru reizi, kad viņi veic pieprasījumu, ir jāatzīmē pieprasītie attēli, kas izšķērdē servera resursus.
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Drawing;
- using System.IO;
- namespace Watermark
- {
- /// <summary>
- /// waterH 的摘要说明
- /// </summary>
- public class waterH : IHttpHandler
- {
- public waterH()
- { }
- private const string WATERMARK_URL = "~/Test/watermark.png";
- private const string DEFAULTIMAGE_URL = "~/Test/watermark.png";
- public void ProcessRequest(HttpContext context)
- {
- System.Drawing.Image Cover;
- if (File.Exists(context.Request.PhysicalPath))
- {
- Cover = Image.FromFile(context.Request.PhysicalPath);
- Image watermark = Image.FromFile(context.Request.MapPath(WATERMARK_URL));
- Graphics g = Graphics.FromImage(Cover);
- g.DrawImage(watermark, new Rectangle(Cover.Width - watermark.Width, Cover.Height - watermark.Height, watermark.Width, watermark.Height), 0, 0, watermark.Width, watermark.Height, GraphicsUnit.Pixel);
- g.Dispose();
- watermark.Dispose();
- }
- else
- {
- Cover = Image.FromFile(context.Request.MapPath(DEFAULTIMAGE_URL));
- }
- context.Response.ContentType = "images/jpeg";
- Cover.Save(context.Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
- Cover.Dispose();
- context.Response.End();
- }
- public bool IsReusable
- {
- get
- {
- return false;
- }
- }
- }
- }
Kopēt kodu waterH.ashx faila kods ir šāds:
Tad jums ir jākonfigurē šāds mezgls web.config:
Zem mezgla system.web
<httpHandlers> <add verb="*" path="Images/*.jpg" type="Watermark.waterH"/> </httpHandlers> Sākumā konfigurētie mezgli bija:
<httpHandlers> <add verb="*" path="Images/*.jpg" type="waterH"/> </httpHandlers> ziņos par kļūdu,
Nepareiza konfigurācija
Apraksts: apstrādājot profilu, kas nepieciešams, lai sniegtu pakalpojumus pieprasījumam, radās kļūda. Lūdzu, pārbaudiet tālāk norādīto informāciju par kļūdu un attiecīgi modificējiet konfigurācijas failu.
Analizatora kļūdas ziņojums: neizdevās ielādēt tipu "waterH".
Avota kļūda:
15. rinda: <system.web> 16. rinda<httpHandlers>: 17. rinda: <add verb="*" path="Images/*.jpg" type="waterH"/> 18. rinda: </httpHandlers> 19. rinda: <compilation debug="true" targetFramework="4.0" />
Visbeidzot,waterH ar projekta nosaukumu!
Visbeidzot, pievienojiet avota koda kopiju:
Watermark.rar
(234.64 KB, Lejupielādes skaits: 0, 售价: 2 粒MB)
|