Загрузить файл с Android в веб-службу Django

Я работаю над приложением для Android, которое взаимодействует с серверной частью Django. Я развернул веб-сервис с помощью mod_wsgi, и у меня есть много вызовов веб-сервисов, которые работают и были протестированы, поэтому я знаю, что все ДОЛЖНО работать. Все остальные звонки работают нормально. Это метод, который я вызываю в Android для отправки фотографии.

public static String uploadFile(String url, int server_id, String filepath) {
    try {
        client.getParams().setParameter("http.socket.timeout", 90000); // 90 second
        HttpPost post = new HttpPost(url);

        MultipartEntity mpEntity = new MultipartEntity();
        mpEntity.addPart("image", new FileBody(new File(filepath), "image/jpeg"));
        post.setEntity(mpEntity);
        post.addHeader("server_id", String.valueOf(server_id));

        HttpResponse response = Connector.client.execute(post);
        if (response.getStatusLine().getStatusCode() != 200) { return "false"; }
        return convertStreamToString(response.getEntity().getContent());
    } catch (Exception e) {
        if (Constants.DEBUG) e.printStackTrace();
        return "false";
    }
}

Это метод, который я использую в своем файле views.py для получения и обработки изображения:

@csrf_exempt
def incident_upload(request):
    if request.method == 'POST':
            server_id = request.POST['server_id']
            incident = get_object_or_404(Incident, pk=server_id)
            imagePath = '/Library/WebServer/program/uploads/' + str(int(time.time() * 1000)) + '.jpg'
            destination = open(imagePath, 'wb+')
            for chunk in request.FILES['image'].chunks():
                    destination.write(chunk)
            destination.close()
            incident.ImagePath = imagePath
            incident.save()
            return render_to_response('webservice/incident_read.html', {'incident': incident, 'device': incident.device})

Когда я пробую этот метод, я получаю действительно полезную ошибку Apache 500 Internal Server Error, и я понятия не имею в чем дело.Я знаю, что этот метод работает, потому что я могу использовать пользовательскую html-страницу, которую я написал для обращения к веб-сервису без Android, и он отлично работает:

<html>
<body>
<form action="http://xxxxxxxxxxx.local/hermes/incident/upload/" enctype="multipart/form-data" method="post">
server_id: <input type="text" name="server_id" />
<br />
file: <input type="file" name="image" />
<br />
<input type="submit" value="send" />
</form>
</body>
</html>

Так что я думаю, что что-то не так с тем, как я форматирую вызов на Android боковая сторона. Я бы предоставил журнал ошибок или трассировку стека, но их нет. Я смотрю журнал ошибок apache, но ничего не появляется. У кого-нибудь есть совет?

ИЗМЕНИТЬ : Итак, я настроил ведение журнала django и смог отладить свой метод загрузки, когда нажал на него с телефона. Кажется, он перестает работать, когда я говорю server_id = request.POST ['server_id'], поэтому каким-то образом этот фрагмент данных не устанавливается правильно, когда я делаю запрос в методе uploadFile. Кто-нибудь видел, как я неправильно выполняю запрос?

6
задан joshkendrick 12 December 2011 в 19:01
поделиться