的值(一般这个值中包含了两个信息,分别是[路径+]文件名以及ContentType)有所差别(其本质除了浏览器的行为因素外,还有默认安全设置的问题)。" />

关于WebForms下面FileUpload控件获取FileName的一个注意点

原创|其它|编辑:郝浩|2009-09-01 10:36:57.000|阅读 1515 次

概述:于是问题已经本明了了:不同的浏览器对于post的值(一般这个值中包含了两个信息,分别是[路径+]文件名以及ContentType)有所差别(其本质除了浏览器的行为因素外,还有默认安全设置的问题)。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

    这个问题源自一位热心而且踏实的读者,发现《ASP.NET 3.5+SQL Server网站模块化开发全程实录》中第117页的一段实例代码:

 

using System;
using System.Web;
using System.Web.UI;
using System.Web.UI.HtmlControls;

public partial class upLoadFile : System.Web.UI.Page
{
    
protected void UpLoadFile_Click(Object sender, EventArgs e)
    {
        
        FileSize.InnerHtml 
= UpLoadFile.PostedFile.ContentLength.ToString();
        
//获取上传文件名
        String theFileDir = UpLoadFile.PostedFile.FileName;//获取文件名的完整路径
        
    }
}

    经过这位朋友的严格跟踪测试,发现PostedFile.FileName并不是“获取文件名的完整路径”,而只是文件名。
    起初我也愣了一下,于是赶紧测试,发现确实是文件名,而不是完整路径。但是在我记忆中,非常确定这个方法是可以获取到完整路径的。于是静下心来一想,真相只有一个——浏览器!
    着手验证。
    上传本地物理路径的文件D:\testupload.jpg。
        用IE7/IE8获取PostedFile.FileName结果如下:testupload.jpg。
        用IE6获取PostedFile.FileName结果如下:D:\testupload.jpg。
    同时使用HttpWatch跟踪了一下,发现从Post的环节上,就已经显现出上述差别:
        IE7/8:filename="testupload.jpg" Content-Type: image/pjpeg
        IE6:filename="D:\testupload.jpg" Content-Type: image/pjpeg

    于是问题已经本明了了:不同的浏览器对于post<input type="file" />的值(一般这个值中包含了两个信息,分别是[路径+]文件名以及ContentType)有所差别(其本质除了浏览器的行为因素外,还有默认安全设置的问题)。

    因此得出一个更加周全的处理建议:使用FileUpload控件在获取文件名的时候,尽量使用Path.GetFileName(UpLoadFile.PostedFile.FileName)这样的方法,将其视同完整路径来处理,这样可以使任何浏览器下面都能得到正确的文件名,而不会包含路径(书本中用了一个比较繁琐的过程过滤路径,仅供学习之用:))。
    同时,也不会要再为获取不到物理路径而感到奇怪了,如果你真的那么好奇,不妨请js帮忙吧,我想这对大多数程序员都不是什么难事了。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:博客园

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP