简介
在 Tornado web 框架中,上传图片通常涉及创建一个表单,让用户选择文件并上传。Tornado 通过其 RequestHandler
类来处理这些请求,你可以重写 post
方法来接收上传的文件。
后端
python
import os
import tornado.ioloop
import tornado.web
import tornado.httpserver
class UploadHandler(tornado.web.RequestHandler):
def post(self):
# 获取上传的文件
file_info = self.request.files['file'][0]
# 获取文件名和文件内容
file_name = file_info['filename']
file_content = file_info['body']
# 定义保存文件的路径
upload_path = os.path.join('uploads', file_name)
# 保存文件
with open(upload_path, 'wb') as f:
f.write(file_content)
# 返回成功信息
self.write({'status': 'success', 'filename': file_name})
def make_app():
return tornado.web.Application([
(r"/upload", UploadHandler),
])
if __name__ == "__main__":
# 确保上传目录存在
if not os.path.exists('uploads'):
os.makedirs('uploads')
app = make_app()
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(8888)
tornado.ioloop.IOLoop.current().start()
在上面的代码中,我们定义了一个 UploadHandler
类,它继承自 tornado.web.RequestHandler
。在 post
方法中,我们获取上传的文件信息,并将其保存到服务器的文件系统中。上传的文件保存在 uploads
目录下,文件名保持不变。
请注意,此示例未包含任何形式的输入验证或错误处理。在实际应用中,你应该检查上传的文件类型(确保是图片),文件大小(防止过大的文件上传),以及可能的安全问题(如文件覆盖和目录遍历攻击)。
前端
此外,你还需要在前端创建一个表单来上传文件。一个简单的 HTML 表单可能如下所示:
html
<!DOCTYPE html>
<html>
<head>
<title>Upload Image</title>
</head>
<body>
<form action="/upload" method="post" enctype="multipart/form-data">
<input type="file" name="file">
<input type="submit" value="Upload">
</form>
</body>
</html>
用户选择文件并点击上传按钮后,浏览器会向 /upload
路径发送一个 POST 请求,包含用户选择的文件。Tornado 服务器上的 UploadHandler
将处理这个请求,并将文件保存到服务器。