嗨,我对烧瓶很新,我想使用ajax调用上传文件到服务器。如文档中所述,我将文件上传到html,如下所示:
<form action="" method=post enctype="multipart/form-data" id="testid">
<table>
<tr>
<td>
<label>Upload</label>
</td>
<td>
<input id="upload_content_id" type="file" name="upload_file" multiple>
<input type="button" name="btn_uplpad" id="btn_upload_id" class="btn-upload" value="Upload"/>
</td>
</tr>
</table>
</form>
我写了这个
的ajax处理程序$(document).ready(function() {
$("#btn_upload_id" ).click(function() {
$.ajax({
type : "POST",
url : "/uploadajax",
cache: false,
async: false,
success : function (data) {},
error: function (XMLHttpRequest, textStatus, errorThrown) {}
});
});
});
我不知道如何从此
获取上传的文件(不是名称) <input id="upload_content_id" type="file" name="upload_file" multiple>
并将文件保存在文件夹中。我不太确定如何从我编写的处理程序中读取文件:
@app.route('/uploadajax', methods = ['POST'])
def upldfile():
if request.method == 'POST':
file_val = request.files['file']
如果有人能提供帮助,我将不胜感激。提前谢谢
答案 0 :(得分:38)
回答你的问题...
HTML:
<form id="upload-file" method="post" enctype="multipart/form-data">
<fieldset>
<label for="file">Select a file</label>
<input name="file" type="file">
</fieldset>
<fieldset>
<button id="upload-file-btn" type="button">Upload</button>
</fieldset>
</form>
JavaScript的:
$(function() {
$('#upload-file-btn').click(function() {
var form_data = new FormData($('#upload-file')[0]);
$.ajax({
type: 'POST',
url: '/uploadajax',
data: form_data,
contentType: false,
cache: false,
processData: false,
success: function(data) {
console.log('Success!');
},
});
});
});
现在,在您的烧录终端视图功能中,您可以通过flask.request.files访问文件的数据。
在旁注中,表单不是表格数据,因此它们不属于表格。相反,您应该使用无序列表或定义列表。
答案 1 :(得分:0)
in the Javascript side::::
var form_data = new FormData();
form_data.append('file', $('#uploadfile').prop('files')[0]);
$(function() {
$.ajax({
type: 'POST',
url: '/uploadLabel',
data: form_data,
contentType: false,
cache: false,
processData: false,
success: function(data) {
console.log('Success!');
},
});
in the server side::::
@app.route('/uploadLabel',methods=[ "GET",'POST'])
def uploadLabel():
isthisFile=request.files.get('file')
print(isthisFile)
print(isthisFile.filename)
isthisFile.save("./"+isthisFile.filename)
答案 2 :(得分:-3)
它位于tutorial。
from flask import send_from_directory @app.route('/uploads/') def uploaded_file(filename): return send_from_directory(app.config['UPLOAD_FOLDER'], filename)
您可以将相同的内容返回给POST请求。然后AJAX成功函数可用于显示响应。
但是出于任何实际目的,将文件名及其关联资源保存在数据库关系表中可能是个好主意。