2017-02-28 4 views
0

développeur android débutant ici. J'essaie de POSTER un fichier .gpx à ma base de données Web. Cependant, je reçois l'erreur de réponse de HTTP 415. Je sais que 415 signifie le type de contenu incorrect et l'API que j'essaye d'employer a ce code. Merci pour tous les conseils!Android multiposte POST http Demande 415 Erreur

 // Test that request has correct content type 
     if (!Request.Content.IsMimeMultipartContent()) 
     { 
      throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType); 
     } 

Je suivais ce tutoriel http://www.codejava.net/java-se/networking/upload-files-by-sending-multipart-request-programmatically.

Ceci est mon Http Demande classe

/** 
* This constructor initializes a new HTTP POST request with content type 
* is set to multipart/form-data 
* @param requestURL 
* @param charset 
* @throws IOException 
*/ 
public MultipartUtility(String requestURL, String charset) 
     throws IOException { 
    this.charset = charset; 

    // creates a unique boundary based on time stamp 
    boundary = "===" + System.currentTimeMillis() + "==="; 

    URL url = new URL(requestURL); 
    httpConn = (HttpURLConnection) url.openConnection(); 
    httpConn.setUseCaches(false); 
    httpConn.setDoOutput(true); // indicates POST method 
    httpConn.setDoInput(true); 
    httpConn.setRequestMethod("POST"); 

    httpConn.setRequestProperty("Connection", "Keep-Alive"); 
    httpConn.setRequestProperty("Content-Type", // content type multipart (FILE) 
      "multipart/form-data; boundary=" + boundary); 
    httpConn.setRequestProperty("Authorization", UserInfo.User.getToken()); 
    outputStream = httpConn.getOutputStream(); 
    writer = new PrintWriter(new OutputStreamWriter(outputStream, charset), 
      true); 
} 

/** 
* Adds a form field to the request 
* @param name field name 
* @param value field value 
*/ 
public void addFormField(String name, String value) { 
    writer.append("--" + boundary).append(LINE_FEED); 
    writer.append("Content-Disposition: form-data; name=\"" + name + "\"") 
      .append(LINE_FEED); 
    //writer.append("Content-Type: text/plain; charset=" + charset).append(LINE_FEED); 
    writer.append(LINE_FEED); 
    writer.append(value).append(LINE_FEED); 
    writer.flush(); 
} 

/** 
* Adds a upload file section to the request 
* @param fieldName name attribute in <input type="file" name="..." /> 
* @param uploadFile a File to be uploaded 
* @throws IOException 
*/ 
public void addFilePart(String fieldName, File uploadFile) 
     throws IOException { 
    String fileName = uploadFile.getName(); 
    writer.append("--" + boundary).append(LINE_FEED); 
    writer.append(
      "Content-Disposition: form-data; name=\"" + fieldName 
        + "\"; filename=\"" + fileName + "\""); 
    //Log.i("fileName",fileName); 
    writer.append("Content-Type: " + "multipart/form-data; boundary=" + boundary); 
    //.append("Content-Transfer-Encoding: binary").append(LINE_FEED); 
    writer.append(LINE_FEED); 
    writer.flush(); 

    FileInputStream inputStream = new FileInputStream(uploadFile); 
    byte[] buffer = new byte[4096]; 
    int bytesRead = -1; 
    while ((bytesRead = inputStream.read(buffer)) != -1) { 
     outputStream.write(buffer, 0, bytesRead); 
    } 
    outputStream.flush(); 
    inputStream.close(); 

    writer.append(LINE_FEED); 
    writer.flush(); 
} 

/** 
* Adds a header field to the request. 
* @param name - name of the header field 
* @param value - value of the header field 
*/ 
public void addHeaderField(String name, String value) { 
    writer.append(name + ": " + value).append(LINE_FEED); 
    writer.flush(); 
    //Log.i("header",name + ": " + value); 
} 

/** 
* Completes the request and receives response from the server. 
* @return a list of Strings as response in case the server returned 
* status OK, otherwise an exception is thrown. 
* @throws IOException 
*/ 
public List<String> finish() throws IOException { 
    List<String> response = new ArrayList<String>(); 

    writer.append(LINE_FEED).flush(); 
    writer.append("--" + boundary + "--").append(LINE_FEED); 
    writer.close(); 

    // checks server's status code first 
    int status = httpConn.getResponseCode(); 
    if (status == HttpURLConnection.HTTP_OK) { 
     BufferedReader reader = new BufferedReader(new InputStreamReader(
       httpConn.getInputStream())); 
     String line = null; 
     while ((line = reader.readLine()) != null) { 
      response.add(line); 
     } 
     reader.close(); 
     httpConn.disconnect(); 
    } else { 
     throw new IOException("Server returned non-OK status: " + status); 
    } 

    return response; 
} 

Ceci est mon activité

 String requestURL = "url"; 


     try { 
      MultipartUtility multipart = new MultipartUtility(requestURL, charset); 

      multipart.addFilePart("filename", File); 

      List<String> response = multipart.finish(); 

      System.out.println("SERVER REPLIED:"); 

      for (String line : response) { 
       System.out.println(line); 
      } 
     } catch (IOException ex) { 
      System.err.println(ex); 
     } 
    } 

