2011-12-09 15 views
6

私はDjangoバックエンドとインターフェイスするAndroidアプリで作業しています。 mod_wsgiを使用してWebサービスをデプロイしました。多くのWebサービスコールが動作してテストされていますので、すべてが動作しているはずです。他のすべての呼び出しは正常に動作します。これは私が写真を送るためにAndroidで呼び出す方法です。AndroidでファイルをDjango Webサービスにアップロード

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内部を取得しますサーバーエラー、私は何が起こっているのか分からない。私は私がアンドロイドせずにWebサービスを打つために書いて、それが正常に動作するカスタムHTMLページを使用することができますので、このメソッドの動作を知っている:

<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のエラーログを見て、何も表示されません。誰でも助言がありますか?

EDIT : 私はdjangoのログを設定して、電話からヒットしたときにアップロードメソッドをデバッグできました。私は、server_id = request.POST ['server_id']と言ったときに動作を停止しているようです。何らかの理由で、uploadFileメソッドで要求を行うと、そのデータが正しく設定されていません。誰でも私が間違ってリクエストをやっているのを見てみましょうか?

+0

Apacheエラーログとは何ですか? –

+0

何もありません!笑それは全く役に立たない!私はmod_wsgiをセットアップしていましたが、エラーが見つかりましたが、このエラーは表示されませんでした。 – Josh

+0

問題はコンテンツタイプのヘッダーにある可能性がありますが、フォームを送信している可能性があります。 –

答えて

2

私が間違っていたことを理解しました。 djangoのロギングをセットアップした後、私はどこがクラッシュしているのかを確認することができました。私は "server_id"変数を取得しようとしたときにクラッシュしていました。私はその変数をヘッダとして設定するのではなく、文字列のボディとしてmultipartエンティティに追加することになりました。

関連する問題