【问题标题】:Retrofit's onFailure method gets called even after right response即使在正确响应之后,Retrofit 的 onFailure 方法也会被调用
【发布时间】:2018-08-28 12:31:03
【问题描述】:

以下是我在 PostMan 中的请求参数

{"assign_id":"1","type":2,"attendance_list":[{"stud_id":"1703","attendanceID":"1","stud_attendance":"4"},{"stud_id":"1704","attendanceID":"2","stud_attendance":"1"},{"stud_id":"1705","attendanceID":"3","stud_attendance":"1"},{"stud_id":"1706","attendanceID":"4","stud_attendance":"1"},{"stud_id":"1707","attendanceID":"5","stud_attendance":"1"},{"stud_id":"1727","attendanceID":"25","stud_attendance":"1"}]}

下面是回复

{"status":1,"msg":"Success"}

现在在我的 Android 应用程序中,我正在使用带有 Gson 的 Retrofit。但是通过Gson,我遇到了一些问题,所以我以jsonObjectjsonArrays的形式发送请求参数。

以下是我按下按钮向服务器提交请求时的代码

val jObjRequest = JsonObject()

                jObjRequest.addProperty("assign_id",ClassModelInstance.getInstance().classInfo.assignId)
                jObjRequest.addProperty("type","2")
                val attendanceArray = JsonArray()
                for(i in 0 until ClassModelInstance.getInstance().studentInfos.size){
                    val jsonObject = JsonObject()
                    jsonObject.addProperty("stud_id",ClassModelInstance.getInstance().studentInfos[i].studId)
                    jsonObject.addProperty("attendanceID",1)
                    jsonObject.addProperty("stud_attendance",ClassModelInstance.getInstance().studentInfos[i].studAttendance)
                    attendanceArray.add(jsonObject)
                }

                jObjRequest.addProperty("attendance_list",attendanceArray.toString())
                Log.i("PritishAttendanceApi2", jObjRequest.toString())

                val submitAttendanceInterface = ApiClient.client.create(SubmitAttendanceInterface::class.java)

                submitAttendanceInterface.takeAttendance(jObjRequest)
                                .enqueue(object : Callback<SubmitAttendanceResponse> {
                    override fun onFailure(call: Call<SubmitAttendanceResponse>, t: Throwable) {
                        activity?.let { it1 -> ToastMaker.make(it1,getString(R.string.something_went_wrong),Toast.LENGTH_LONG) }
                        Log.i("Pritish",t.message+"\t"+t.localizedMessage+"\t"+t.printStackTrace()+"\t"+t.cause+"\n"+call.request())
                        alertDialog.dismiss()
                    }

                    override fun onResponse(call: Call<SubmitAttendanceResponse>, response: Response<SubmitAttendanceResponse>) {
                        if(response.body()?.status.toString().equals("1",true)){
                            activity?.let { it1 -> ToastMaker.make(it1,response.body()?.msg.toString(),Toast.LENGTH_LONG) }
                            goToPreviousFragment()
                        } else {
                            activity?.let { it1 -> ToastMaker.make(it1,response.body()?.msg.toString(),Toast.LENGTH_LONG) }
                        }

                        alertDialog.dismiss()
                    }

                })

这是接口和响应类

interface SubmitAttendanceInterface {

    @Headers("Content-Type: application/json")
    @POST("timetable/takeAttendance")
    fun takeAttendance(@Body body: JsonObject): Call<SubmitAttendanceResponse>

}

data class SubmitAttendanceResponse(
        @SerializedName("status")
        @Expose
        var status: Int? = null,
        @SerializedName("msg")
        @Expose
        var msg: String? = null

)

当我使用HttpInterceptor 登录时,我得到com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected BEGIN_OBJECT but was STRING at line 2 column 1 path

我在 Stack Overflow 上搜索了上述错误,但答案不符合我的要求

JSON Error "java.lang.IllegalStateException: Expected BEGIN_OBJECT but was STRING at line 1 column 1 path $"

"Expected BEGIN_OBJECT but was STRING at line 1 column 1"

我已经在日志中编辑了网址,因为我不想公开网址。

【问题讨论】:

  • 将 httplogginginterceptor 添加到改造客户端以获取网络调用日志
  • @Nudge 请检查您是否使用正确的 url 进行发布请求并将正确的 json 正文发布到服务器。
  • @ManthanPatel 我正在使用它。请再次阅读我提到的问题。如果你愿意,我可以把日志发给你
  • 是发送日志
  • @Nainal 我使用了正确的网址。我查过了。

标签: android kotlin gson retrofit2


【解决方案1】:

根据您的日志和示例数据,您应该将数据“attendance_list”作为字符串插入的 json 数组发布

试试 jObjRequest.add("attendance_list",attendanceArray) 安装的 jObjRequest.addProperty("attendance_list",attendanceArray.toString())

【讨论】:

    猜你喜欢
    • 2014-10-22
    • 1970-01-01
    • 2013-10-09
    • 2014-05-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-08-14
    • 2021-04-04
    相关资源
    最近更新 更多