Android で JSON 経由で API から情報を取得しようとしています。情報のダウンロードに成功したので、「Categories」というタグを付けて JSONArray に入れる必要があります。最終的に、これはリストビューになります。これが私のコードです:
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URL;
import java.net.URLConnection;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.StatusLine;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import android.util.Log;
public class jsonParser {
//initialize
static JSONObject object =null;
public jsonParser(){
}
public JSONObject getJSONfromURL (String url){
//HTTP call
try{
URLConnection connection = new URL(url).openConnection();
BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream()), 2048 * 16);
StringBuffer builder = new StringBuffer();
String line;
while ((line = reader.readLine()) != null) {
builder.append(line).append("\n");
}
String blah = builder.toString();
//Parsing string into JSONArray
JSONObject object = new JSONObject ( new String(builder.toString()) );
Log.e("success","created object: " + object);
} catch(Exception e){
Log.e("Http Error","Error in http connection " + e.toString());
}
return object;
}
}
Logcat は次のとおりです。
05-12 16:57:54.040: E/success(9625): created object: {"Categories":[{"id":"2","name":"Glass Repair"},{"id":"3","name":"Appliance Repair"},{"id":"4","name":"Air Conditioning"},{"id":"5","name":"Community Involvement"},{"id":"6","name":"Electrical"},{"id":"7","name":"Flooring"},{"id":"8","name":"Heating Repair"},{"id":"9","name":"Landscaping"},{"id":"10","name":"Plumbing"},{"id":"11","name":"Remodeling\/Renovation"},{"id":"12","name":"Window Coverings"}]}
05-12 16:57:54.040: E/JSON Variable(9625): json returns this value: null
05-12 16:57:54.070: E/Test JSON(9625): JSON s returns: null
05-12 16:57:54.070: W/dalvikvm(9625): threadid=1: thread exiting with uncaught exception (group=0x416bf438)
05-12 16:57:54.070: E/AndroidRuntime(9625): FATAL EXCEPTION: main
05-12 16:57:54.070: E/AndroidRuntime(9625): java.lang.NullPointerException
05-12 16:57:54.070: E/AndroidRuntime(9625): at com.example.hstnc_activity.DisplayServiceActivity$Request.onPostExecute(DisplayServiceActivity.java:104)
05-12 16:57:54.070: E/AndroidRuntime(9625): at com.example.hstnc_activity.DisplayServiceActivity$Request.onPostExecute(DisplayServiceActivity.java:1)
05-12 16:57:54.070: E/AndroidRuntime(9625): at android.os.AsyncTask.finish(AsyncTask.java:631)
05-12 16:57:54.070: E/AndroidRuntime(9625): at android.os.AsyncTask.access$600(AsyncTask.java:177)
05-12 16:57:54.070: E/AndroidRuntime(9625): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
05-12 16:57:54.070: E/AndroidRuntime(9625): at android.os.Handler.dispatchMessage(Handler.java:99)
05-12 16:57:54.070: E/AndroidRuntime(9625): at android.os.Looper.loop(Looper.java:137)
05-12 16:57:54.070: E/AndroidRuntime(9625): at android.app.ActivityThread.main(ActivityThread.java:4918)
05-12 16:57:54.070: E/AndroidRuntime(9625): at java.lang.reflect.Method.invokeNative(Native Method)
05-12 16:57:54.070: E/AndroidRuntime(9625): at java.lang.reflect.Method.invoke(Method.java:511)
05-12 16:57:54.070: E/AndroidRuntime(9625): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
05-12 16:57:54.070: E/AndroidRuntime(9625): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
05-12 16:57:54.070: E/AndroidRuntime(9625): at dalvik.system.NativeStart.main(Native Method)
最後に、JSON 情報を次に示します (これを取得するために jsonlint.com を使用しました)。
{
"Categories": [
{
"id": "2",
"name": "Glass Repair"
},
{
"id": "3",
"name": "Appliance Repair"
},
{
"id": "4",
"name": "Air Conditioning"
},
{
"id": "5",
"name": "Community Involvement"
},
{
"id": "6",
"name": "Electrical"
},
{
"id": "7",
"name": "Flooring"
},
{
"id": "8",
"name": "Heating Repair"
},
{
"id": "9",
"name": "Landscaping"
},
{
"id": "10",
"name": "Plumbing"
},
{
"id": "11",
"name": "Remodeling/Renovation"
},
{
"id": "12",
"name": "Window Coverings"
}
]
}
ASync メソッドは次のとおりです。
public class Request extends AsyncTask<String, Void, JSONObject> {
private static final int REGISTRATION_TIMEOUT = 3 * 1000;
private static final int WAIT_TIMEOUT = 30 * 1000;
private ProgressDialog dialog =
new ProgressDialog(DisplayServiceActivity.this);
protected void onPreExecute() {
dialog = new ProgressDialog(DisplayServiceActivity.this);
dialog.setMessage("Getting your info real quick... Please wait...");
dialog.show();
}
protected JSONObject doInBackground(String... params) {
json = jParser.getJSONfromURL(url);
Log.e("JSON Variable", "json returns this value: " + json);
return json;
}
protected void onPostExecute(JSONObject s) {
super.onPostExecute(s);
dialog.dismiss();
Log.e("Test JSON","JSON s returns: " + s);
try {
directory = s.getJSONArray("Categories");
} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
for(int i = 0; i< directory.length(); i++){
String str_id = directory.optString(i, "id");
String str_name = directory.optString(i, "name");
displayCatList(str_id, str_name);
Log.e("Test directory","Directory returns: " + json);
}
}
}
私はすべての助けに感謝します!