❶ ajaxupload.js无法获取上传文件
ajaxupload.js是一个开源的实现Ajax文件上传的jQuery插件,常用于向服务器上传文件。如果遇到该插件无法获取上传文件的问题,猜郑可能是以下几个方面的原因:1、插件引用错误:首先需要确保插件已正确引用,可以检查HTML代码或控制台中是否出现引用错误或没有引用相关JS文件的情况。2、表单设置错误:使用ajaxupload.js时,需要将表单对象传皮兆衫递给插件以表示文件上传的上下文。如果表单对象设置有误,插件可能无法获取上传文件。可以确保表单中存在file类型的input,并将其作为参数传递给插件。3、上传文件格式不正确:如果上传文件的格式不受支持,则插件可能无法正确获取上传文件。可以确保上传的文件格式与插件支持的格式相同。4、安全问题限制:有些情况下,安全设置可能会禁止通过javaScript读取文件内容,防止网站被黑客攻击等。可以检查安全设置以确定是否存在限制。5、程序服务端问题:如果前面几个问题都排除了,还是无法获取上传文件,则可能是由于程序服务端的设置或代码实现问题,需要进一步检查或调试燃腔。
❷ 怎么用ajax实现上传文件的功能
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 objectvar 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目录下。