Les filigranes sont conçus pour nous empêcher de voler nos images.
Deux façons d’obtenir l’effet de filigrane
1) Un filigrane peut être ajouté lorsque l’utilisateur télécharge.
a) Avantages : Comparé aux deux méthodes, le serveur envoie cette image directement au client à chaque lecture de l’utilisateur.
b) Inconvénients : Détruit l’image originale.
2) Grâce au programme global de traitement général, lorsque l’utilisateur demande cette image, il faut ajouter un filigrane.
a) Avantages : L’image originale n’est pas détruite
b) Inconvénients : Les utilisateurs doivent filigraner les images demandées à chaque demande, ce qui gaspille les ressources du serveur.
- 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;
- }
- }
- }
- }
Code de copie Le code de fichier pour waterH.ashx est le suivant :
Ensuite, vous devez configurer le nœud suivant sur le web.config :
Sous le nœud system.web
<httpHandlers> <ajouter verbe="* » chemin="Images/*.jpg » type="Watermark.waterH"/> </httpHandlers> Au début, les nœuds que j’ai configurés étaient :
<httpHandlers> <ajouter verbe="* » chemin="Images/*.jpg » type="waterH"/> </httpHandlers> signalera une erreur,
Mauvaise configuration
Description : Une erreur s’est produite lors du traitement du profil requis pour fournir les services à la demande. Veuillez vérifier les détails spécifiques de l’erreur ci-dessous et modifier le fichier de configuration en conséquence.
Message d’erreur de l’analyseur : Échec de charger le type « waterH ».
Erreur de source :
Ligne 15 : <system.web> Ligne 16 <httpHandlers>: Ligne 17 : <ajouter verbe="* » chemin="Images/*.jpg » type="waterH"/> Ligne 18 : </httpHandlers> Ligne 19 : <compilation debug="true » targetFramework="4.0 » />
Enfin, danswaterH avec le nom du projet !
Enfin, joignez une copie du code source :
Watermark.rar
(234.64 KB, Nombre de téléchargements: 0, 售价: 2 粒MB)
|