前后端交互——上传文件与FormData,闭关60天学懂NDK+Flutter
// 假设我们有一个用于上传文件的函数,我们将使用Kotlin + Android的方式来实现它
// 上传文件的函数
fun uploadFile(fileUri: Uri, context: Context) {
// 创建RequestBody,用于封装文件数据
val requestBody = fileUri.toFile().asRequestBody("multipart/form-data".toMediaType())
// 创建MultipartBody.Part,用于封装文件和其他表单字段
val filePart = MultipartBody.Part.createFormData("file", fileUri.toFile().name, requestBody)
// 添加其他表单字段
val additionalPart = MultipartBody.Part.createFormData("username", "exampleUser")
// 创建Retrofit实例
val retrofit = Retrofit.Builder()
.baseUrl("http://your-api-url.com/") // 替换为你的API URL
.addConverterFactory(GsonConverterFactory.create())
.build()
// 创建API接口的实例
val service = retrofit.create(FileUploadService::class.java)
// 发送文件和其他数据到服务器
val call = service.uploadFile(filePart, additionalPart)
call.enqueue(object : Callback<ResponseBody> {
override fun onResponse(call: Call<ResponseBody>, response: Response<ResponseBody>) {
// 处理响应
Log.d("Upload", "success: ${response.body()}")
}
override fun onFailure(call: Call<ResponseBody>, t: Throwable) {
// 处理错误
Log.e("Upload", "failure: ${t.message}")
}
})
}
// 定义用于上传文件的API接口
interface FileUploadService {
@Multipart
@POST("upload")
fun uploadFile(
@Part file: MultipartBody.Part,
@Part("username") username: RequestBody
): Call<ResponseBody>
}
// 使用示例
// 假设我们有一个Uri对象,指向我们想要上传的文件
val fileUri: Uri = ...
val context: Context = ...
uploadFile(fileUri, context)
这个代码示例展示了如何在Android中使用Retrofit库和OkHttp来上传文件和其他表单数据。它使用了MultipartBody.Part
来封装文件和RequestBody
来封装表单字段。通过调用API接口的uploadFile
方法,我们可以将文件和数据发送到服务器。这个例子提供了一个简洁的函数uploadFile
,用于封装文件上传的逻辑,并且展示了如何使用Retrofit进行异步网络请求。
评论已关闭