flask 验证ok 另外一种方式
2018-03-01 15:36
211 查看
# coding=utf-8 import os,time from flask import Flask, render_template, send_from_directory, request, jsonify import os app = Flask(__name__) UPLOAD_FOLDER = 'static\uploads' app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER # 设置文件上传的目标文件夹 basedir = os.path.abspath(os.path.dirname(__file__)) # 获取当前项目的绝对路径 ALLOWED_EXTENSIONS = set(['txt', 'png', 'jpg', 'xls', 'JPG', 'PNG', 'xlsx', 'gif', 'GIF']) # 允许上传的文件后缀 # 判断文件是否合法 def allowed_file(filename): return '.' in filename and filename.rsplit('.', 1)[1] in ALLOWED_EXTENSIONS # 具有上传功能的页面 @app.route('/test/upload') def upload_test(): return render_template('upload2.html') @app.route('/api/upload', methods=['POST'], strict_slashes=False) def api_upload(): print "req", request file_dir = os.path.join(basedir, app.config['UPLOAD_FOLDER']) # 拼接成合法文件夹地址 print "filedir",file_dir if not os.path.exists(file_dir): os.makedirs(file_dir) # 文件夹不存在就创建 f=request.files['file'] # 从表单的file字段获取文件,myfile为该表单的name值 print "ff",f,f.filename if f and allowed_file(f.filename): # 判断是否是允许上传的文件类型 print "ok" fname=f.filename ext = fname.rsplit('.', 1)[1] # 获取文件后缀 unix_time = int(time.time()) new_filename = str(unix_time)+'.'+ext # 修改文件名 f.save(os.path.join(file_dir, new_filename)) #保存文件到upload目录 return jsonify({"errno": 0, "errmsg": "上传成功"}) else: print "err" return jsonify({"errno": 1001, "errmsg": "上传失败"}) @app.route("/download/<path:filename>") def downloader(filename): print "file",filename dirpath = os.path.join(app.root_path, 'upload') # 这里是下在目录,从工程的根目录写起,比如你要下载static/js里面的js文件,这里就要写“static/js” return send_from_directory(dirpath, filename, as_attachment=True) # as_attachment=True 一定要写,不然会变成打开,而不是下载 if __name__ == '__main__':app.run(debug=True)
upload2.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form id="form1" method="post" action="/api/upload" enctype="multipart/form-data">
<div>
<input id="File1" type="file" name="file"/> <!--后台代码中获取文件是通过form的name来标识的-->
<input type="submit">提交</input>
</div>
<p>
<a href="http://127.0.0.1:8888/download/3.txt" download="33.txt">Download file</a>
</p>
</form>
</body>
</html>
相关文章推荐
- 另外一种WebService的用户验证方式---使用验证票
- 从EXCEL上传到内表的另外一种方式
- 用一种无耻的方式解决bootstrapvalidator不支持中国id验证的方法
- MasterPage的另外一种实现方式
- linux下mysql 5.x得到root密码后的另外一种利用方式
- jboss 认证绕过漏洞利用的另外一种方式添加用户
- 另外一种设置沉浸式标题栏的方式
- 项目记录05--客unity,服erlang--另外一种AssetBundle打包方式
- 另外一种方式打开网站
- iOS中另外一种多线程实现方式NSOperation
- 使用临时表的另外一种方式
- lazarus用另外一种方便的方式生成xml
- form的另外一种提交方式(伪装提交)
- 另外一种DataGrid与Datalist的嵌套--更好的方式[原创]
- 以另外一种方式写二叉树,感受很深啊!
- java中写构造函数的另外一种方式
- JFrame嵌套背景另外一种实现方式
- CXF实现用户验证(相比前面的另外的一种方法完全Spring)
- GridView的另外一种分页方式,可提高加载速度
- asp.net中web用户身份验证的一种方式。