0

我正在尝试使用改造为Meetup API实施 OAuth 2 身份验证。我有授权码,但无法获取访问令牌。这是所有相关的代码位:

我的 onResume 方法:

override fun onResume() {
    super.onResume()

    // the intent filter defined in AndroidManifest will handle the return from ACTION_VIEW intent
    val uri = intent.data
    if (uri != null && uri.toString().startsWith(CALL_BACK)) {
        val code = uri.getQueryParameter("code")
        if (code != null) {
            // get access token
            // we'll do that in a minute
            //"authorize code: $code".show(this)
            Log.i("Rakshak","Code: $code") // The Authorization Code is printed

            val loginService = ServiceGenerator.createService(LoginService::class.java)
            //var request = RequestBody(CLIENT_ID,CLIENT_SECRET,"authorization_code",CALL_BACK,code)
            val requestBody = "client_id=$CLIENT_ID"+
                              "&client_secret=$CLIENT_SECRET"+
                              "&grant_type=authorization_code"+
                              "&redirect_uri=$CALL_BACK+" +
                              "&code=$code"

            val call = loginService.getAccessToken(requestBody)
            //val accessToken = call.execute().body()

            call.enqueue(object : retrofit2.Callback<AccessToken>{
                override fun onResponse(call: Call<AccessToken>?, response: Response<AccessToken>?) {
                    Log.i("Rakshak","Response:  ${response.toString()}") // Prints: "Response{protocol=h2, code=400, message=, url=https://secure.meetup.com/oauth2/access}"
                    Log.i("Rakshak","Access token: ${response?.body()?.accessToken}")// Prints: "Access token: null"
                }

                override fun onFailure(call: Call<AccessToken>?, t: Throwable?) {
                    Log.i("Rakshak","Didn't work. ${t?.localizedMessage}")

                }

            })

        } else if (uri.getQueryParameter("error") != null) {
            // show an error message here
            "Didn't work. Code: $code".show(this)
        }
    }
}

登录服务界面:

interface LoginService {
@FormUrlEncoded
@POST("https://secure.meetup.com/oauth2/access")
fun getAccessToken(@Field("body") requestBody: String): Call<AccessToken>

}

请求体类:

data class RequestBody(
    var client_id:String,
    var client_secret: String,
    var grant_type: String,
    var redirect_uri: String,
    var code: String)

服务生成器类的相关方法:

private val API_BASE_URL = "https://secure.meetup.com/oauth2/access/"

private val httpClient = OkHttpClient.Builder()

private val builder = Retrofit.Builder()
        .baseUrl(API_BASE_URL)
        .addConverterFactory(GsonConverterFactory.create())

private var retrofit = builder.build()

fun <S> createService(serviceClass: Class<S>): S {
    return retrofit.create(serviceClass);
}

为什么对访问令牌 POST 的响应给我一个 400 响应而不是带有访问令牌的 JSON,就像它在这里描述的那样?我错过了什么?

4

1 回答 1

0

使用@Body注解意味着它将使用注册Converter的来序列化正文,因此它不会像文档描述的那样发送它,而是作为通过 GSON 编码的 JSON 对象发送。

您需要使用“表单编码”方法发送数据,查找改造文档的“表单编码和多部分”部分。

于 2017-09-02T17:55:39.807 回答