[英]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.