Хранение изображений в Google DataStore с использованием колбы (Python)

StackOverflow https://stackoverflow.com/questions/4022974

Вопрос

Я использую колбу на приложении Google App и отчаянно искал помощь, чтобы решить это. Документация GAE разговаривает о хранении изображений в хранилище данных, используя BLOBPROPERTY, который должен быть сделан что-то подобное: -

class MyPics(db.Model):
      name=db.StringProperty()
      pic=db.BlobProperty()

Теперь изображение должно храниться в DataStore, делая это: -

def storeimage():
    pics=MyPics()
    pics.name=request.form['name']
    uploadedpic=request.files['file']  #where file is the fieldname in the form of the                
                                        file uploaded
    pics.pic=db.Blob(uploadedpic)
    pics.put()
    redirect ... etc etc

Но я не могу сделать это. Как я получаю db.blob принимает строку, но учитывая объект FileStorage ... Может кто-нибудь помочь мне с этим. Также, если кто-то мог наметить меня, как транслировать изображение назад после загрузки.

Это было полезно?

Решение

Хорошо, так это то, как я наконец решил это: -

@userreg.route('/mypics',methods=['GET','POST'])
def mypics():    
   if request.method=='POST':
      mydata=MyPics()
      mydata.name=request.form['myname']
      file=request.files['file']
      filedata=file.read()
      if file:
         mydata.pic=db.Blob(filedata)
      mydata.put()
      return redirect(url_for('home'))
   return render_template('mypicform.html')

Вышеуказанное хранит файл в виде BLOB в DataStore, а затем он может быть получен набором ниже: -

@userreg.route('/pic/<name>')
def getpic(name):
     qu=db.Query(MyPics).filter('name =',name).get()
     if qu.pic is None:
         return "hello"
     else:
         mimetype = 'image/png'
         return current_app.response_class(qu.pic,mimetype=mimetype,direct_passthrough=False)

Другие советы

Вы должны рассмотреть возможность использования BlobStore хранить ваши данные. Вместо а db.Blob вы будете использовать blobstore.BlobReferenceProperty: http://code.google.com/appengine/docs/python/datastore/typesandpropertyclasses.html#blobreferenceproperty.

Загрузка и загрузка довольно просто, как показано здесь: http://code.google.com/appengine/docs/python/blobstore/overview.html#complete_sample_app.

У меня следующая модель

class Picture(db.Model):    
    data = db.BlobProperty()
    ext = db.StringProperty()
    content_type = db.StringProperty()

и хранить его с помощью следующего кода:

def create_picture():
    if request.files['file']:                       
        picture.data = request.files['file'].read()
        picture.ext = request.files['file'].filename.rsplit('.', 1)[1]
        picture.content_type = request.files['file'].content_type
        picture.put()
        flash(u'File uploaded', 'correct')
        return redirect(url_for("edit_picture", id=picture.key()))
    else:
        return render_template('admin/pictures/new.html', title=u'Upload a picture', message=u'No picture selected')

Чтобы сделать миниатюру, которую вы можете использовать следующий код:

@frontend.route('/thumbnail/<id>/<width>x<height>.<ext>')
def thumbnail(id, width, height, ext):
    key = db.Key(id)
    picture = Picture.get(key)
    img = images.Image(picture.data)

    if width != '0':
        w = int(width)
    else:
        w = img.width

    if height != '0':
        h = int(height)
    else:
        h = img.height

    if img.height > h and h != 0:
        w = (int(width) * img.width) / img.height;

    if img.width > w:
        h = (int(height)  * img.height) / img.width;

    thumb = images.resize(picture.data, width=w, height=h)    
    response = make_response(thumb)
    response.headers['Content-Type'] = picture.content_type
    return response
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top