007真人007真人

来源:乐虎lehu国际娱乐之家  责任编辑:小易  

原来以为文件上传是一个比较简单的功能,结果搞了一个晚上才搞定~这里主要介绍两种方法实现。

方法一:Form表单提交

html代码:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8" />
  <title>上传文件</title>
  <script src="Scripts/jquery-1.11.3.min.js"></script>
</head>
<body>
  <form action="UploadHandler.ashx" method="post" enctype="multipart/form-data">
    <input id="file_upload" name="file_upload" type="file" />
    <input id="btn_upload" type="submit" value="上传" />
  </form>
</body>
</html>

UploadHandler.ashx代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace WebApplication1
{
  /// <summary>
  /// UploadHandler 的摘要说明
  /// </summary>
  public class UploadHandler : IHttpHandler
  {
    public void ProcessRequest(HttpContext context)
    {
      context.Response.ContentType = "text/plain";

      HttpPostedFile file = context.Request.Files["file_upload"];
      string filePath = context.Server.MapPath("~/UploadFiles/") + System.IO.Path.GetFileName(file.FileName);
      file.SaveAs(filePath);

      context.Response.Write("上传文件成功");
    }

    public bool IsReusable
    {
      get
      {
        return false;
      }
    }
  }
}

该方法虽然能够实现文件的上传,但是form表单提交之后整个页面就刷新了,如果要无刷新上传文件的话,就要使用ajax了。

方法二:jquery + ajax无刷上传

html代码:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8" />
  <title>上传文件</title>
  <script src="Scripts/jquery-1.11.3.min.js"></script>
</head>
<body>
  <input id="file_upload" name="file_upload" type="file" />
  <input id="btn_upload" type="button" value="上传" />

  <script>
    $(document).ready(function ()
    {
      $('#btn_upload').bind('click', function ()
      {
        var formData = new FormData();
        formData.append('upload_file', $('#file_upload')[0].files[0]);
        $.ajax({
          url: 'UploadHandler.ashx',
          type: 'post',
          data: formData,
          contentType: false,
          processData: false,
          success: function (msg)
          {
            if (msg == "Yes")
            {
              alert('文件上传成功');
            }
            else
            {
              alert('文件上传失败');
            }
          }
        })
      });
    });
  </script>
</body>
</html>

UploadHandler.ashx代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace WebApplication1
{
  /// <summary>
  /// UploadHandler 的摘要说明
  /// </summary>
  public class UploadHandler : IHttpHandler
  {

    public void ProcessRequest(HttpContext context)
    {
      context.Response.ContentType = "text/plain";

      if (context.Request.Files.Count > 0)
      {
        HttpPostedFile file = context.Request.Files["upload_file"];
        string filePath = context.Server.MapPath("~/UploadFiles/") + System.IO.Path.GetFileName(file.FileName);
        file.SaveAs(filePath);
        context.Response.Write("Yes");
      }
      else
      {
        context.Response.Write("No");
      }
    }

    public bool IsReusable
    {
      get
      {
        return false;
      }
    }
  }
}

个人更推荐方法二,运行结果如下图所示:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持乐虎lehu国际娱乐之家。

您可能感兴趣的文章:


  • 本文相关:
  • ashx介绍以及ashx文件与aspx文件之间的区别
  • jquery向.ashx文件post中文乱码问题的解决方法
  • jquery+ashx无刷新gridview数据显示插件(实现分页、排序、过滤功能)
  • 关于html+ashx开发中几个问题的解决方法
  • asp.net ashx中获得session的方法
  • jquery ajax,ashx,json的用法总结
  • html+ashx 表单提交示例
  • jquery ajax.ashx 高效分页实现代码
  • ashx文件的使用小结
  • 在.ashx文件中获取cookies值实现代码
  • asp.net中利用ashx实现图片防盗链的原理分析
  • mysql安装后.net程序运行出错的解决方法
  • asp.net 下载文件时输出文件内容
  • repeater、gridview 在绑定时判断判断显示不同的行样式或文本
  • asp.net 用xml生成放便扩展的自定义树
  • asp.net读取xml文件4种方法分析
  • .net使用rabbitmq即时发消息demo
  • asp.net mvc 3实现访问统计系统
  • asp.net获取网站目录物理路径示例
  • asp.net 主题的简单配置教程
  • 详解asp.net core 之 identity 入门(三)
  • 免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.pradaoutletonline.net All Rights Reserved