Android原生HttpURLConnection上传图片方案

创建上传方法

Kotlin 复制代码
object FormUploader {
    private val BOUNDARY = "Boundary-" + System.currentTimeMillis()
    private const val LINE_FEED = "\r\n"

    @Throws(IOException::class)
    fun uploadImage(url: String, imageFile: File, params: MutableMap<String?, String?>): String {
        val connection = URL(url).openConnection() as HttpURLConnection
        connection.setRequestMethod("POST")
        connection.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + BOUNDARY)
        connection.setDoOutput(true)

        connection.getOutputStream().use { outputStream ->
            DataOutputStream(outputStream).use { writer ->

                // 写入文本参数
                for (entry in params.entries) {
                    writer.writeBytes("--" + BOUNDARY + LINE_FEED)
                    writer.writeBytes("Content-Disposition: form-data; name=\"" + entry.key + "\"" + LINE_FEED)
                    writer.writeBytes(LINE_FEED)
                    writer.writeBytes(entry.value + LINE_FEED)
                }

                // 写入文件数据
                writer.writeBytes("--" + BOUNDARY + LINE_FEED)
                writer.writeBytes("Content-Disposition: form-data; name=\"file\"; filename=\"" + imageFile.getName() + "\"" + LINE_FEED)
                writer.writeBytes("Content-Type: image/*" + LINE_FEED)
                writer.writeBytes(LINE_FEED)

                Files.copy(imageFile.toPath(), outputStream)
                writer.writeBytes(LINE_FEED)
                writer.writeBytes("--" + BOUNDARY + "--" + LINE_FEED)
            }
        }
        // 处理响应
        return readResponse(connection)
    }

    @Throws(IOException::class)
    private fun readResponse(connection: HttpURLConnection): String {
        BufferedReader(InputStreamReader(connection.getInputStream())).use { reader ->
            val response = StringBuilder()
            var line: String?
            while ((reader.readLine().also { line = it }) != null) {
                response.append(line)
            }
            return response.toString()
        }
    }

调用上传图片方法

Kotlin 复制代码
 viewModelScope.launch(Dispatchers.IO) {
                    LogUtils.w("开始上传了........................")
                    val map = mutableMapOf<String?, String?>()
                    map.put("appKey", "123456")
                    map.put("token", "eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiIxNzg3Mzg0NTA4OSIsImxvZ2luX3VzZXJfa2V5IjoiZjFkMGRkODEtNzg2ZC00YzE1LWE4ZmYtYmQxZWM1Njk2M2I5")
                    map.put("timestamp", "2025-08-26 17:01:15")
                    map.put("ver", "1.0")
                    map.put("sign", "0ecbff7239c7650b75637522683ec7d")
                    val result = FormUploader.uploadImage(
                        "https://127.0.0.1/gatewayApi/sign/common/commonDeal/upload",
                        intent.file,
                        map
                    )
                    LogUtils.w("上传完成结果:$result")
相关推荐
Doro再努力8 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
Daniel李华9 小时前
echarts使用案例
android·javascript·echarts
做人不要太理性10 小时前
CANN Runtime 运行时组件深度解析:任务调度机制、存储管理策略与维测体系构建逻辑
android·运维·魔珐星云
我命由我1234510 小时前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
朗迹 - 张伟10 小时前
Tauri2 导出 Android 详细教程
android
lpruoyu11 小时前
【Android第一行代码学习笔记】Android架构_四大组件_权限_持久化_通知_异步_服务
android·笔记·学习
独自破碎E12 小时前
【BISHI15】小红的夹吃棋
android·java·开发语言
李堇15 小时前
android滚动列表VerticalRollingTextView
android·java
lxysbly16 小时前
n64模拟器安卓版带金手指2026
android
游戏开发爱好者819 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview