如何实现C#文件自动上传

如何实现C#文件自动上传,第1张

在Web编程中,我们常需要把一些本地文件上传到Web服务器上,上传后,用户可以通过浏览器方便地浏览这些文件,应用十分广泛。

首先,在你棚圆氏的VisualC#webproject中增加一个上传用的WebForm,为了要腔明上传文件,需要在ToolBox中选择HTML类的FileField控件,将此控件加入到WebForm中,然而此时该控件还不是服务端控件,我们需要为它加上如下一段代码:<inputid=uploadfile1type=filesize=49runat=server>,这样它就成为服务端控件了,如果需要同时上传数个文件时,我们可以相应增加此控件。

需要注意的是代码中一定要把<form>的属性设置成为:

<formmethod=postencType=multipart/form-datarunat=server>

如果没有这个属性,就不能实现上传。

然后在此WebForm中增加一个WebForm类的Button,双击Button添加如下代码:

//上传图片的程序段

DateTimenow=DateTime.Now

//取现在时间到DataTime类的对象now中

stringstrBaseLocation=D:\\web\\FC\\pic\\

//这是文件将上传到的服务器的绝对目录

if(uploadfile1.PostedFile.ContentLength!=0)//判断选取对话框选取的文件长度是否为0

{uploadfile1.PostedFile.SaveAs(strBaseLocation+now.DayOfYear.ToString()+uploadfile1.PostedFile.ContentLength.ToString()+.jpg)

//执行上传,并自动根据日期和文件大小不同为文件命名,确保不重复

Label1.Text=图片1已经上传,文件名为:+now.DayOfYear.ToString()+uploadfile1.PostedFile.ContentLength.ToString()+.jpg

navigator.Insert(System.Xml.TreePosition.After,XmlNodeType.Element,pic1,,)

navigator.Insert(System.Xml.TreePosition.FirstChild,XmlNodeType.Text,pic1,,)

navigator.Value=now.DayOfYear.ToString()+uploadfile1.PostedFile.ContentLength.ToString()+.jpg

navigator.MoveToParent()}

上面的代码用链散于笔者开发的一个使用XML文件存储新闻信息的系统中,后面几句代码作用是写上传文件信息到XML文件中。如果要上传其他类型文件,只需要将jpg改为相应类型的后缀名即可,如改为doc即可上传Word文件,浏览器即可直接浏览上传的Word文件。

【注意事项】

1.上传文件不可以无限大

2.要注意IIS的安全性方面的配合

3.用VisualStudio的安装项目做安装程序的时候,请注意安装程序所在的绝对路径问题

4.注意文件上传后的重名问题。

第一种:经典的form和input上传。

设置form的aciton为后端页面,enctype="multipart/form-data",type=‘post’

<form action='http://www.ty2y.com/' enctype="multipart/form-data" type='post'><input type='file'><input type='hidden' name='userid'><input type='hidden' name='signature'><button>提交</button></form>

使用input选择文件,设置好其他input的值,点击提交,将文件数据及签名等认证信息发送到form设置的action对应的页面,浏览器也会跳转到该页面。触发form表单提交数据的方式有2种,一种是在页面上点击button按钮或<input

type='submit'>按钮触发,第二种是在js中执行form.submit()方法。

优点:使用简单方便,兼容性好,基本所有浏览器都支持。

缺点:1. 提交数据后页面会跳转(下面会讲如何禁止页面跳转)。

2.因为是浏览器发起的请求,不是一个ajax,所以前端无法知肆尺道什么时候上传结束。

3. form表单里发送除文件外的数据,一般是新建一个type=hidden的input,value=‘需要传的数据’,每发送一个数据就需要一个input,一旦多了就会使得dom看起来比较冗余。

小技巧:

form表单提交数据后会自动跳转到action指定的页面,为了禁止页面跳转,可以在页面中新建一个空的ifame,比如name='upload',然后设置form的target="Uploader",form有一个target的属性,规定在何处打开action,这样form提交数据后就会仍停留在当前页。代码如下:

<form action='http://www.jshaman.com/' enctype="multipart/form-data" type='post'  target="uploader1"><input type='file'><button>提交</button></form><ifrmae name='upload' id='uploader1'></iframe>

这样写的另一个好处是,可以知道什么时候上传完成并接收到后端的回调结果。比如上面这个例子,文件数据发送到了

'uploadFile.php',假设该页面处理完数据后返回了一个地址,该地址会被写入到之前谨兄的iframe中。所以在ifame的onload函数触发时,也就是上传完成后,可以在iframe中读取到后端返回的数据。

var  iframe = document.getElementById('upload1')

iframe.onload = function () {  

                    var doc = window.frames['uploader1'].document                    var pre = doc.getElementsByTagName('pre')      祥雹袭              var obj = JSON.parse(pre[0].innerHTML)

                }

使用这种方法时需要注意,iframe有跨域限制,创建出来的iframe的地址如果和当前页面地址不同源,会报错。这种情况下,建议大家在iframe的onload函数中,再次向后端请求一个接口获取文件地址,而不是直接去iframe里读取。或者返回这样的数据。

<script type="text/javascript">window.top.window[callback](data)</script>

callback是和前端约定好的名字,上传完成后触发该函数并返回后端数据。

第二种:使用formData上传。

用js构造form表单的数据,简单高效,但最低只兼容IE10,所以需要兼容IE9的童鞋们就略过这个方法吧。

html:

<input type='file'>

js:

var formData = new FormData()

formData.append("userid", userid)

formData.append("signature", signature)

formData.append("file", file) //file是blob数据//再用ajax发送formData到服务器即可,

注意一定要是post方式上传

说明:第一种方法提到了创建多个type=‘hidden’的input来发送签名数据,这儿可以用formData.append方法来代替该 *** 作,避免了dom中有多个input的情况出现。最后将file数据也append到formData发送到服务器即可完成上传。

优点:由于这种方式是ajax上传,可以准确知道什么时候上传完成,也可以方便地接收到回调数据。

缺点:兼容性差

第三种:使用fileReader读取文件数据进行上传。

HTML5的新api,兼容性也不是特别好,只兼容到了IE10。

var fr = new FileReader()

                fr.readAsDataURL(file)

                fr.onload = function (event) {                    var data= event.target.result //此处获得的data是base64格式的数据                    img.src = data

                    ajax(url,{data} ,function(){})

                }

上面获得的data可以用来实现图片上传前的本地预览,也可以用来发送base64数据给后端然后返回该数据块对应的地址。

优点: 同第二种

缺点:一次性发送大量的base64数据会导致浏览器卡顿,服务器端接收这样的数据可能也会出现问题。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12274954.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存