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 相关文章推荐
判断字符串的长度(优化版)中文占两个字符
Oct 30 Javascript
node.js超时timeout详解
Nov 26 Javascript
jQuery使用empty()方法删除元素及其所有子元素的方法
Mar 26 Javascript
深入浅出分析javaScript中this用法
May 09 Javascript
jQuery插件formValidator自定义函数扩展功能实例详解
Nov 25 Javascript
angularjs的select使用及默认选中设置
Apr 08 Javascript
js中的 || 与 &amp;&amp; 运算符详解
May 24 Javascript
node.js中TCP Socket多进程间的消息推送示例详解
Jul 10 Javascript
Vue项目中使用WebUploader实现文件上传的方法
Jul 21 Javascript
Vue触发隐藏input file的方法实例详解
Aug 14 Javascript
详解Vue3中对VDOM的改进
Apr 23 Javascript
微信小程序自定义底部弹出框动画
Nov 18 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
将数字格式的计算结果转为汉字格式
2006/10/09 PHP
PHP实现多维数组转字符串和多维数组转一维数组的方法
2015/08/08 PHP
Laravel 数据库加密及数据库表前缀配置方法
2019/10/10 PHP
javascript英文日期(有时间)选择器
2007/05/02 Javascript
JavaScript 以对象为索引的关联数组
2010/05/19 Javascript
Android中的jQuery:AQuery简介
2014/05/06 Javascript
在JavaScript中处理时间之setMinutes()方法的使用
2015/06/11 Javascript
IE中document.createElement的iframe无法设置属性name的解决方法
2015/09/14 Javascript
Flow之一个新的Javascript静态类型检查器
2015/12/21 Javascript
js仿百度登录页实现拖动窗口效果
2016/03/11 Javascript
在js里怎么实现Xcode里的callFuncN方法(详解)
2016/11/05 Javascript
js实现简单的二级联动效果
2017/03/09 Javascript
vuejs点击class变化的实例
2018/09/05 Javascript
Javascript读写cookie的实例源码
2019/03/16 Javascript
解决vue项目input输入框双向绑定数据不实时生效问题
2020/08/05 Javascript
Vue ​v-model相关知识总结
2021/01/28 Vue.js
python函数形参用法实例分析
2015/08/04 Python
python学习之编写查询ip程序
2016/02/27 Python
Python中关键字nonlocal和global的声明与解析
2017/03/12 Python
Python实现读取并保存文件的类
2017/05/11 Python
Linux RedHat下安装Python2.7开发环境
2017/05/20 Python
Puppeteer使用示例详解
2019/06/20 Python
解决Pycharm 包已经下载,但是运行代码提示找不到模块的问题
2019/08/31 Python
Django Admin设置应用程序及模型顺序方法详解
2020/04/01 Python
Python random模块的使用示例
2020/10/10 Python
python 将Excel转Word的示例
2021/03/02 Python
泰国折扣酒店预订:Hotels2Thailand
2018/03/20 全球购物
2019年.net常见面试问题
2012/02/12 面试题
刚毕业大学生自荐信范文
2014/02/20 职场文书
工作建议书范文
2014/05/13 职场文书
债务纠纷委托书范本
2014/10/14 职场文书
2014年个人工作总结范文
2014/11/07 职场文书
公司保洁员岗位职责
2015/02/13 职场文书
《牧场之国》教学反思
2016/02/22 职场文书
Python自动化测试PO模型封装过程详解
2021/06/22 Python
maven 解包依赖项中的文件的解决方法
2022/07/15 Java/Android