English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
In precedenza, il caricamento delle immagini avveniva direttamente convertendo le immagini in stream IO e inviandole al server, senza utilizzare framework per trasmettere immagini.
Recentemente, mentre lavoravo su un progetto, ho deciso di cambiare metodo per caricare immagini.
Sviluppando Android ora, Okhttp è diventato sempre più importante, quindi questa volta ho scelto di caricare immagini utilizzando Okhttp.
Okhttp è ora aggiornato alla versione Okhttp3, rispetto alla versione precedente ci sono alcune differenze. Ho trovato molti materiali online,
Dopo molte prove e debug con i colleghi backend in Java, è stato finalmente possibile caricare più immagini e trasmettere alcuni parametri come coppie chiave-valore.
Di seguito è la mia implementazione di questo processo:
private static final MediaType MEDIA_TYPE_PNG = MediaType.parse("image/png"); /** * caricamento di più immagini e parametri * @param reqUrl indirizzo URL * @param params parametri * @param pic_key chiave di upload immagine * @param paths immagine percorso */ public Observable<String> sendMultipart(String reqUrl,Map<String, String> params,String pic_key, List<File> files){ return Observable.create(new Observable.OnSubscribe<String>(){ @Override public void call(Subscriber<? super String> subscriber) { MultipartBody.Builder multipartBodyBuilder = new MultipartBody.Builder(); multipartBodyBuilder.setType(MultipartBody.FORM); //通过遍历map中所有参数到builder if (params != null){ for (String key : params.keySet()) { multipartBodyBuilder.addFormDataPart(key, params.get(key)); } } // Aggiungi tutti i percorsi assoluti delle immagini in paths al builder, e约定key come "upload" per accettare più immagini in background if (files != null){ for (File file : files) { multipartBodyBuilder.addFormDataPart(pic_key, file.getName(), RequestBody.create(MEDIA_TYPE_PNG, file)); } } // Costruisci il corpo della richiesta RequestBody requestBody = multipartBodyBuilder.build(); Request.Builder RequestBuilder = new Request.Builder(); RequestBuilder.url(reqUrl);// Aggiungi l'indirizzo URL RequestBuilder.post(requestBody); Request request = RequestBuilder.build(); mOkHttpClient.newCall(request).enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { subscriber.onError(e); subscriber.onCompleted(); call.cancel(); } @Override public void onResponse(Call call, Response response) throws IOException { String str = response.body().string(); subscriber.onNext(str); subscriber.onCompleted(); call.cancel(); } }); } }); }
Chiamata nell'interfaccia utente UI:
OkHttp3Utils.getInstance().sendMultipart(Constants.URL.URL_ADD_NOTICE, mMap, "appendix", mImageList) .observeOn(AndroidSchedulers.mainThread()) .subscribeOn(Schedulers.newThread()) .subscribe(new Subscriber<String>() { @Override public void onCompleted() { } @Override public void onError(Throwable throwable) { LogUtil.i(TAG, "throwable:\" + throwable.toString()); } @Override public void onNext(String s) { LogUtil.i(TAG, "s:\" + s); } });
Durante il debug, una volta ho scritto multipartBodyBuilder.addFormDataPart(pic_key, file.getName(), RequestBody.create(MEDIA_TYPE_PNG, file)); come multipartBodyBuilder.addFormDataPart(pic_key, null, RequestBody.create(MEDIA_TYPE_PNG, file));, il che ha causato che il server non potesse ottenere l'immagine in modo convenzionale (anche se i dati dell'immagine erano visibili durante il debug con breakpoint), questo punto deve essere notato.
Questo è tutto il contenuto dell'articolo, spero che sia utile per la tua apprendimento e ti auguro di sostenere fortemente la guida di urla.
Dichiarazione: il contenuto di questo articolo è stato tratto da Internet, il diritto d'autore spetta ai rispettivi detentori. Il contenuto è stato contribuito e caricato autonomamente dagli utenti di Internet, il sito web non detiene il diritto di proprietà, non è stato editato manualmente e non assume alcuna responsabilità legale. Se trovi contenuti sospetti di violazione del copyright, invia una e-mail a notice#oldtoolbag.com (sostituisci # con @) per segnalare il problema e fornire prove pertinenti. Una volta verificata la veridicità, il sito web rimuoverà immediatamente il contenuto sospetto di violazione del copyright.