教学思路ASP.Net之服务器控件: 四、FileUpload
在ASP.Net中如果想打开一个文件实现保存的效果,不能像Winform中使用openFileDialog控件,可以限制打开文件的类型,是否上传也必须通过另外一个控件的一个事件才能激发,如下Button2_Click.
winform中openFileDialog的使用方法如下,但是可参考性很少
openFileDialog1.Filter = "图片类型(*.jpg)|*.jpg";//限制打开文件的类型
if (openFileDialog1.ShowDialog() == DialogResult.OK) //根据对话框的选择结果判断是否上传
{
imageList1.Images.Add(Image.FromFile(openFileDialog1.FileName));//上传选中的文件
}
下面就让我们来学习一下FileUpLoad控件
![](/assets/blank.gif)
![](/assets/blank.gif)
1 //上传图片
2 //TextBox2为上传图片的自定义文件名.
3 protected void Button2_Click(object sender, EventArgs e)
4 {
5 if (FileUpload1.HasFile)//判读是否有文件
6 {
7 string filename = FileUpload1.FileName;//得到文件在本地的路径,及全路径
8 string kzm = filename.Substring(filename.LastIndexOf ("."));//将扩展名存放到变量kzm中
9 string uploadfilename = Server.MapPath("upload") +"\\"+TextBox2.Text+kzm;//得到文件在服务器上的路径和文件名和扩展名。
10 if (!kzm.Equals(".jpg")&& kzm != ".JPG") //判断扩展名
11 Response.Write("<script>alert('格式不正确');</script>");
12 if (File.Exists(uploadfilename)) //判断重名
13 Response.Write("<script>alert('图片重名,请更换图片名称!');</script>");
14 else
15 {
16 try
17 {
18 FileUpload1.SaveAs(uploadfilename);//将文件上传到服务器上。
19 Image1.ImageUrl = "upload\\" + TextBox2.Text + kzm;//图片路径为刚才上传的文件
20 Image1.Height = 300;//控制图片的大小
21 Image1.Width =250;
22 }
23 catch(Exception ex)
24 {
25 Response .Write ("<script>alert('"+ex.Message.ToString ()+"');</script>");
26 }
27 }
28 }
29 else
30 {
31 Response.Write("<script>alert('你还没选择上传的图片!');</script>");
32
33 }
34 }
下面的代码为在客户端书写对于上传控件文本格式的验证方法:
Code
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Upload.aspx.cs" Inherits="Upload" %>
<!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>Asp.net文件上传时的客户端简单验证</title>
<script language="javascript" >
function checkmes(id)
{
var filename = document.getElementById(id).value;
//验证是否选择文件
if(filename=="")
{
alert("请选择一个文件!");
return false;
}
//验证扩展名
var ex = filename.substring(filename.length-4);
if(ex!=".xls")
{
alert("你选择的文件类型不正确,请选择一个Excel文件!");
return false;
}
//最后提示信息
return confirm("你确定要上传此Excel文件?");
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<strong>Asp.net文件上传时的客户端简单验证<br />
<br />
<asp:FileUpload ID="fu_Excel" runat="server" Width="300px" />
<asp:Button ID="btn_Upload" runat="server" Text="上 传" OnClick="btn_Upload_Click" /> </strong></div>
</form>
</body>
</html>
在CS文件进行调用验证脚本的方法如下:
![](/assets/blank.gif)
![](/assets/blank.gif)
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;
public partial class Upload : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
btn_Upload.Attributes.Add("onclick", "javascript:return checkmes('" + fu_Excel.ClientID + "');");
}
protected void btn_Upload_Click(object sender, EventArgs e)
{
//上传文件的服务器端代码
}
}
对于上传文件的验证方式还可以采用ASP.Net中的验证控件,如下便是对于照片格式的验证方式。
![](/assets/blank.gif)
![](/assets/blank.gif)
<asp:FileUpload ID="FileUpload1" runat="server" />
<asp:RegularExpressionValidator
id="FileUpLoadValidator" runat="server"
ErrorMessage="上传图片只能为.jpg或.gif"
ValidationExpression="^([a-zA-Z]:\\)[0-9a-zA-Z\u4e00-\u9fa5\w\s\\!@#\$%^&\*\(\)_\+\-=\[\]{};'\,\.]*(.jpg|.JPG|.gif|.GIF|.bmp|.BMP)$"
ControlToValidate="FileUpload1"></asp:RegularExpressionValidator>
如果想改变上传文件的大小限制,要在config文件中,在 <system.web/> 节点内加入如下节点及其属性
<httpRuntime executionTimeout ="90" maxRequestLength="4096"/>
批量上传:
![](/assets/blank.gif)
![](/assets/blank.gif)
1
![](/assets/blank.gif)
2
![](/assets/blank.gif)
![](/assets/blank.gif)
![](/assets/blank.gif)
3
![](/assets/blank.gif)
4
![](/assets/blank.gif)
5
![](/assets/blank.gif)
![](/assets/blank.gif)
![](/assets/blank.gif)
6
![](/assets/blank.gif)
7
![](/assets/blank.gif)
8
![](/assets/blank.gif)
![](/assets/blank.gif)
![](/assets/blank.gif)
9
![](/assets/blank.gif)
10
![](/assets/blank.gif)
![](/assets/blank.gif)
![](/assets/blank.gif)
11
![](/assets/blank.gif)
12
![](/assets/blank.gif)
13
![](/assets/blank.gif)
14
![](/assets/blank.gif)
![](/assets/blank.gif)
![](/assets/blank.gif)
15
![](/assets/blank.gif)
16
![](/assets/blank.gif)
17
![](/assets/blank.gif)
18
![](/assets/blank.gif)
19
![](/assets/blank.gif)
20
![](/assets/blank.gif)
21
![](/assets/blank.gif)
转载于:https://www.cnblogs.com/wangfang224120999/archive/2009/05/31/1398948.html
教学思路ASP.Net之服务器控件: 四、FileUpload相关推荐
- asp.NET自定义服务器控件内部细节系列教程四
如大家要转载,请保留本人的版权: /* *Description:asp.NET自定义服务器控件内部细节系列教程 *Auther:崇崇-天真的好蓝 *MSN:chongchong2008@msn.co ...
- 矩阵位移法是用于求解杆系结构的计算机方法,结构力学的教学思路
结构力学的教学思路 2019-10-14 版权声明 举报文章 一.经典位移法(以下简称位移法)和矩阵位移法都是求解杆系结构的基本方法,是结构力学课程中两个十分重要的内容,两种方法都是结构力学课程中讲授 ...
- 三人英语计算机主题口语对话,计算机英语Web Quest主题教学思路(共3641字).doc
计算机英语Web Quest主题教学思路(共3641字) 计算机英语Web Quest主题教学思路(共3641字) 计算机英语课程教学长期以来采用以教师为主的传统教学模式,教学方法多为讲授法,教学组织 ...
- 教学思路SQL之入门习题《学生成绩》 五、使用视图完成多表查询
视图的概念: 视图对象是一个虚拟的表,虚拟表所包含的结果集是对一个或多个表的查询. 视图本身不保存这个结果集,而是保存查询的定义. 视图的定义是对已经存在表的查询. 使用视图和使用表很类似,可以把视图 ...
- ASP.NET 2.0使用FileUpload控件上传文件示例
在ASP.NET 2.0中使用FileUpload服务器控件很容易的就能将文件上传到服务器,一个简单的例子如下: aspx: 程序代码 <%@ Page Language="C#&qu ...
- asp.NET自定义服务器控件内部细节系列教程五
如大家要转载,请保留本人的版权: /* *Description:asp.NET自定义服务器控件内部细节系列教程 *Auther:崇崇-天真的好蓝 *MSN:chongchong2008@msn.co ...
- (教学思路 c#之类一)声明类和对象、定义类成员及其引用
上一节(教学思路 c#之面向对象二)初步理解面向对象的基本概念中,我没有提到任何的代码,只是用语言和实例来说明什么是类和对象以及面向对象的特性等基本概念,类是c#程序语言的重要核心,也是构建应用程序最 ...
- 小白开学Asp.Net Core《四》 —— 使用AspectCore-Framework
小白开学Asp.Net Core<四> -- 使用AspectCore-Framework 一.AspectCore-Frame ...
- asp.NET自定义服务器控件内部细节系列教程一
如大家要转载,请保留本人的版权: /* *Description:asp.NET自定义服务器控件内部细节系列教程 *Auther:崇崇-天真的好蓝 *MSN:chongchong2008@msn.co ...
最新文章
- 比较两个字符串是否相等
- 俄罗斯最新开源的牛掰数据库ClickHouse
- visual foxpro 程序员指南_如何平衡工作和生活的关系?程序员归来依旧是少年的好方法...
- ADS1.2开发环境创建与简要介绍
- 网络工程师常用英文单词和缩写翻译
- 带有天气预报的高大上web报表制作分享
- 55. Yii import class 与 对象创建
- Vijos 1041题:神风堂人数
- 9008刷机模式写入超时刷机帮_高通9008模式刷机,让小米刷机不再畏惧
- 如何安装Win10/Ubuntu双系统
- axure中继器求和_中继器使用场景(二):购物车金额实时求和
- NLP-文本摘要:“文本摘要”综述(Text Summarization)
- python图书销售系统
- 为什么苹果手机通话的时候不能录音?
- 求2的零次方 加 2的一次方 加2的二次方等等的和
- 企查查app sign算法破解(完结)
- micropython大小_Micropython进阶 | 如何用单片机制作鞋码匹配仪
- Golang底层原理学习笔记(一)
- 51单片机开关简单使用
- 仿抖音短视频APP双端系统源码+带教程/PHP的