怎么用ajax实现上传文件的功能

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么用ajax实现上传文件的功能相关的知识,希望对你有一定的参考价值。

参考技术A

HTTP File Server

http-file-server 是用 python 实现的 HTTP 文件服务器,支持上传和下载文件。

运行

$ python file-server.py files 8001

其中第一个参数 files 是存放文件的路径,第二个参数 8001 是 HTTP 服务器端口。

接口

1. 读取文件

GET /pathtofile/filename

2. 读取文件夹下所有文件(已经忽略隐藏文件)

GET /path

返回文件列表为 JSON 数组,文件名末尾带有 / 的表示是文件夹。 filename 为文件名,mtime 为修改时间。

["filename":"f1.txt","mtime":1001,"filename":"p3/","mtime":1002]

3. 上传文件

采用 POST 方式上传文件,URL 参数中传参数 name 表示上传的文件名,POST 内容为文件内容。

POST /upload?name=filename

ajax 示例:

// file is a FileReader object
var data = file.readAsArrayBuffer();
var xhr = new XMLHttpRequest();
var url = "http://localhost:8001/upload?name=xxx.md";
xhr.open("post", url, true);
xhr.setRequestHeader("Accept", "application/json, text/javascript, */*; q=0.01");
xhr.onreadystatechange = function()
if (xhr.readyState==4 && xhr.status==200)

console.log(xhr.responseText);


xhr.send(data);

文件名 filename 可以包含相对路径。比如:upload?name=md/xxx.md。则上传至 md 目录下。

我用WebService 上传文件 想用ajax方法发送提交的文件请求 能做到吗??

参考技术A 据我所知,像csdn这样的网站我写博客的时候都是没有采用Ajax的,因为Ajax一般都是get方式提交数据的,这样的话对提交数据的长度有限制。所以用Ajax可能比较难实现了。

以上是关于怎么用ajax实现上传文件的功能的主要内容,如果未能解决你的问题,请参考以下文章

最近在研究nodejs如何实现文件上传功能

multipartfile 文件上传前端怎么用div和ajax

ajaxfileupload.js上传文件时后台用java怎么接收文件流

ajax上传文件是怎么实现的

怎么用Java实现FTP上传

Ajax上传文件怎样才能分块上传呢?