使用FileUpload控件上传图片并自动生成缩略图、自动生成带文字和图片的水印图
作者:Tecsun 日期:2007-03-18
字体大小: 小 中 大
文借助vs2005中自带的FileUpload控件实现图片文件的上传并生成缩略图。
实现过程:选择图片上传成功后,取得已经存在服务器的文件生成缩略图,并且判断是否是图片类型的文件,这个的判断可以在程序中修改,本程序只是判断了“image/bmp”、“image/gif”、“image/pjpeg”三种类型。
代码如下:
upfile.aspx文件
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="upfile.aspx.cs" Inherits="upfile_upfile" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>无标题页</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:FileUpload ID="FileUpload1" runat="server" />
<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="上传" /><br />
<asp:Label ID="Label1" runat="server"></asp:Label></div>
</form>
</body>
</html>
upfile.aspx.cs文件
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.IO;
public partial class upfile_upfile : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{ }
protected void Button1_Click(object sender, EventArgs e)
{
if (FileUpload1.HasFile)
{
string fileContentType = FileUpload1.PostedFile.ContentType;
if (fileContentType == "image/bmp" || fileContentType == "image/gif" || fileContentType == "image/pjpeg")
{
string name = FileUpload1.PostedFile.FileName; // 客户端文件路径
FileInfo file = new FileInfo(name);
string fileName = file.Name; // 文件名称
string fileName_s = "s_" + file.Name; // 缩略图文件名称
string fileName_sy = "sy_" + file.Name; // 水印图文件名称(文字)
string fileName_syp = "syp_" + file.Name; // 水印图文件名称(图片)
string webFilePath = Server.MapPath("file/" + fileName); // 服务器端文件路径
string webFilePath_s = Server.MapPath("file/" + fileName_s); // 服务器端缩略图路径
string webFilePath_sy = Server.MapPath("file/" + fileName_sy); // 服务器端带水印图路径(文字)
string webFilePath_syp = Server.MapPath("file/" + fileName_syp); // 服务器端带水印图路径(图片)
string webFilePath_sypf = Server.MapPath("file/shuiyin.jpg"); // 服务器端水印图路径(图片)
if (!File.Exists(webFilePath))
{
try
{
FileUpload1.SaveAs(webFilePath); // 使用 SaveAs 方法保存文件
AddShuiYinWord(webFilePath, webFilePath_sy);
AddShuiYinPic(webFilePath, webFilePath_syp, webFilePath_sypf);
MakeThumbnail(webFilePath, webFilePath_s, 130, 130, "Cut"); // 生成缩略图方法
Label1.Text = "提示:文件“" + fileName + "”成功上传,并生成“" + fileName_s + "”缩略图,文件类型为:" + FileUpload1.PostedFile.ContentType + ",文件大小为:" + FileUpload1.PostedFile.ContentLength + "B";
}
catch (Exception ex)
{
Label1.Text = "提示:文件上传失败,失败原因:" + ex.Message;
}
}
else
{
Label1.Text = "提示:文件已经存在,请重命名后上传";
}
}
else
{
Label1.Text = "提示:文件类型不符";
}
}
}
/**//// <summary>
/// 生成缩略图
/// </summary>
/// <param name="originalImagePath">源图路径(物理路径)</param>
/// <param name="thumbnailPath">缩略图路径(物理路径)</param>
/// <param name="width">缩略图宽度</param>
/// <param name="height">缩略图高度</param>
/// <param name="mode">生成缩略图的方式</param>
public static void MakeThumbnail(string originalImagePath, string thumbnailPath, int width, int height, string mode)
{
System.Drawing.Image originalImage = System.Drawing.Image.FromFile(originalImagePath);
int towidth = width;
int toheight = height;
int x = 0;
int y = 0;
int ow = originalImage.Width;
int oh = originalImage.Height;
switch (mode)
{
case "HW"://指定高宽缩放(可能变形)
break;
case "W"://指定宽,高按比例
toheight = originalImage.Height * width / originalImage.Width;
break;
case "H"://指定高,宽按比例
towidth = originalImage.Width * height / originalImage.Height;
break;
case "Cut"://指定高宽裁减(不变形)
if ((double)originalImage.Width / (double)originalImage.Height > (double)towidth / (double)toheight)
{
oh = originalImage.Height;
ow = originalImage.Height * towidth / toheight;
y = 0;
x = (originalImage.Width - ow) / 2;
}
else
{
ow = originalImage.Width;
oh = originalImage.Width * height / towidth;
x = 0;
y = (originalImage.Height - oh) / 2;
}
break;
default:
break;
}
//新建一个bmp图片
System.Drawing.Image bitmap = new System.Drawing.Bitmap(towidth, toheight);
//新建一个画板
System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap);
//设置高质量插值法
g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;
//设置高质量,低速度呈现平滑程度
g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
//清空画布并以透明背景色填充
g.Clear(System.Drawing.Color.Transparent);
//在指定位置并且按指定大小绘制原图片的指定部分
g.DrawImage(originalImage, new System.Drawing.Rectangle(0, 0, towidth, toheight),
new System.Drawing.Rectangle(x, y, ow, oh),
System.Drawing.GraphicsUnit.Pixel);
try
{
//以jpg格式保存缩略图
bitmap.Save(thumbnailPath, System.Drawing.Imaging.ImageFormat.Jpeg);
}
catch (System.Exception e)
{
throw e;
}
finally
{
originalImage.Dispose();
bitmap.Dispose();
g.Dispose();
}
}
/**//// <summary>
/// 在图片上增加文字水印
/// </summary>
/// <param name="Path">原服务器图片路径</param>
/// <param name="Path_sy">生成的带文字水印的图片路径</param>
protected void AddShuiYinWord(string Path, string Path_sy)
{
string addText = "测试水印";
System.Drawing.Image image = System.Drawing.Image.FromFile(Path);
System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(image);
g.DrawImage(image, 0, 0, image.Width, image.Height);
System.Drawing.Font f = new System.Drawing.Font("Verdana", 16);
System.Drawing.Brush b = new System.Drawing.SolidBrush(System.Drawing.Color.Blue);
g.DrawString(addText, f, b, 15, 15);
g.Dispose();
image.Save(Path_sy);
image.Dispose();
}
/**//// <summary>
/// 在图片上生成图片水印
/// </summary>
/// <param name="Path">原服务器图片路径</param>
/// <param name="Path_syp">生成的带图片水印的图片路径</param>
/// <param name="Path_sypf">水印图片路径</param>
protected void AddShuiYinPic(string Path, string Path_syp, string Path_sypf)
{
System.Drawing.Image image = System.Drawing.Image.FromFile(Path);
System.Drawing.Image copyImage = System.Drawing.Image.FromFile(Path_sypf);
System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(image);
g.DrawImage(copyImage, new System.Drawing.Rectangle(image.Width - copyImage.Width, image.Height - copyImage.Height, copyImage.Width, copyImage.Height), 0, 0, copyImage.Width,copyImage.Height, System.Drawing.GraphicsUnit.Pixel);
g.Dispose();
image.Save(Path_syp);
image.Dispose();
}
}
文章来自: 本站原创
引用通告地址: http://blog.nwtbb.cn/trackback.asp?tbID=326
分享到:
相关推荐
然后,定义几个字符串变量来存储不同处理后的文件名:原始文件名、缩略图文件名、带有文字水印的文件名和带有图片水印的文件名。 使用Server.MapPath方法将相对URL转换为服务器上的绝对路径,以便保存上传的文件。...
### FileUpload 控件上传图片并自动生成缩略图、自动生成带文字和图片的水印 #### 概述 在Web开发中,处理用户上传的图片是一个常见的需求。特别是对于那些涉及图片展示的网站(如博客、电子商务平台等),不仅...
### ASP.NET 使用FileUpload控件上传图片并自动生成缩略图、自动生成带文字水印和图片水印 #### 概述 在 ASP.NET 应用程序开发中,经常需要处理用户上传的文件,尤其是图片文件。本篇教程将详细介绍如何使用 ASP...
本篇将详细讲解如何使用ASP.NET中的FileUpload控件来实现图片上传,并结合C#后端代码自动生成带有文字和图片水印的缩略图。 首先,`FileUpload`控件是ASP.NET提供的一种用于上传文件的服务器控件。在HTML页面中,...
在给定的文档中,我们讨论的是如何使用ASP.NET中的FileUpload控件来实现一个功能,即用户上传图片后,系统自动创建缩略图并添加文字或图片水印。以下是对这一过程的详细解释: 首先,`<asp:FileUpload>`控件在HTML...
该文档是关于在ASP.NET环境下使用FileUpload控件实现图片上传,并进行图片处理,包括生成缩略图以及添加文字和图片水印的功能。下面将详细解释这个过程中的关键知识点: 1. **FileUpload控件**:ASP.NET中的...
在本示例中,我们看到一个使用ASP.NET创建的网页,该网页允许用户上传图片,并在后台处理上传的图片,生成缩略图以及带有文字和图片水印的新图像。以下是这个过程中涉及的关键知识点: 1. **FileUpload控件**: - ...
在ASP.NET平台中,开发一个能够处理上传图片并生成缩略图、添加图片水印以及文字水印的功能是一项常见的需求。这个"上传图片生成缩略图、图片水印、文字水印_aspx开发教程.rar"文件很可能是包含了一系列的源代码、...
在ASP.NET中,实现图片上传、自动生成缩略图以及添加水印的功能是常见的需求,尤其是在构建内容管理系统或电子商务网站时。以下将详细介绍这些技术点。 1. 图片上传: ASP.NET提供了多种方法来处理文件上传。最...
根据给定的文件信息,我们可以总结出以下关于在C#中处理图片,包括上传、生成缩略图以及添加文字或图像水印的关键知识点: ### C#上传图片 在Web开发中,图片上传是一项常见的功能。在ASP.NET中,可以通过`<asp:...
在本资源"ASP.NET源码——上传图片生成缩略图、图片水印、文字水印.zip"中,包含了实现图片处理功能的源代码,主要涵盖了以下几个关键知识点: 1. 图片上传: 在ASP.NET中,可以使用HttpPostedFileBase对象来处理...
在ASP.NET开发中,处理图像是一项常见的任务,包括上传图片、生成缩略图、添加水印(图片水印和文字水印)等。这个压缩包文件"ASP.NET-[其他类别]上传图片生成缩略图、图片水印、文字水印.zip"显然包含了一个示例...
通过以上步骤,我们可以构建一个完整的图片处理系统,实现用户上传图片、生成缩略图,并添加文字或图片水印的功能。在实际项目中,还可以根据需求进行扩展,例如添加图片裁剪、旋转等功能,或者结合数据库存储图片元...
### ASP.NET 图片上传生成缩略图和水印的知识点详解 #### 一、ASP.NET 图片上传原理 在 ASP.NET 开发中,图片上传是一个常见的功能需求。它主要涉及前端用户界面的设计以及后端逻辑处理。前端通常利用 `FileUpload...
这个"asp.net图片上传(水印、缩略图、远程保存)源码"提供了一套完整的解决方案,涵盖了图片处理的几个重要方面。 首先,图片上传功能涉及到客户端与服务器端的交互。在ASP.NET中,可以使用FileUpload控件来实现用户...
在本文中,我们将深入探讨如何使用Visual Studio 2005和ASP.NET技术来生成缩略图和水印。在ASP.NET开发环境中,这是一项常见的需求,尤其在处理图像上传和展示时。以下是你需要知道的关键知识点: 1. **ASP.NET Web...
ASP.NET图片上传加水印EVPIc增强版是一款基于.NET框架的应用实例,它提供了一整套解决方案,用于处理用户在网站上上传图片的过程,包括图片的上传、添加水印、生成缩略图以及远程保存等功能。这个源代码库旨在帮助...
服务器端接收到请求后,处理图片数据,如保存到指定目录、调整尺寸、生成缩略图等,并返回响应信息,更新页面状态。 2. 实现方式: - AJAXUpload:使用jQuery插件,如jQuery File Upload,可以实现无刷新的图片...