繁体   English   中英

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

[英]Getting content from http request android, conent ill-formed

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

我正在根据此链接构建它。

这是我用来发出请求的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,JR QJLNN-. K / rW03 5 +81 $ =?[ ) ɱ B إа 2 )+ $ 2 ? ?7 ; 0 2 995= -=/$$ " 30T 9 뇛

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

你知道为什么我会得到这样的回应吗?

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM