2010-03-28 1 views
3

J'utilise gae avec django. J'ai un projet nommé MusicSite avec adresse suivante mapping-Chargement de fichier dans Google Application Engine à l'aide de Django

urls.py 

from django.conf.urls.defaults import * 
from MusicSite.views import MainHandler 
from MusicSite.views import UploadHandler 
from MusicSite.views import ServeHandler 

urlpatterns = patterns('',(r'^start/', MainHandler), 
     (r'^upload/', UploadHandler), 
     (r'^/serve/([^/]+)?', ServeHandler), 
) 

Il y a un MusicSite d'application à l'intérieur MusicFun avec les éléments suivants codes-

views.py 

import os 
import urllib 

from google.appengine.ext import blobstore 
from google.appengine.ext import webapp 
from google.appengine.ext.webapp import blobstore_handlers 
from google.appengine.ext.webapp import template 
from google.appengine.ext.webapp.util import run_wsgi_app 

def MainHandler(request): 
    response=HttpResponse() 
    upload_url = blobstore.create_upload_url('http://localhost: 
8000/upload/') 
    response.write('<html><body>') 
    response.write('<form action="%s" method="POST" 
enctype="multipart/form-data">' % upload_url) 
    response.write("""Upload File: <input type="file" 
name="file"><br> <input type="submit" 
     name="submit" value="Submit"> </form></body></html>""") 
    return HttpResponse(response) 

def UploadHandler(request): 
    upload_files=request.FILES['file'] 
    blob_info = upload_files[0] 
    response.redirect('http://localhost:8000/serve/%s' % 
blob_info.key()) 

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) 

maintenant chaque fois qu'un téléchargement d'un fichier à l'aide/démarrage et cliquez sur Soumettre je suis pris à une page blanche avec l'url suivant-

localhost:8000/_ah/upload/ahhnb29nbGUtYXBwLWVuZ2luZS1kamFuZ29yGwsSFV9fQmxvYlVwbG9hZFNlc3Npb25fXxgHDA 

Ces rando m alphabets continuent à varier mais le résultat est le même. Une page vide après chaque téléchargement. Quelqu'un s'il vous plaît aider.

Les réponses du serveur sont aussi dessous-

INFO:root:"GET /start/ HTTP/1.1" 200 - 
INFO:root:"GET /favicon.ico HTTP/1.1" 404 - 
INFO:root:Internal redirection to http://localhost:8000/upload/ 
INFO:root:Upload handler returned 500 
ERROR:root:Invalid upload handler response. Only 301, 302 and 303 
statuses are permitted and it may not have a content body. 
INFO:root:"POST /_ah/upload/ 
ahhnb29nbGUtYXBwLWVuZ2luZS1kamFuZ29yGwsSFV9fQmxvYlVwbG9hZFNlc3Npb25fXxgCDA 
HTTP/1.1" 500 - 
INFO:root:"GET /favicon.ico HTTP/1.1" 404 - 

Répondre

3

Votre gestionnaire de téléchargement retourne 500:

INFO:root:Upload handler returned 500 
ERROR:root:Invalid upload handler response. Only 301, 302 and 303 statuses are permitted and it may not have a content body. 

Ceci est presque certainement parce qu'il est lancer une exception; vous devez persuader Django de consigner l'exception afin de pouvoir voir ce qui ne va pas. Alternativement, attrapez-le et connectez-vous vous-même!