1.使用HTML的input标签

    <input type="file" multiple="multiple" id="file_load" />

  2.使用JS为input的file添加一个change事件

      $('#file_load').change(function () {
      var fileObj = document.getElementById("file_load").files; // js 获取文件对象
      if (typeof (fileObj) == "undefined" || fileObj.size <= 0) {
      alert("请选择文件");
      return;
        }
      if (fileObj.length > 10) {   //因本人项目需求、一次最多上传的文件个数不能超过10个
      alert("一次上传文件不能超过10个");  
        return;
        }
      var formData = new FormData();   //FormData专门用来给ajax向后台传递文件用的
      formData.append("action", "FileLoad");//向后台传递值、是键值对的形式
      for (var i = 1; i <= fileObj.length; i++) {
      formData.append("file", fileObj[i]); //向formData 里追加文件
      }
      $.ajax({
      url: "../Method/FileUpload.ashx",
      type: "post",
      cache: false,
      data: formData,
      dataType: 'json',  //这里采用json格式向后台传递数据、如果后台需要返回信息也必须返回json数据 只有这样ajax的回调函数才能接收到后台传过来的值
      cache: false,//上传文件无需缓存
      processData: false,//用于对data参数进行序列化处理 这里必须false
      contentType: false, 
      success: function (data) {
      if (data == 'OK') {

      //上传完成
      };
    }
   }
});
});

  3.一般处理程序(上传)

    public void FileLoad(HttpContext context)

    {
      string path = "";//文件保存路径
      for (int i = 0; i < context.Request.Files.Count; i++)
      {
        HttpPostedFile file = context.Request.Files[i];
        path = context.Server.MapPath("~/File/" + file.FileName);
        file.SaveAs(path);
      }
    //返回json数据
    JavaScriptSerializer js = new JavaScriptSerializer();
    context.Response.Write(js.Serialize("OK"));
    }

    

    

  4.文件下载前端

  我这里不方便使用项目中的代码,所以就简单写个Demo

   <a href="../Method/FileDowload.ashx?action=DowFile&filename=1.txt">下载</a>   直接使用a标签访问一般处理程序,带两个参数 分别为需要请求的方法和需要下载的文件名称

action=DowFile、filename=1.txt

  

  

 4.一般处理程序(下载)

  public void DowFile(HttpContext context)
  {
    string filename = context.Request["filename"].ToString();    //文件名称就是前端传来的filename这个参数
    string path = "~/File/" + filename;
    System.IO.FileInfo file = new System.IO.FileInfo(System.Web.HttpContext.Current.Server.MapPath(path));
    context.Response.Clear();
    context.Response.Charset = "UTF-8";
    context.Response.ContentEncoding = System.Text.Encoding.UTF8;
    context.Response.AddHeader("Content-Type", "application/octet-stream");
              // 添加头信息,为"文件下载/另存为"对话框指定默认文件名,设定编码为UTF8,防止中文文件名出现乱码
              context.Response.AddHeader("Content-Disposition", "attachment; filename=" + System.Web.HttpUtility.UrlEncode(file.Name, System.Text.Encoding.UTF8));
             // 添加头信息,指定文件大小,让浏览器能够显示下载进度
             context.Response.AddHeader("Content-Length", file.Length.ToString());
             //// 指定返回的是一个不能被客户端读取的流,必须被下载
             context.Response.ContentType = "application/ms-excel";
             // 把文件流发送到客户端
             context.Response.WriteFile(path);
             // 停止页面的执行
             context.Response.End();
          }

我这个是在项目的跟目录里创建了一个文件夹File。<input type="file" multiple="multiple" id="file_load" />标签的默认样式改法有很多  百度上有

