• Webform(文件上传)


    1.HTML编码:

    <input type="file" />

    2.控件:FileUpload

    它是用来选择要上传的文件,还需要一个按钮来将选中的文件上传到服务器上

    string path = "images/" + FileUpload1.FileName;
    FileUpload1.SaveAs(Server.MapPath(path));

    优化1:文件保留原有名称和后缀

    string path = "images/" + FileUpload1.FileName;

    优化2:防止重名,或是同一时间多个人同时上传同一名称文件

    string path = "images/" + DateTime.Now.ToString("yyyyMMddhhssmmms") + Request.Cookies["ures"].Value + FileUpload1.FileName;

    优化3:可以上传大文件,默认是4MB,4096KB
    方法:扩容

    在Web.config中的system.web标记中添加下面一句:
    <httpRuntime maxRequestLength="扩容大小" />

    注意:不要扩的太大,因为如果多人同时上传大文件,可能会造成服务器内存溢出,导致服务器崩溃。

    优化4:超过上传要求的大小,阻止上传并提示文件过大
    C#端解决:

    if( FileUpload1.PostedFile.ContentLength>(1024*1024*10))
    {
    Labei1.Text="文件超过10M,不要上传这么大的!";
    return;
    }

    C#端不好用,因为如果文件超过了最大长度,C#端是限制不住的,会直接将程序崩溃

    JS端:

    复制代码
    document.getElementById("Button1").onclick = function () {
            //取出上传元素
            var fi1 = document.getElementById("FileUpload1");
            //判断是否有选中的文件
            if (fi1.value.length <= 0) {
                alert('请选择要上传的文件!');
                return false;
            }
            else {
                //验证选中的文件长度是否满足条件
                if (fi1.files[0].size > (1024 * 1024 * 10))
                {
                    alert('文件过大,不允许上传!');
                    return false;
                }
            }
        };
    复制代码

    优化5:限制可以选择的文件类型

    在Fileupload属性里加 accept=".jpg,.jpeg,.png"

    断点续传:

    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 DFile : System.Web.UI.Page 
    { 
    protected void Page_Load(object sender, EventArgs e) 
    { 
    } 
    protected void LinBtnDFile_Click(object sender, EventArgs e) 
    { 
    // 创建一比特数组 
    byte[] buffer = new Byte[10240]; 
    // 指定要下载文件的路径. 
    string filePath = @"D:爱智旮旯.rar"; 
    // 或取文件名包括扩展名 
    string fileName = Path.GetFileName(filePath); 
    Stream fileStream = null; 
    try 
    { 
    // 打开文件 
    fileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read); 
    Response.Clear(); 
    // 获取文件的大小 
    long fileSize = fileStream.Length; 
    long sum = 0; 
    if (Request.Headers["Range"] != null) 
    { 
    Response.StatusCode = 206; // 表示返回到客户端的 HTTP 输出状态的整数。默认值为 200。 
    sum = long.Parse(Request.Headers["Range"].Replace("bytes=", "").Replace("-", "")); 
    } 
    if (sum != 0) 
    { 
    Response.AddHeader("Content-Range", "bytes " + sum.ToString() + "-" + ((long)(fileSize)).ToString() + "/" + fileSize.ToString()); 
    } 
    // 获取部分http头信息 
    Response.AddHeader("Content-Length", ((long)(fileSize - sum)).ToString()); 
    Response.ContentType = "application/octet-stream"; 
    //获取文件来源 
    Response.AddHeader("Content-Disposition", "attachment; filename=" + HttpUtility.UrlEncode(Request.ContentEncoding.GetBytes(fileName))); 
    // Response.Flush(); 
    fileStream.Position = sum; //设置当前流位置 
    fileSize = fileSize - sum; 
    // 当文件大小大于0是进入循环 
    while (fileSize > 0) 
    { 
    // 判断客户端是否仍连接在服务器 
    if (Response.IsClientConnected) 
    { 
    // 获取缓冲区中的总字节数. 
    int length = fileStream.Read(buffer, 0, 10240); 
    // 写入数据 
    Response.OutputStream.Write(buffer, 0, length); 
    // 将缓冲区的输出发送到客户端 
    Response.Flush(); 
    buffer = new Byte[10240]; 
    fileSize = fileSize - length; 
    } 
    else 
    { 
    //当用户断开后退出循环 
    fileSize = -1; 
    } 
    } 
    } 
    catch (Exception ex) 
    { 
    Response.Write("Error : " + ex.Message); 
    } 
    finally 
    { 
    if (fileStream != null) 
    { 
    //关闭文件 
    fileStream.Close(); 
    } 
    Response.End(); 
    } 
    } 
    }
    View Code
  • 相关阅读:
    ES 6 系列
    ES 6 系列
    EChart.js 笔记二
    EChart.js 笔记一
    图像阈值_有cv2.threshold,cv2.adaptiveThreshold 等。
    几何变换——放大、镜像、平移、旋转、透视、仿射
    颜色空间转换---追踪物体
    图像算术运算——相加、相减、与、或、异或、非
    javascript中json对象与字符串互转及取值
    爬虫:Selenium + PhantomJS
  • 原文地址:https://www.cnblogs.com/1711643472qq/p/6179360.html
Copyright © 2020-2023  润新知