国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android使用OkHttp上傳圖片的實例代碼

2019-12-12 02:33:34
字體:
來源:轉載
供稿:網友

簡介

上傳圖片是一個APP的常見功能,可以是通過OOS上傳到阿里云,也可以直接上傳到Server后臺,OOS有提供相應的SDK,此處忽略。下面通過OkHttp來實現圖片的上傳

代碼

直接上代碼UploadFileHelper.kt

object UploadFileHelper { //--------ContentType private val MEDIA_OBJECT_STREAM = MediaType.parse("multipart/form-data") //--------上傳延時時間 private val WRITE_TIME_OUT:Long = 50 private val mOkHttpClient by lazy { OkHttpClient() } //------基本參數---------- val version = AppConstant.API_VERSION val platform = AppConstant.API_PLATFORM val methodName = AppConstant.API_UPLOADFILE_METHOD val token = ignoreException("") { UserModel.token() } val userId = ignoreException(0) { UserModel.id() } //------------------------ //不帶參數同步上傳文件 fun syncUploadFile(actionUrl: String = "",file: File,maxW: Int = 256,maxH: Int = 256):String?{  val uploadFile = optionFileSize(file,maxW,maxH,null)  if(uploadFile!=null){   val response = createNoParamsOkHttpCall(actionUrl,uploadFile).execute()   if(uploadFile.exists())    uploadFile.delete()   return getResponseToPath(response.body()!!.string())  }  return null } //不帶參數異步上傳文件 fun asyncUploadFile(actionUrl:String = "", file: File,maxW: Int = 256,maxH: Int = 256,      uploadCallBackListener: UploadCallBackListener? = null){  val uploadFile = optionFileSize(file,maxW,maxH,uploadCallBackListener)  if(uploadFile!=null)  createNoParamsOkHttpCall(actionUrl,uploadFile).enqueue(object: Callback{   override fun onFailure(c: Call, e: IOException) {    uploadCallBackListener?.onUploadFailure(e.toString())   }   override fun onResponse(c: Call, response: Response) {    if(uploadFile.exists())    uploadFile.delete()     uploadCallBackListener?.onUploadSuccess(getResponseToPath(response.body()!!.string()))    response.body()!!.close()   }  }) } //帶參數同步上傳文件 fun syncParamsUploadFile(actionUrl: String= "",file: File,params:HashMap<String,Any>,      maxW: Int = 256,maxH: Int = 256):String?{  val uploadFile = optionFileSize(file,maxW,maxH,null)  if(uploadFile!=null){   params.put("filename",uploadFile)   val response = createParamsOkHttpCall(actionUrl,params,null,false).execute()   if(uploadFile.exists())    uploadFile.delete()   return getResponseToPath(response.body()!!.string())  }  return null } //帶參數異步上傳文件 fun asyncParamsUploadFile(actionUrl: String= "",file: File,params:HashMap<String,Any>,maxW: Int = 256,maxH: Int = 256,      uploadCallBackListener: UploadCallBackListener? = null, isProgress:Boolean = true){  val uploadFile = optionFileSize(file,maxW,maxH,uploadCallBackListener)  if(uploadFile!=null){   params.put("filename",uploadFile)   createParamsOkHttpCall(actionUrl,params,uploadCallBackListener,isProgress).enqueue(object :Callback{    override fun onFailure(c: Call, e: IOException) {     uploadCallBackListener?.onUploadFailure(e.toString())    }    override fun onResponse(c: Call, response: Response) {      if(uploadFile.exists())      uploadFile.delete()     uploadCallBackListener?.onUploadSuccess(getResponseToPath(response.body()!!.string()))     response.body()!!.close()    }   })  } } //------創建一個沒有帶參數的Call fun createNoParamsOkHttpCall(actionUrl: String,file: File):Call{  val requestUrl = "${AppConstant.HOST}/$actionUrl"  val requestBody = RequestBody.create(MEDIA_OBJECT_STREAM,file)  val request = Request.Builder().url(requestUrl).post(requestBody).build()  return mOkHttpClient.newBuilder().writeTimeout(WRITE_TIME_OUT,TimeUnit.SECONDS).build().newCall(request) } //------創建一個帶參數的Call fun createParamsOkHttpCall(actionUrl: String,params:Map<String,Any>,        uploadCallBackListener: UploadCallBackListener? = null,        isProgress:Boolean = true):Call{  //-----AppConstant.HOST 上傳圖片的Server的BASE_URL http://xxx.com  val requestUrl = "${AppConstant.HOST}/$actionUrl"  val builder = MultipartBody.Builder()  builder.setType(MultipartBody.FORM)  val newParams = mutableMapOf(    "version" to version,    "platform" to platform,    "methodName" to methodName,    "token" to token,    "user_id" to userId)  newParams.putAll(params)  newParams.forEach( action = {   if(it.value is File){    builder.addFormDataPart(it.key, (it.value as File).name,    if(isProgress) createProgressRequestBody(MEDIA_OBJECT_STREAM!!,(it.value as File),uploadCallBackListener)    else RequestBody.create(null, (it.value as File)))   }else{    builder.addFormDataPart(it.key,it.value.toString())   }  })  val body = builder.build()  val request = Request.Builder().url(requestUrl).post(body).build()  return mOkHttpClient.newBuilder().writeTimeout(WRITE_TIME_OUT,TimeUnit.SECONDS).build().newCall(request) } //創建帶進度RequestBody fun createProgressRequestBody(contentType:MediaType,file:File,         uploadCallBackListener: UploadCallBackListener? = null):RequestBody{  return object:RequestBody(){   override fun contentType(): MediaType = contentType   override fun contentLength() = file.length()   override fun writeTo(sink: BufferedSink) {    ignoreException {     val source = Okio.source(file)     val buf = Buffer()     val remaining = contentLength()     var current: Long = 0     var readCount: Long = source.read(buf, 2048)     while (readCount != -1L) {      sink.write(buf, readCount)      current += readCount      uploadCallBackListener?.onUploadProgress(current,remaining)      readCount = source.read(buf, 2048)     }    }   }  } } //根據圖片大小簡單壓縮 fun optionFileSize(file: File,maxW:Int,maxH:Int,uploadCallBackListener: UploadCallBackListener?):File?{  try {   val uploadFile = File(AppBridge.AppContext().externalCacheDir, file.hashCode().toString())   ImageUtils.resize(file, maxW, maxH, uploadFile)   return uploadFile  } catch (e: Exception) {   uploadCallBackListener?.onUploadFailure("壓縮圖片失敗")   return null  } } //解析Server返回的數據獲取圖片路徑, /*  {"code":200,"msg":"上傳成功","data":{"path":""}} */ fun getResponseToPath(response:String):String{  val dataJsonObj = JSONObject(response).get("data") as JSONObject  return dataJsonObj.get("path") as String } //回調方法 interface UploadCallBackListener{  fun onUploadFailure(error:String)  fun onUploadProgress(currentSize:Long,totalSize:Long)  fun onUploadSuccess(path:String) }}
inline fun <T> ignoreException(def: T, f: () -> T): T { try {  return f() } catch(e: Exception) {  Timber.e(e, "")  return def }}

最后根據是否要帶參數、同步或異步調用其中對應的方法可以了

syncUploadFile(xxx)asyncUploadFile(xxx)syncParamsUploadFile(xxx)asyncParamsUploadFile(xxx)

總結

首先根據是否要帶參數上傳,如果不帶參數上傳,直接創建RequestBody;如果帶參數上傳,創建MultipartBody.Builder(),然后把所有參數addFormDataPart進去,其中addFormDataPart方法有個RequestBody參數通過是否要監聽進度創建,如果需要進度,需重寫RequestBody的writeTo()方法,如果不監聽進度,直接創建RequestBody,最后builder.build()得到RequestBody

通過上步驟得到的RequestBody以及上傳圖片的Server路徑,可以配置出一個Request對象。

把Request對象通過.newCall(request)配置在OkHttpClient得到Call對象

最后Call調用同步.execute()或者異步.enqueue(callBack),在回調里面處理返回的數據。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 闸北区| 扬州市| 读书| 泰顺县| 平度市| 寻甸| 通辽市| 西青区| 孟连| 桦甸市| 常熟市| 大城县| 区。| 达尔| 易门县| 巴彦淖尔市| 肥乡县| 谷城县| 柳林县| 沅江市| 永胜县| 方山县| 巢湖市| 新昌县| 宣恩县| 大竹县| 商南县| 无锡市| 桂东县| 卢龙县| 庆元县| 通化市| 明光市| 固安县| 交城县| 湖南省| 临漳县| 绩溪县| 十堰市| 买车| 甘洛县|