• 文件上传中的错误文件上传及其命名


        文件上传的方法很多。上传代码附录在后。本文主要讨论上传文件的命名。
    文件上传后,仅仅把文件的原有名字作为上传后的名字,可能会发生重名的情况。因此,我才用将上传发生的时间添加到文件名中。以消除重名的情况发生。代码如下:
         int i = fileName.LastIndexOf(".");    //fileName是文件的原有名字
         newname = fileName.Insert(i,"("+DateTime.Now.ToString().Replace(":","")+")");
        一个名为bird.gif的文件在2005年10月10日10时10分10秒上传得文件名为bird(2005-10-10101010).gif
    在本地机器上测试一直没有出现问题。
    给客户安装后上传却总是不成功。最后发现原来日期的格式有了问题,在本地日期格式为2005-10-10,而客户机的日期格式却是05\10\10,结果同一个名为bird.gif的文件上传后的文件名变为bird(05\10\10101010).gif,系统会去寻找bird(05\10\10目录,并向它下面保存10101010).gif文件。事实上根本不存在bird(05\10\10目录,从而导致了错误发生。
        解决的办法:1分别取出年,月,日,分,秒,时作连接成一个字符串。
                            2通过产生一个随机数,放在文件名后。
                            Random ro = new Random();
                            long strNum = ro.Next(100000,999999);
    附文件上传的代码:(C#)

    UpLoad.aspx

    <!--StartFragment--><%@ Page language="c#" Codebehind="UpLoad.aspx.cs" AutoEventWireup="false" Inherits="WebPortal.Upload" %>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
    <HTML>
      <HEAD>
        <title>多文件上传</title>
        <script language="JavaScript">
        function addFile()
        {
        var str = '<INPUT type="file" size="50" NAME="File">'
        document.getElementById('MyFile').insertAdjacentHTML("beforeEnd",str)
        }
        </script>
      </HEAD>
      <body>
        <form id="form1" method="post" runat="server" enctype="multipart/form-data">
          <div align="center">
            <h3>多文件上传</h3>
            <P id="MyFile"><INPUT type="file" size="50" NAME="File"></P>
            <P>
              <input type="button" value="增加(Add)" onclick="addFile()">
              <input onclick="this.form.reset()" type="button" value="重置(ReSet)">
              <asp:Button Runat="server" Text="开始上传" ID="UploadButton"></asp:Button>
            </P>
            <P>
            <asp:Label id="strStatus" runat="server" Font-Names="宋体" Font-Bold="True" Font-Size="9pt"
              Width="500px" BorderStyle="None" BorderColor="White"></asp:Label>
            </P>
          </div>
        </form>
      </body>
    </HTML>

    UpLoad.aspx.cs

    using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Drawing; using System.Web; using System.Web.SessionState; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.HtmlControls; namespace WebPortal { /// <summary> /// UpLoad 的摘要说明。 /// 实现多文件上传 /// </summary> public class Upload : System.Web.UI.Page { protected System.Web.UI.WebControls.Button UploadButton; protected System.Web.UI.WebControls.Label strStatus; private void Page_Load(object sender, System.EventArgs e) { /// 在此处放置用户代码以初始化页面 if (this.IsPostBack) this.SaveImages(); } private Boolean SaveImages() { ///'遍历File表单元素 HttpFileCollection files = HttpContext.Current.Request.Files; /// '状态信息 System.Text.StringBuilder strMsg = new System.Text.StringBuilder(); strMsg.Append("上传的文件分别是:<hr color=red>"); try { for(int iFile = 0; iFile < files.Count; iFile++) { ///'检查文件扩展名字 HttpPostedFile postedFile = files[iFile]; string fileName, fileExtension; fileName = System.IO.Path.GetFileName(postedFile.FileName); if (fileName != "") { fileExtension = System.IO.Path.GetExtension(fileName); strMsg.Append("上传的文件类型:" + postedFile.ContentType.ToString() + "<br>"); strMsg.Append("客户端文件地址:" + postedFile.FileName + "<br>"); strMsg.Append("上传文件的文件名:" + fileName + "<br>"); strMsg.Append("上传文件的扩展名:" + fileExtension + "<br><hr>"); ///'可根据扩展名字的不同保存到不同的文件夹 ///注意:可能要修改你的文件夹的匿名写入权限。 postedFile.SaveAs(System.Web.HttpContext.Current.Request.MapPath("images/") + fileName); } } strStatus.Text = strMsg.ToString(); return true; } catch(System.Exception Ex) { strStatus.Text = Ex.Message; return false; } } #region Web 窗体设计器生成的代码 override protected void OnInit(EventArgs e) { // // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。 // InitializeComponent(); base.OnInit(e); } /// <summary> /// 设计器支持所需的方法 - 不要使用代码编辑器修改 /// 此方法的内容。 /// </summary> private void InitializeComponent() { this.ID = "Upload"; this.Load += new System.EventHandler(this.Page_Load); } #endregion } }
  • 相关阅读:
    python学习(十七) 扩展python
    python学习(十六) 测试
    python学习(十五) 屏幕抓取
    python学习(十四) 网络编程
    python学习(十三) 数据库支持
    python学习(十二) 图形化用户界面
    python学习(十一) 文件和流
    python学习(十) 自带电池
    方法编写经验总结
    如何编写方法
  • 原文地址:https://www.cnblogs.com/sutengcn/p/291485.html
Copyright © 2020-2023  润新知