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

作者:仰天一笑 时间:2023-08-12 00:22:07 

本文实例讲述了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)
 {
  //如果有錯誤則返回錯誤信息(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程序设计有所帮助。

标签:js,ajax
0
投稿

猜你喜欢

  • JavaScript实现年历效果

    2023-09-10 10:53:26
  • 使用递归删除树形结构的所有子节点(java和mysql实现)

    2024-01-12 23:22:16
  • 总结Python连接CS2000的详细步骤

    2023-04-21 20:26:33
  • 解决微信浏览器缓存站点入口文件(IIS部署Vue项目)

    2024-05-13 10:40:00
  • 利用python进行接口测试及类型介绍

    2021-02-11 21:27:01
  • python编写函数注意事项总结

    2021-08-19 22:15:10
  • php输出指定时间以前时间格式的方法

    2024-05-09 14:46:39
  • Python中免验证跳转到内容页的实例代码

    2021-03-27 11:19:55
  • 全国哀悼日 建议站点换素装(附代码)

    2008-05-19 12:05:00
  • 一个滑动展示的小代码

    2011-07-01 12:58:05
  • python重试装饰器示例

    2022-07-28 10:03:12
  • sql 2000清空后让表的id从1开始等数据库操作

    2024-01-18 11:30:15
  • 使用numpngw和matplotlib生成png动画的示例代码

    2023-06-15 13:38:21
  • 用python画个敬业福字代码

    2022-04-04 18:36:59
  • python之Socket网络编程详解

    2021-05-29 14:43:22
  • Python 查找list中的某个元素的所有的下标方法

    2022-10-15 21:48:16
  • vue实现拖拽交换位置

    2024-04-30 08:45:51
  • Python 模拟购物车的实例讲解

    2021-01-13 05:24:08
  • 使用python将图片按标签分入不同文件夹的方法

    2021-04-14 05:34:54
  • MySQL中的count(*) 和 count(1) 区别性能对比分析

    2024-01-24 03:12:51
  • asp之家 网络编程 m.aspxhome.com