Ceci est ma réponse de httpbin

/*I/System.out: SERVEUR REPONDU:

I/System.out: {

I/System.out: "args": {},

I/System.out: "data": "",

I/System.out: "Fichiers": {

I/System.out: "NomFichier": "http: //www.topografix.com/GPX/1/1 \" version = \ "1.0 \"> \ n \ n \ r \ n "

I/System.out:},

I/System.out: "forme": {},

I/système. out: "têtes": {

I/System.out: "Accept-Encoding": "gzip",

I/System.out: "Autorisation": "Bearer",

I /System.out: "Content-Length": "322",

I/System.out: "Type de contenu": "multipart/form-data; limite ==== === 1488396069658 "

I/System.out: "Hôte": "httpbin.org",

I/System.out: "User-Agent":" Dalvik /2.1.0 (Linux, U, Android 7.0, Android SDK construit pour x86 construire/NYC) »

I/System.out:},

I/System.out: "JSON": null,

I/System.out: "origine": "50.174.210.222",

I/System.out: "url": "http://httpbin.org/post"

I/System.out:} */

SI QUELQU'UN EST AUTRE PRESENTANT CE TROUBLE .. J'UTILISÉ RETROFIT2 POUR RÉUSSIR UPLOAD MON DOSSIER.

//Retrofit2 method 
public void uploadFile() { 

    OkHttpClient.Builder okHttpClientBuilder = new OkHttpClient.Builder(); 
    HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor(); 
    interceptor.setLevel(HttpLoggingInterceptor.Level.BODY); 
    okHttpClientBuilder.addInterceptor(interceptor); 

    okHttpClientBuilder.addInterceptor(new Interceptor() { 
     @Override 
     public okhttp3.Response intercept(Chain chain) throws IOException { 
      okhttp3.Request original = chain.request(); 

      okhttp3.Request.Builder requestBuilder = original.newBuilder() 
        .header("Authorization", UserInfo.User.getToken()); 

      okhttp3.Request request = requestBuilder.build(); 
      return chain.proceed(request); 
     } 
    }); 


    MediaType MEDIA_TYPE_XML = MediaType.parse("application/xml"); 

    RequestBody filePart = RequestBody.create(MEDIA_TYPE_XML, gpx); 

    MultipartBody.Part file = MultipartBody.Part.createFormData("Track", gpx.getName(), filePart); 

    Retrofit.Builder builder = new Retrofit.Builder() 
      .baseUrl("URL") 
      .addConverterFactory(GsonConverterFactory.create()) 
      .client(okHttpClientBuilder.build()); 

    Retrofit retrofit = builder.build(); 

    UserClient client = retrofit.create(UserClient.class); 

    Call<ResponseBody> call = client.uploadFile(file); 
    call.enqueue(new Callback<ResponseBody>() { 
     @Override 
     public void onResponse(Call<ResponseBody> call, retrofit2.Response<ResponseBody> response) { 
      Log.i("works", call.toString()); 
     } 

     @Override 
     public void onFailure(Call<ResponseBody> call, Throwable t) { 
      Log.i("Fail", "gg"); 
     } 
    }); 
} 

Mon interface

interface publique UserClient {

@Multipart 
@POST("Gpx") 
Call<ResponseBody> uploadFile(
     @Part MultipartBody.Part File 
     ); 

}

+0

passage à retrofit2 télécharger est multipart easy.https: //futurestud.io/tutorials/retrofit-2-how-to-upload-files-to-server – Remario

+0

J'ai essayé .. très difficile à déboguer. J'ai reçu une réponse réussie, mais je ne peux pas le voir .. – HelpinCodingpls

+0

oh utiliser l'okcepteur intercepter pour se connecter. – Remario

Répondre

0
public static <C> C createService(Class<C> cClass) { 
     HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor(); 
     interceptor.setLevel(HttpLoggingInterceptor.Level.BODY); 
     OkHttpClient client = new OkHttpClient.Builder().addInterceptor(interceptor).build(); 
     Retrofit retrofit = new Retrofit.Builder() 
       .client(client) 
       .baseUrl(UrlManager.Manager.BASE_URL) 
       .build(); 
     return retrofit.create(cClass); 
    } 

ce code crée une usine se connecte ensuite toutes les demandes ware du milieu. Ce code une fois appelé, chaque contenu par rapport à la requête sera log automatiquement dans logcat. vous pouvez filtrer en tapant okHTTp.

Pour utiliser l'intercepteur: inclure compile 'com.squareup.okhttp3:logging-interceptor:3.3.1'

+0

Comment puis-je l'utiliser pour voir les journaux? – HelpinCodingpls

+0

https://futurestud.io/tutorials/retrofit-getting-started-and-android-client lire sur la rénovation. – Remario

+0

Oui, certains où dans votre code, il y a une erreur de syntaxe. côté serveur qui est.Debug votre serveur ligne par ligne, – Remario