0

我使用此链接作为上传图片的示例:

https://gist.github.com/jdstanhope/5079277

我的 HTML 代码:

 <form action="/upload_image" method="post" id="form1" runat="server">
       <div class="fileButtons">
         <input type='file' id="imgInp" name="imgInput" accept="image/*"/><br><br>
         <input type='button' id='remove' value='Remove' />
        </div></form>

主要.py:

class SetImage(webapp2.RequestHandler):
    def post(self):
        logging.debug("test")
        id = str(self.request.get('id'))
        image = self.request.get('imgInput')

app = webapp2.WSGIApplication([('/upload_image', SetImage),
                               ('/', MainPage)], debug=True)

但是当我添加图像时,什么都没有做,并且日志控制台不打印:

logging.debug("test")
4

2 回答 2

1

将图像上传到 GAE 的推荐方法是使用blobstore

以下是文档的快速细分,可帮助您快速实现这一目标:

进口:

import os
import urllib
import webapp2

from google.appengine.ext import blobstore
from google.appengine.ext.webapp import blobstore_handlers

提供表单 HTML。此表单使用选定的文件数据执行 POST 到 GAE:

class MainHandler(webapp2.RequestHandler):
    def get(self):
        upload_url = blobstore.create_upload_url('/upload')
        self.response.out.write('<html><body>')
        self.response.out.write('<form action="%s" method="POST"
                enctype="multipart/form-data">' % upload_url)
        self.response.out.write("""Upload File: 
                <input type="file" name="file"><br> <input type="submit"
                name="submit" value="Submit"> </form></body></html>""")

添加用于接收 POST 数据(文件的二进制内容)的处理程序。此函数的最后一行是将响应重定向到可以下载文件的位置:

class UploadHandler(blobstore_handlers.BlobstoreUploadHandler):
    def post(self):
        # 'file' is file upload field in the form
        upload_files = self.get_uploads('file')
        blob_info = upload_files[0]
        self.redirect('/serve/%s' % blob_info.key())

添加处理程序以提供您使用上述 UploadHandler 上传的图像:

class ServeHandler(blobstore_handlers.BlobstoreDownloadHandler):
    def get(self, resource):
        resource = str(urllib.unquote(resource))
        blob_info = blobstore.BlobInfo.get(resource)
        self.send_blob(blob_info)

最后,定义应用程序的路由:

app = webapp2.WSGIApplication([('/', MainHandler),
                           ('/upload', UploadHandler),
                           ('/serve/([^/]+)?', ServeHandler)],
                            debug=True)
于 2014-01-04T15:09:51.217 回答
0

关于您的日志语句未触发的问题:默认日志级别为dev_appserver.py,您可以使用该标志info覆盖该级别。--dev_appserver_log_level

参考新的 dev_appserver 文档

要从 multipart/form-data POST 请求访问上传的文件,webapp2 文档声明它们在request.POST.

于 2013-09-20T04:38:44.247 回答