0

我正在 GAE 上制作一个简单的应用程序,允许用户输入图像的 url 和名称。然后,该应用程序将此图像连同其名称一起上传到数据存储区。

上传后页面自我重定向,然后应该将图像发送回客户端并显示在他们的机器上。

应用程序运行,但没有显示图像。我得到的日志消息是:

AttributeError:“NoneType”对象没有属性“图像”

蟒蛇:

import jinja2   # html template libary
import os

jinja_environment = jinja2.Environment(loader=jinja2.FileSystemLoader(os.path.dirname(__file__)))

import urllib   
import urllib2 
import webapp2

from google.appengine.ext import db
from google.appengine.api import urlfetch


class Default_tiles(db.Model):
  name = db.StringProperty()
  image = db.BlobProperty(default=None)


class MainPage(webapp2.RequestHandler):
  def get(self):

    # this just prints out the url which the user enters into input
    image_name = self.request.get('image_name') 

    template_values = {
        'image_name': image_name,
    }

    template = jinja_environment.get_template('index.html')
    self.response.out.write(template.render(template_values))



class Upload(webapp2.RequestHandler):
  def post(self):

    # get information from form post upload
    image_url = self.request.get('image_url') 
    image_name = self.request.get('image_name')

    # create database entry for uploaded image 
    default_tile = Default_tiles()
    default_tile.name = image_name
    default_tile.image = db.Blob(urlfetch.Fetch(image_url).content)
    default_tile.put()

    self.redirect('/')


class Get_default_tile(webapp2.RequestHandler):
  def get(self):
    name = self.request.get('image_name')
    default_tile = self.get_default_tile(name)

    self.response.headers['Content-Type'] = "image/png"
    self.response.out.write(default_tile.image)

  def get_default_tile(self, name):
    result = db.GqlQuery("SELECT * FROM Default_tiles WHERE name = :1 LIMIT 1", name).fetch(1)
    if (len(result) > 0):
      return result[0]
    else:
      return None


app = webapp2.WSGIApplication([('/', MainPage),
                               ('/upload', Upload),
                               ('/default_tile_img', Get_default_tile)],
                              debug=True)

的HTML:

<html>
    <head>
        <link type="text/css" rel="stylesheet" href="/stylesheets/main.css" />
    </head>

    <body>
        <form action="/upload" method="post">
            <div>
                <p>Name: </p>
                <input name="image_name">
            </div>
            <div>
                <p>URL: </p>
                <input name="image_url">
            </div>
            <div><input type="submit" value="Upload Image"></div>
        </form>
        <img src="default_tile_img?{{ image_name }}">

    </body>

</html>

谢谢你的帮助。

4

1 回答 1

1

首先,您需要将GET参数发送回您的MainPage处理程序。如果你把它放在你的Upload处理程序中,这应该可以工作,在重定向线上:

self.redirect('/?image_name=%s' % image_name)

这将确保MainPage知道我们刚刚上传了什么图像。

第二个问题只是<img>模板中的标签。应该是这样的:

<img src="default_tile_img?image_name={{image_name}}">

进行这些更改后,我已经对其进行了测试,并且可以正常工作。

看起来一切都很好,除了你的GET参数。请记住,当您传递GET请求时,您需要指定它的名称和值,以便您的应用程序可以从标头中正确获取它。例如,如果您希望标头指定 image_name 是什么,您将传递此 URL:

http://domain.com/?image_name=name

代替:

http://domain.com/?name

于 2013-02-02T02:57:07.613 回答