2013-08-31 13 views
0

이 코드의 오류는 무엇입니까?facebook 그래프 오류 - org.json.JSONException : 이름에 값이 없음

페이스 북 페이지 이름을 추가하고 json 데이터를 가져오고 싶지만 발견 할 수없는 오류가 있습니다. URL의 예는 내가 사용 this 이 모두 내가 사용하는 파일 및 추가 로그 캣의 메시지입니다 :

08-31 08:21:35.972: W/System.err(8157): org.json.JSONException: No value for name 
08-31 08:21:36.002: W/System.err(8157):  at org.json.JSONObject.get(JSONObject.java:354) 
08-31 08:21:36.002: W/System.err(8157):  at org.json.JSONObject.getString(JSONObject.java:514) 
08-31 08:21:36.002: W/System.err(8157):  at com.engahmedphp.facebookcollector.PagesActivity$MyAsyncTask.onPostExecute(PagesActivity.java:82) 
08-31 08:21:36.002: W/System.err(8157):  at com.engahmedphp.facebookcollector.PagesActivity$MyAsyncTask.onPostExecute(PagesActivity.java:1) 
08-31 08:21:36.012: W/System.err(8157):  at android.os.AsyncTask.finish(AsyncTask.java:631) 
08-31 08:21:36.032: W/System.err(8157):  at android.os.AsyncTask.access$600(AsyncTask.java:177) 
08-31 08:21:36.032: W/System.err(8157):  at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644) 
08-31 08:21:36.032: W/System.err(8157):  at android.os.Handler.dispatchMessage(Handler.java:99) 
08-31 08:21:36.062: W/System.err(8157):  at android.os.Looper.loop(Looper.java:137) 
08-31 08:21:36.062: W/System.err(8157):  at android.app.ActivityThread.main(ActivityThread.java:5103) 
08-31 08:21:36.062: W/System.err(8157):  at java.lang.reflect.Method.invokeNative(Native Method) 
08-31 08:21:36.072: W/System.err(8157):  at java.lang.reflect.Method.invoke(Method.java:525) 
08-31 08:21:36.072: W/System.err(8157):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737) 
08-31 08:21:36.072: W/System.err(8157):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
08-31 08:21:36.072: W/System.err(8157):  at dalvik.system.NativeStart.main(Native Method) 
08-31 08:21:36.072: I/Choreographer(8157): Skipped 72 frames! The application may be doing too much work on its main thread. 

내가 어떻게해야합니까 PagesActivity.java

package com.engahmedphp.facebookcollector; 


import org.json.JSONException; 
import org.json.JSONObject; 

import android.os.AsyncTask; 
import android.os.Bundle; 
import android.app.Activity; 
import android.app.AlertDialog; 
import android.app.ProgressDialog; 
import android.content.DialogInterface; 
import android.util.Log; 
import android.view.Menu; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 

public class PagesActivity extends Activity { 

    DatabaseHandler db = new DatabaseHandler(this); 
    JSONObject json; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_pages); 

     final Button button = (Button) findViewById(R.id.addPage); 
     button.setOnClickListener(new View.OnClickListener() { 
      public void onClick(View v) { 
       AlertDialog.Builder alert = new AlertDialog.Builder(
         PagesActivity.this); 

       alert.setTitle("Add New Page"); 
       alert.setMessage("Enter Page Name OR Valid Facebook Link"); 

       // Set an EditText view to get user input 
       final EditText input = new EditText(PagesActivity.this); 
       alert.setView(input); 

       alert.setPositiveButton("Ok", 
         new DialogInterface.OnClickListener() { 
          public void onClick(DialogInterface dialog, 
            int whichButton) { 
           String value = input.getText().toString(); 
           // Do something with value! 
           String url = "http://graph.facebook.com/" 
             + value + "/?fields=picture,name";        
           new MyAsyncTask().execute(url); 

          } 
         }); 

       alert.setNegativeButton("Cancel", 
         new DialogInterface.OnClickListener() { 
          public void onClick(DialogInterface dialog, 
            int whichButton) { 
           // Canceled. 
          } 
         }); 

       alert.show(); 
      } 
     }); 

    } 

    private class MyAsyncTask extends AsyncTask<String, Void, Void> { 

     ProgressDialog mProgressDialog; 

     @Override 
     protected void onPostExecute(Void result) { 

      try { 

       String name = json.getString("name"); 

       String fid = json.getString("id"); 
       String picture = json.getJSONObject("picture") 
         .getJSONObject("data").getString("url"); 

       Log.d("name", name); 
       Log.d("fid", fid); 
       Log.d("picture", picture); 
       db.addPage(name, fid, picture); 
      } catch (JSONException e) { 
       e.printStackTrace(); 
      } 

      mProgressDialog.dismiss(); 
     } 

     @Override 
     protected void onPreExecute() { 

      mProgressDialog = ProgressDialog.show(PagesActivity.this, 
        "Loading...", "Data is Loading..."); 
     } 

     @Override 
     protected Void doInBackground(String... params) {   
       addPageData(params[0]);   
      return null; 
     } 
    } 

    public JSONObject addPageData(String url) { 

     // Creating JSON Parser instance 
     JSONParser jParser = new JSONParser(); 

     // getting JSON string from URL 
     json = jParser.getJSONFromUrl(url); 

     return json; 

    } 

    @Override 
    public boolean onCreateOptionsMenu(Menu menu) { 
     // Inflate the menu; this adds items to the action bar if it is present. 
     getMenuInflater().inflate(R.menu.splash, menu); 
     return true; 
    } 

} 

로그 캣 json 개체 잘못? 또는 비동기를 잘못 사용하거나 무엇을 ??

답변

0

예외가 발생하면 읽으십시오. 여기 LogCat은 JSONException: No value for name라고 말합니다. 실제로 대가로 물건을 얻고 있으며 AsyncTask은 괜찮아 보입니다. JSONException: no value for data 과 같은 질문을 확인하면 HttpPostHttpGet으로 변경할 것을 제안합니다.

+0

대단히 감사합니다. >> 작동 중입니다. –

관련 문제