fix: use java.net.URLEncoder for form encoding (removes Ktor FormDataContent dependency), simplify postForm to use Map<String, String>

This commit is contained in:
yumoqing 2026-05-18 09:36:13 +08:00
parent b342ae85c6
commit 26ebfe132c
2 changed files with 11 additions and 6 deletions

View File

@ -79,11 +79,11 @@ class BricksHttp(private val context: BricksContext? = null) {
*/
suspend fun postForm(
url: String,
form: Parameters,
form: Map<String, String>,
authToken: String = ""
): String {
val formBody = form.flattenEntries().joinToString("&") { (k, v) ->
"${encodeURLParameter(k)}=${encodeURLParameter(v)}"
val formBody = form.entries.joinToString("&") { (k, v) ->
"${java.net.URLEncoder.encode(k, "UTF-8")}=${java.net.URLEncoder.encode(v, "UTF-8")}"
}
val response = client.post(url) {
contentType(ContentType.Application.FormUrlEncoded)

View File

@ -55,7 +55,9 @@ class SageClient {
_loginError.value = null
try {
val url = "$baseUrl/rbac/user/userpassword_login.dspy"
val formBody = "username=${encodeURLParameter(username)}&passwd=${encodeURLParameter(password)}"
val encodedUser = java.net.URLEncoder.encode(username, "UTF-8")
val encodedPass = java.net.URLEncoder.encode(password, "UTF-8")
val formBody = "username=$encodedUser&passwd=$encodedPass"
val response = client.post(url) {
contentType(ContentType.Application.FormUrlEncoded)
@ -138,7 +140,7 @@ class SageClient {
path: String,
params: Map<String, String> = emptyMap(),
method: String = "GET",
formBody: String = "",
formBody: Map<String, String> = emptyMap(),
jsonBody: JsonObject? = null
): Result<JsonObject> = mutex.withLock {
try {
@ -155,8 +157,11 @@ class SageClient {
setBody(jsonBody)
}
formBody.isNotEmpty() -> {
val bodyStr = formBody.entries.joinToString("&") { (k, v) ->
"${java.net.URLEncoder.encode(k, "UTF-8")}=${java.net.URLEncoder.encode(v, "UTF-8")}"
}
contentType(ContentType.Application.FormUrlEncoded)
setBody(formBody)
setBody(bodyStr)
}
}
}