Android Kotlin Retrofit Post 请求输入的数据未发送
Android Kotlin Retrofit Post Request Inputted data does not sent
所以我必须处理 POST 请求,其正文数据取自表单中的某些输入。
此服务的端点是 https://someUrl.com/switching-product/switch?orderID=A002&procode=0200011&nip=P19120
从 Postman 返回的 Response 就像 this。
这个请求的正文是这样的:
在这种情况下,我有这个接口来处理 POST 请求:
///Endpoint: https://someUrl.com/switching-product/switch?orderID=A002&procode=0200011&nip=P19120
interface editProductDetail{
@FormUrlEncoded
@POST("switch")
fun editProductDetail(@Query("orderID") orderID: String,
@Query("procode") procode: String,
@Query("nip") nip : String,
@Field("procode_new") procodeNew: String,
@Field("item_qty_new") itemQtyNew: String,
@Field("item_price_new") itemPriceNew: String,
@Field("item_name_new") itemNameNew: String,
@Field("total_price_new") totalPriceNew: String): Call<OutstandingOrderDetailPOJODataClassDetailItem>
}
这是数据class 我使用:
data class OutstandingOrderDetailPOJODataClassDetailItem(
@field:SerializedName("item_price_new")
val itemPriceNew: Int? = null,
@field:SerializedName("item_name_new")
val itemNameNew: String? = null,
@field:SerializedName("total_price")
val totalPrice: Int? = null,
@field:SerializedName("item_price")
val itemPrice: Int? = null,
@field:SerializedName("item_name")
val itemName: String? = null,
@field:SerializedName("status_refund")
val statusRefund: String? = null,
@field:SerializedName("detail_id")
val detailId: Int? = null,
@field:SerializedName("procode_new")
val procodeNew: String? = null,
@field:SerializedName("refund_date")
val refundDate: String? = null,
@field:SerializedName("request_refund")
val requestRefund: String? = null,
@field:SerializedName("procode")
val procode: String? = null,
@field:SerializedName("last_update")
val lastUpdate: String? = null,
@field:SerializedName("item_qty_new")
val itemQtyNew: Int? = null,
@field:SerializedName("order_id")
val orderId: String? = null,
@field:SerializedName("total_price_new")
val totalPriceNew: Int? = null,
@field:SerializedName("item_qty")
val itemQty: Int? = null,
@field:SerializedName("refund")
val refund: Int? = null
)
正如您在上面看到的,正文也具有包含在数据中的属性 class。 (此数据class也用于使用此服务输入数据的App中的相关服务。
这是触发 POST 请求的函数:
NetworkConfig().editOutstandingOrderProductDetailService().editProductDetail(
selectedOrderId,
selectedProcode,
selectedNip,
procodeNew,
itemNewQty,
itemPriceNew,
itemNewName,
totalPriceNew
).enqueue(object :
Callback<OutstandingOrderDetailPOJODataClassDetailItem> {
override fun onFailure(call: Call<OutstandingOrderDetailPOJODataClassDetailItem>, t: Throwable) {
Log.i("Order", "It Failed!!")
if (call.isCanceled) {
Toast.makeText((activity as AppCompatActivity), "Request Aborted", Toast.LENGTH_SHORT).show()
} else {
Toast.makeText((activity as AppCompatActivity), t.localizedMessage, Toast.LENGTH_SHORT).show()
}
}
override fun onResponse(
call: Call<OutstandingOrderDetailPOJODataClassDetailItem>,
response: Response<OutstandingOrderDetailPOJODataClassDetailItem>
) {
Log.i("Order", "Switching Process done!!!")
Log.i("Order", "Status: ${response.body()}")
}
})
从上面看,它在 logCat 中打印响应,如下所示:
我是不是漏掉了什么?或者有什么我需要改变的?如果有任何我遗漏的细节,请告诉我!
您的请求是 JSON object
,而不是 formurl
。
当您想将参数作为 formurl
传递时,使用 @Field
标签
使用模型class或JsonObject和@Body标签来传递参数为JsonObject
.
模型 class 例如,
data class TestClass{
val text1: String,
val text2: String
}
现在将此 class 作为请求传递
@POST("URL")
fun apiName(@Body request: TestClass);
JSON 对象示例,
JSONObject paramObject = new JSONObject();
paramObject.put("key1", "value1");
paramObject.put("key1", "vaalue2");
现在将其作为 String
或 JsonObject
传递
@POST("URL")
fun apiName(@Body request: String); // pass as String
所以我必须处理 POST 请求,其正文数据取自表单中的某些输入。
此服务的端点是 https://someUrl.com/switching-product/switch?orderID=A002&procode=0200011&nip=P19120
从 Postman 返回的 Response 就像 this。
这个请求的正文是这样的:
在这种情况下,我有这个接口来处理 POST 请求:
///Endpoint: https://someUrl.com/switching-product/switch?orderID=A002&procode=0200011&nip=P19120
interface editProductDetail{
@FormUrlEncoded
@POST("switch")
fun editProductDetail(@Query("orderID") orderID: String,
@Query("procode") procode: String,
@Query("nip") nip : String,
@Field("procode_new") procodeNew: String,
@Field("item_qty_new") itemQtyNew: String,
@Field("item_price_new") itemPriceNew: String,
@Field("item_name_new") itemNameNew: String,
@Field("total_price_new") totalPriceNew: String): Call<OutstandingOrderDetailPOJODataClassDetailItem>
}
这是数据class 我使用:
data class OutstandingOrderDetailPOJODataClassDetailItem(
@field:SerializedName("item_price_new")
val itemPriceNew: Int? = null,
@field:SerializedName("item_name_new")
val itemNameNew: String? = null,
@field:SerializedName("total_price")
val totalPrice: Int? = null,
@field:SerializedName("item_price")
val itemPrice: Int? = null,
@field:SerializedName("item_name")
val itemName: String? = null,
@field:SerializedName("status_refund")
val statusRefund: String? = null,
@field:SerializedName("detail_id")
val detailId: Int? = null,
@field:SerializedName("procode_new")
val procodeNew: String? = null,
@field:SerializedName("refund_date")
val refundDate: String? = null,
@field:SerializedName("request_refund")
val requestRefund: String? = null,
@field:SerializedName("procode")
val procode: String? = null,
@field:SerializedName("last_update")
val lastUpdate: String? = null,
@field:SerializedName("item_qty_new")
val itemQtyNew: Int? = null,
@field:SerializedName("order_id")
val orderId: String? = null,
@field:SerializedName("total_price_new")
val totalPriceNew: Int? = null,
@field:SerializedName("item_qty")
val itemQty: Int? = null,
@field:SerializedName("refund")
val refund: Int? = null
)
正如您在上面看到的,正文也具有包含在数据中的属性 class。 (此数据class也用于使用此服务输入数据的App中的相关服务。
这是触发 POST 请求的函数:
NetworkConfig().editOutstandingOrderProductDetailService().editProductDetail(
selectedOrderId,
selectedProcode,
selectedNip,
procodeNew,
itemNewQty,
itemPriceNew,
itemNewName,
totalPriceNew
).enqueue(object :
Callback<OutstandingOrderDetailPOJODataClassDetailItem> {
override fun onFailure(call: Call<OutstandingOrderDetailPOJODataClassDetailItem>, t: Throwable) {
Log.i("Order", "It Failed!!")
if (call.isCanceled) {
Toast.makeText((activity as AppCompatActivity), "Request Aborted", Toast.LENGTH_SHORT).show()
} else {
Toast.makeText((activity as AppCompatActivity), t.localizedMessage, Toast.LENGTH_SHORT).show()
}
}
override fun onResponse(
call: Call<OutstandingOrderDetailPOJODataClassDetailItem>,
response: Response<OutstandingOrderDetailPOJODataClassDetailItem>
) {
Log.i("Order", "Switching Process done!!!")
Log.i("Order", "Status: ${response.body()}")
}
})
从上面看,它在 logCat 中打印响应,如下所示:
我是不是漏掉了什么?或者有什么我需要改变的?如果有任何我遗漏的细节,请告诉我!
您的请求是 JSON object
,而不是 formurl
。
当您想将参数作为 formurl
@Field
标签
使用模型class或JsonObject和@Body标签来传递参数为JsonObject
.
模型 class 例如,
data class TestClass{
val text1: String,
val text2: String
}
现在将此 class 作为请求传递
@POST("URL")
fun apiName(@Body request: TestClass);
JSON 对象示例,
JSONObject paramObject = new JSONObject();
paramObject.put("key1", "value1");
paramObject.put("key1", "vaalue2");
现在将其作为 String
或 JsonObject
@POST("URL")
fun apiName(@Body request: String); // pass as String