我在读取输出表单请求方面有问题。
public JSONArray listLights()
{
try
{
URL adres = new URL("https://api.lifx.com/v1/lights/all");
HttpURLConnection polaczenie = (HttpURLConnection) adres.openConnection();
polaczenie.setRequestProperty("Authorization", "Bearer " + apiKey);
polaczenie.setRequestMethod("GET");
BufferedReader wejscie = new BufferedReader(new InputStreamReader((polaczenie.getInputStream())));
StringBuilder odpowiedz = new StringBuilder();
String json;
while ((json = wejscie.readLine()) != null)
odpowiedz.append(json);
wejscie.close();
return new JSONArray(odpowiedz.toString());
}
catch (Exception wyjatek)
{
wyjatek.printStackTrace();
}
return new JSONArray();
}我也加入了AndroidManifest的互联网接入。
欢迎留言。:P
编辑:
我谷歌互联网,并找到了部分解决方案。添加了AsyncTask,但现在我收到了'429‘响应代码。
public class JSONTask extends AsyncTask<String, String, String>
{
String apiKey = "blah_blah_blah";
String txtresult;
@Override
protected String doInBackground(String... params) {
HttpsURLConnection connection = null;
BufferedReader reader = null;
try
{
URL adres = new URL(params[0]);
HttpsURLConnection polaczenie = (HttpsURLConnection) adres.openConnection();
polaczenie.setRequestProperty("Authorization", "Bearer " + apiKey);
polaczenie.setRequestMethod("GET");
System.out.println(polaczenie.getResponseCode());
InputStream stream = polaczenie.getInputStream();
reader = new BufferedReader(new InputStreamReader(stream));
StringBuffer buffer = new StringBuffer();
String line = "";
while ((line = reader.readLine()) != null)
{
buffer.append(line);
}
return buffer.toString();
}
catch (MalformedURLException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
finally {
if (connection != null)
connection.disconnect();
try
{
if (reader != null)
reader.close();
}
catch (IOException e)
{
e.printStackTrace();
}
}
return null;
}
@Override
protected void onPostExecute(String s)
{
super.onPostExecute(s);
widok.setText(s);
}
}我现在的StackTrace
EDIT2:
新的一天,新的惊喜。我发现我每10次尝试一次或两次与灯泡连接。有什么想法吗?
发布于 2016-04-17 10:11:16
HTTP状态代码429意味着在给定的时间内请求过多。那么你到底在做多少个请求?
发布于 2016-04-17 14:09:13
android.os.NetworkOnMainThreadException --这意味着,您必须从UIthread以外的另一个威胁中发出htttp请求。为什么要使用异步任务?
编辑:你也可以从邮递员那里打个电话,也许你会发现问题所在。
发布于 2016-04-25 10:59:24
最后,一切都正常了。问题出在灯泡或Lifx云这一边。
https://stackoverflow.com/questions/36666620
复制相似问题