从 http 请求 android 获取内容,内容格式错误

Getting content from http request android, conent ill-formed

我正在尝试使用 OAuth2 方法连接到 Twitter API 以获取不记名令牌。 我正在使用 AsyncTask 调用 Twitter。我的请求似乎已被接受并且 return 和 error code 200,但是当我尝试读取应该包含我想要的令牌的内容时,但格式很奇怪,而且内容-响应的长度。

我是按照这个link来搭建的。

这是我用来发出请求的AsyncTask

private class RequestBearerTockenTask extends AsyncTask<String, Integer, String> {
    @Override
    protected String doInBackground(String... string) {

        // On récupère les keys passées en paramètre
        String consumerKey = string[0];
        String secretKey = string[1];

        // On encode en base64 le bearerToken en accord avec la doc twitter
        String base64encodedBearerToken = Base64.encodeToString((consumerKey + ":" + secretKey).getBytes(), Base64.NO_WRAP);

        // Variables locales de la fonction
        String bearerTocken = "";
        URL url = null;
        HttpURLConnection urlConnection = null;

        try {
            // On formate la requete HTTP
            url = new URL("https://api.twitter.com/oauth2/token");
            urlConnection = (HttpURLConnection) url.openConnection();

            urlConnection.setRequestMethod("POST");
            urlConnection.setRequestProperty("Host", "api.twitter.com");
            urlConnection.setRequestProperty("User-Agent", " My Twitter App v1.0.23");
            urlConnection.setRequestProperty("Authorization", "Basic " + base64encodedBearerToken);
            urlConnection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded;charset=UTF-8");
            urlConnection.setRequestProperty("Content-Length", "29");
            urlConnection.setRequestProperty("Accept-Encoding", "gzip");

            String requestBody =  "grant_type=client_credentials";
            byte[] outputInBytes = requestBody.getBytes("UTF-8");
            OutputStream os = urlConnection.getOutputStream();
            os.write( outputInBytes );
            os.close();

            // On lit l'entete de la reponse
            int responseCode = urlConnection.getResponseCode();

            switch (responseCode) {
                case 200:
                case 201:

                    BufferedReader rd = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
                    String line;
                    while ((line = rd.readLine()) != null) {
                        bearerTocken += line;
                    }
                    break;
                default:
                    bearerTocken = "";
            }

        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return bearerTocken;
    }
}

最后的bearerToken是这样的:

����������������V*��N͋/�,HU�RJJM,J-R�QJLNN-.�K�����/�rW03��5��+81��$���=?[��)�ɱ���B�إа�2�)+����$�2�� ����?���?7�;�0�2�995=�-=/$$�"�30T�����������9�뇛������

根据文档,内容长度为 149 而不是 140。

你知道为什么我会收到这样的回复吗?

如果您没有decoding/handling gzip 压缩,为什么要使用它?内容以 gzip 编码。在使用它之前,您需要对其进行解码。我建议您在调用 API 时不要使用该编码。删除代码行 urlConnection.setRequestProperty("Accept-Encoding", "gzip");,一切都应该工作。