使用Ajax和一般处理程序实现文件上传与下载的更多相关文章

  1. MVC文件上传与下载

    MVC文件上传与下载 MVC文件上传与下载 想想自己从毕业到工作也有一年多,以前公司的任务的比较重,项目中有的时候需要用到什么东西都去搜索一下,基础知识感觉还没有以前在学校中的好.最近开始写博客,真的 ...

  2. SpringBoot整合阿里云OSS文件上传、下载、查看、删除

    1. 开发前准备 1.1 前置知识 java基础以及SpringBoot简单基础知识即可. 1.2 环境参数 开发工具:IDEA 基础环境:Maven+JDK8 所用技术:SpringBoot.lom ...

  3. JavaServlet的文件上传和下载

    关于JSP中的文件上传和下载操作 先分析一下上传文件的流程 1-先通过前段页面中的选择文件选择要上传的图片 index.jsp <%@ page language="java" ...

  4. Struts2学习总结——文件上传与下载

    Struts2文件上传与下载 1.1.1新建一个Maven项目(demo02) 在此添加Web构面以及 struts2 构面 1.2.1配置Maven依赖(pom.xml 文件) <?xml v ...

  5. [实战]MVC5+EF6+MySql企业网盘实战(18)——文件上传,下载,修改

    写在前面 经过一段时间的秀秀改改,终于把文件上传下载,修改文件夹文件名称的功能实现了. 系列文章 [EF]vs15+ef6+mysql code first方式 [实战]MVC5+EF6+MySql企 ...

  6. JavaWeb:实现文件上传与下载

    JavaWeb:实现文件上传与下载 文件上传前端处理 本模块使用到的前端Ajax库为Axio,其地址为GitHub官网. 关于文件上传 上传文件就是把客户端的文件发送给服务器端. 在常见情况(不包含文 ...

  7. koa2基于stream(流)进行文件上传和下载

    阅读目录 一:上传文件(包括单个文件或多个文件上传) 二:下载文件 回到顶部 一:上传文件(包括单个文件或多个文件上传) 在之前一篇文章,我们了解到nodejs中的流的概念,也了解到了使用流的优点,具 ...

  8. javaWeb文件上传与下载

    文件上传与下载在项目中运用的使用频率很大 今天也花时间整理了一下 多文件上传图片回显 和文件下载  1.多文件上传 这里会涉及到几个属性 fileSizeThreshold:缓冲区文件的大小 如果上传 ...

  9. vue+axios+elementUI文件上传与下载

    vue+axios+elementUI文件上传与下载 Simple_Learn 关注  0.5 2018.05.30 10:20 字数 209 阅读 15111评论 4喜欢 6 1.文件上传 这里主要 ...

随机推荐

  1. SAS学习笔记51 SAS数据集

    结构 SAS数据集是关系型的,包含两个部分:描述部分(变量)和数据部分(观察值) 形式 SAS系统中共有两种类型的数据集: 1.SAS 数据文件(SAS datafiles) 2.SAS 数据视窗(S ...

  2. Codeforces Round #415 (Div. 1) (CDE)

    1. CF 809C Find a car 大意: 给定一个$1e9\times 1e9$的矩阵$a$, $a_{i,j}$为它正上方和正左方未出现过的最小数, 每个询问求一个矩形内的和. 可以发现$ ...

  3. Http 和 Socket 之间的恩爱情仇

    前言 一些刚入门的小伙伴可能会用 Socket,也会用 OkHttp 或者 HttpUrlConnection 等一些 HTTP 客户端工具,这两个东西看着有点像可是又不太一样,到底是哪里不一样呢? ...

  4. 查询并批量插入数据的Sql命令

    INSERT INTO student(id,xuesheng,yuwen,shuxue,yingyu) SELECT id,xuesheng,yuwen,shuxue,yingyu FROM stu ...

  5. Java 之 File类(文件操作)

    一.概述 java.io.File 类是文件和目录路径名册抽象表示,主要用于文件和目录的创建.查找和删除等操作. File类是一个与系统无关的类,任何的操作系统都可以使用这个类中的方法. 路径问题: ...

  6. Dubbo服务发布、引用

    DUBBO原理.应用与面经总结 Dubbo原理和源码解析之服务暴露 Dubbo原理和源码解析之服务引用 服务发布 服务的发布总共做了以下几件事,这个也可以从日志log上看出来: 暴露本地服务 暴露远程 ...

  7. Redis其他数据结构

    用户日活月活怎么统计 - Redis HyperLogLog 详解 HyperLogLog 提出问题 我们先思考一个常见的业务问题:如果你负责开发维护一个大型的网站,有一天老板找产品经理要网站每个网页 ...

  8. vue中计算属性和侦听属性

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certificatio

    场景:Java调用PHP接口,代码部署在服务器上后,调用报错,显示PHP服务器那边证书我这边服务器不信任(我猜的). 异常信息: 2019-08-06 14:00:09,102 [http-nio-4 ...

  10. RestFramework之序列化组件

    一.restframework的序列化组件的使用 1.导入序列化组件与模型类 from rest_framework import serializers from app01.models impo ...