Le filigrane servono a impedirci di rubare le nostre immagini.
Due modi per ottenere l'effetto filigrana
1) La filigrana può essere aggiunta quando l'utente carica.
a) Vantaggi: rispetto ai due metodi, il server invia questa immagine direttamente al cliente ogni volta che l'utente la legge.
b) Contro: distrugge l'immagine originale.
2) Attraverso il programma globale di elaborazione generale, quando l'utente richiede questa immagine, si aggiunge una filigrana.
a) Benefici: La foto originale non viene distrutta
b) Svantaggi: gli utenti devono affiancare le immagini richieste ogni volta che fanno una richiesta, sprecando le risorse del server.
- 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;
- }
- }
- }
- }
Copia codice Il codice file per waterH.ashx è il seguente:
Poi devi configurare il seguente nodo sul web.config:
Sotto il nodo system.web
<httpHandlers> <aggiungi verbo="*" path="Immagini/*.jpg" type="Watermark.waterH"/> </httpHandlers> All'inizio, i nodi che ho configurato erano:
<httpHandlers> <aggiungi verbo="*" path="Immagini/*.jpg" type="waterH"/> </httpHandlers> segnala un errore,
Configurazione errata
Descrizione: Si è verificato un errore durante l'elaborazione del profilo necessario per fornire servizi alla richiesta. Si prega di verificare i dettagli specifici dell'errore qui sotto e di modificare il file di configurazione di conseguenza.
Messaggio di errore dell'analizzatrice: Fallita la carica del tipo "waterH".
Errore della fonte:
Riga 15: <system.web> Riga 16<httpHandlers>: Riga 17: <aggiungi verbo="*" path="Immagini/*.jpg" type="waterH"/> Riga 18: </httpHandlers> Riga 19: <compilation debug="true" targetFramework="4.0" />
Infine, inwaterH con il nome del progetto!
Infine, allega una copia del codice sorgente:
Watermark.rar
(234.64 KB, Numero di download: 0, 售价: 2 粒MB)
|