проблема при попытке вызвать мой API - AndroidRuntime: неустранимое исключение: OkHttp Dispatcher - PullRequest
0 голосов
/ 02 апреля 2019

Я нашел ответ: Я просто забыл проанализировать ответ в json с помощью Gson в методе loginAction ()

private fun loginAction(user: String)
    {
        UserService.userLogin(user, {
            response ->
            val token = response.header("x-auth")
            val userData = Gson().fromJson(response.body()!!.string(), User::class.java)
            createUserSession(baseContext, userData, token)

            this.openHomeActivity()
        },
        {
            error ->
            Log.d("ERROR", error.toString())
        })
    }

Я пытаюсь добавить активность входа в свое мобильное приложение, используя внешний API для проверки электронной почты и пароля. Я использую OkHttp 3.14.0 для подключения к API, но я получаю эту ошибку, когда пытаюсь подключить своего пользователя:

2019-04-02 13:37:10.630 5118-5176/fr.myapp.firstapp E/AndroidRuntime: FATAL EXCEPTION: OkHttp Dispatcher
    Process: fr.myapp.firstapp, PID: 5118
    java.lang.Error: org.json.JSONException: End of input at character 0 of 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1173)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
        at java.lang.Thread.run(Thread.java:764)
     Caused by: org.json.JSONException: End of input at character 0 of 
        at org.json.JSONTokener.syntaxError(JSONTokener.java:449)
        at org.json.JSONTokener.nextValue(JSONTokener.java:97)
        at org.json.JSONObject.<init>(JSONObject.java:159)
        at org.json.JSONObject.<init>(JSONObject.java:176)
        at fr.myapp.firstapp.LoginActivity$loginAction$1.invoke(LoginActivity.kt:44)
        at fr.myapp.firstapp.LoginActivity$loginAction$1.invoke(LoginActivity.kt:15)
        at fr.myapp.firstapp.network.UserService$Companion$userLogin$1.onResponse(UserService.kt:21)
        at okhttp3.RealCall$AsyncCall.execute(RealCall.java:174)
        at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641) 
        at java.lang.Thread.run(Thread.java:764) 

вот мой логин:

class LoginActivity : AppCompatActivity() {

    lateinit var usernameInput: EditText
    lateinit var passwordInput: EditText
    lateinit var loginBtn: Button

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.login_activity)

        this.usernameInput = findViewById(R.id.login_username_input)
        this.passwordInput = findViewById(R.id.login_password_input)
        this.loginBtn = findViewById(R.id.login_action_btn)

        loginBtn.setOnClickListener { this.loginAction(this.loginInfo()) }
    }

    private fun openHomeActivity()
    {
        val intent = Intent(this, HomeActivity::class.java)
        startActivity(intent)
        finish()
    }

    private fun loginAction(user: String)
    {
        UserService.userLogin(user, {
            response ->
            val jsonData: String = response.body()!!.string()
            val userObj = JSONObject(jsonData)

            createUserSession(this, userObj)
            this.openHomeActivity()
        },
        {
            error ->
            Log.d("ERROR", error.toString())
        })
    }

    private fun loginInfo(): String
    {
        val username: String = this.usernameInput.text.toString()
        val password: String = this.passwordInput.text.toString().sha512()
        val data = JSONObject()
            .put("username", username)
            .put("password", password)

        return data.toString()
    }
}

и мой пользовательский сервис:

class UserService {
    companion object {
        private val JSON = MediaType.get("application/json; charset=utf-8")

        fun userLogin(data: String, success: (success: Response) -> Unit, failure: (error: IOException) -> Unit)
        {
            val body = RequestBody.create(this.JSON, data)
            val request: Request = Request.Builder()
                .url(UrlBuilder.api + "/user/login")
                .post(body)
                .build()

            OkHttpClient().newCall(request).enqueue(object: Callback {
                override fun onResponse(call: Call, response: Response) = success(response)
                override fun onFailure(call: Call, e: IOException) = failure(e)
            })
        }
}

Я также добавил авторизацию для подключения к Интернету в моем AndroidManifest.xml:

<uses-permission android:name="android.permission.INTERNET"/>

Спасибо за вашу помощь

PS: извините за мой английский, это не мой основной язык

1 Ответ

0 голосов
/ 03 апреля 2019

Я нашел ответ: я просто забыл проанализировать ответ в json, используя Gson в методе loginAction ()

private fun loginAction(user: String)
    {
        UserService.userLogin(user, {
            response ->
            val token = response.header("x-auth")
            val userData = Gson().fromJson(response.body()!!.string(), User::class.java)
            createUserSession(baseContext, userData, token)

            this.openHomeActivity()
        },
        {
            error ->
            Log.d("ERROR", error.toString())
        })
    }
...