我正在尝试调试,并找出无法正常工作的原因以及如何使其正常工作。
MainActivity.kt
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
...
fetchJson()
}
所以这只是调用了我的函数fetchJson
这是功能:
fun fetchJson() {
println("Attempting to Fetch JSON")
val url = "https://www.mocky.io/v2/5ed340ab340000650001f28c"
val request = Request.Builder().url(url).build()
val client = OkHttpClient()
client.newCall(request).enqueue(object: okhttp3.Callback {
override fun onFailure(call: okhttp3.Call, e: IOException) {
println("Failed to execute request")
}
override fun onResponse(call: okhttp3.Call, response: okhttp3.Response) {
val body = response?.body?.string()
println(body)
println("success")
val gson = GsonBuilder().create()
val homeFeed = gson.fromJson(body, note::class.java)
/* runOnUiThread {
recycler_view.adapter = MainAdapter(homeFeed)
}*/
}
})
其背后的想法是,您获取JSON数据并将其放入适配器类中,并在卡视图中显示它们。
我的问题不是适配器或卡视图,而是其余的API。它不想与我的模拟REST API一起使用,但可以与其他REST API一起使用。我不确定为什么吗?
我已经尝试添加网络安全异常,我不得不删除我的适配器类以使其成功。当我收到onresponse调用时,我仍然无法在控制台中找到JSON主体,并且因为我在调试控制台中没有收到错误,所以我不知道发生了什么。
我不知道这里什么不起作用。是GSON转换器吗?其余的API是我的代码吗?我的模拟器有问题吗?...等?
主体应打印到控制台的类:
class note(val noteis: List<Mlist>)
class Mlist(val text1: String, val text2: String, val text3: String)
我可以看到两个问题:
onFailure
方法中没有堆栈跟踪。让我们添加它:println("Failed to execute request, $e")
现在运行此命令将返回PKIX path building failed: (...) unable to find valid certification path to requested target
由于Java不信任来自www.mocky.io
的证书,因此失败。您可以通过更改OkHttpClient
的配置来添加或忽略它,但是现在让我们简单地将URL从https://
更改为http://
。
通过该更改,您应该将响应正文打印出来,如果不是这样,您的错误超出了提供的代码范围。
来自链接的JSON数据如下:
{
"Mlist": {
"text1": "text1a",
"text2": "text2a",
"text3": "text3a"
}
}
因此它不是Mlist
对象的列表,而是名为Mlist
的字段中的单个对象。为此,我们可以:
a)更改note
类中的字段名称
class note(val Mlist: Mlist)
b)使用@SerializedName
注释
@SerializedName("Mlist")
val notes: Mlist
顺便说一句。您可以将note
和Mlist
更改为data class
,以便可以使用print*
方法查看其内容。