js+ajax实现获取文件大小的方法


Posted in Javascript onDecember 08, 2015

本文实例讲述了js+ajax实现获取文件大小的方法。分享给大家供大家参考,具体如下:

顾名思义,通过JS和Ajax来获取上传文件的大小,在上传之前可以有个判断,对上传的文件有所控制,因为js控制文件大小(JS获取文件大小)有些问题,具体大家试下就知道了,在此整理了一下ajax的获取文件大小的方法,比较好用,再调试过程中,出现了c:/fakepath/ 的错误,也将解决方案罗列在下面,以供大家参考

废话少说,代码如下

JS如下:

<script language="Jscript">
function chksize(){
  var ticketType = "Oil";
  var file1=document.getElementById("txtfile");
  var v = file1.value;
  file1.select();
  var realpath = document.selection.createRange().text;
  var input = "<Record><Type>TicketLoanResult</Type><TicketType>" + realpath + "</TicketType></Record>";
  var objXmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
  objXmlHttp.Open("POST", "XMLHttpPost.aspx", false);
  objXmlHttp.Send(input);
  var returnXml = objXmlHttp.responseText;
  if(returnXml!=null)
  {
   returnXml=parseInt(returnXml/1024/1024);
  }
  alert(returnXml); 
  return false; 
}
</script>

后台C#代码:

public partial class XMLHttpPost : System.Web.UI.Page
{
 protected void Page_Load(object sender, EventArgs e)
 {
  try
  {
   XmlDocument xmlDocumenet = new XmlDocument();
   xmlDocumenet.Load(Request.InputStream);
   string type = xmlDocumenet.SelectSingleNode("descendant::Type").InnerText;
   string returnMessage = string.Empty;
   switch (type.Trim())
   {
    case "TicketLoanResult":
     returnMessage = GetTicketLoanResult(xmlDocumenet);
     break;
    default:
     break;
   }
   Response.ContentType = "text/xml";
   Response.Write(returnMessage);
  }
  catch (Exception exceptional)
  {
   //如果有???t返回??信息(Xml格式)
   string errorMessage = "<Error>" + exceptional.Message + "</Error>";
   Response.ContentType = "text/xml";
   Response.Write(errorMessage);
  }
  finally
  {
   Response.End();
  }
 }
 private string GetTicketLoanResult(XmlDocument input)
 {
  XmlNode item = input.SelectSingleNode("descendant::TicketType");
  string ticketType = item.InnerText.Trim();
  FileStream stream = new FileStream(ticketType,FileMode.Open);
  return stream.Length.ToString();
 }
}

完整实例代码点击此处本站下载。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js中cookie的使用详细分析
May 28 Javascript
基于jquery的checkbox下拉框插件代码
Jun 25 Javascript
javascript的内存管理详解
Aug 07 Javascript
js onload处理html页面加载之后的事件
Oct 30 Javascript
我的Node.js学习之路(二)NPM模块管理
Jul 06 Javascript
jQuery中$this和$(this)的区别介绍(一看就懂)
Jul 06 Javascript
js+flash实现的5图变换效果广告代码(附演示与demo源码下载)
Apr 01 Javascript
Bootstrap实现各种进度条样式详解
Apr 13 Javascript
vue单页缓存方案分析及实现
Sep 25 Javascript
javascript中undefined的本质解析
Jul 31 Javascript
Websocket 向指定用户发消息的方法
Jan 09 Javascript
JavaScript实现矩形块大小任意缩放
Aug 25 Javascript
JS表格组件神器bootstrap table详解(基础版)
Dec 08 #Javascript
详解js中构造流程图的核心技术JsPlumb(2)
Dec 08 #Javascript
详解js中构造流程图的核心技术JsPlumb
Dec 08 #Javascript
jQuery遮罩层实现方法实例详解(附遮罩层插件)
Dec 08 #Javascript
jQuery实现的简单提示信息插件
Dec 08 #Javascript
JS组件Bootstrap Table表格多行拖拽效果实现代码
Dec 08 #Javascript
AngularJS实现全选反选功能
Dec 08 #Javascript
You might like
php_xmlhttp 乱码问题解决方法
2009/08/07 PHP
php加水印的代码(支持半透明透明打水印,支持png透明背景)
2013/01/17 PHP
php fsockopen解决办法 php实现多线程
2014/01/20 PHP
PHP的pcntl多进程用法实例
2015/03/19 PHP
微信支付开发维权通知实例
2016/07/12 PHP
PHP使用GD库制作验证码的方法(点击验证码或看不清会刷新验证码)
2017/08/15 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
初学Javascript的一些总结
2008/11/03 Javascript
js实现改进的仿蓝色论坛导航菜单效果代码
2015/09/06 Javascript
three.js快速入门【推荐】
2017/01/21 Javascript
jQuery排序插件tableSorter使用方法
2017/02/10 Javascript
JavaScript实现QQ聊天消息展示和评论提交功能
2017/05/22 Javascript
Javascript创建类和对象详解
2017/05/31 Javascript
解析vue中的$mount
2017/12/21 Javascript
vue-cli3全面配置详解
2018/11/14 Javascript
JavaScript数组去重的方法总结【12种方法,号称史上最全】
2019/02/28 Javascript
关于AOP在JS中的实现与应用详解
2019/05/06 Javascript
Node.js爬虫如何获取天气和每日问候详解
2019/08/26 Javascript
理解JavaScript中的Proxy 与 Reflection API
2020/09/21 Javascript
vue 实现element-ui中的加载中状态
2020/11/11 Javascript
Python中的变量和作用域详解
2016/07/13 Python
python利用urllib和urllib2访问http的GET/POST详解
2017/09/27 Python
终端命令查看TensorFlow版本号及路径的方法
2018/06/13 Python
Python实现多态、协议和鸭子类型的代码详解
2019/05/05 Python
itchat-python搭建微信机器人(附示例)
2019/06/11 Python
详解Python并发编程之从性能角度来初探并发编程
2019/08/23 Python
Stuart Weitzman美国官网:美国奢华鞋履品牌
2016/08/18 全球购物
英国家庭、花园、汽车和移动解决方案:Easylife Group
2018/05/23 全球购物
手工制作的意大利皮革运动鞋:KOIO
2020/01/05 全球购物
致跳高运动员广播稿
2014/01/13 职场文书
国际商务专业职业生涯规划书范文
2014/01/17 职场文书
2015年大学生党员承诺书
2015/04/27 职场文书
golang 生成对应的数据表struct定义操作
2021/04/28 Golang
如何使用PyCharm及常用配置详解
2021/06/03 Python
Java常用工具类汇总 附示例代码
2021/06/26 Java/Android
Win11局域网共享权限在哪里设置? Win11高级共享的设置技巧
2022/04/05 数码科技