Java 解析JSON响应中的数据并填充到listview

Java 解析JSON响应中的数据并填充到listview,java,android,json,listview,Java,Android,Json,Listview,这是我的JSON结构 URL:: http://54.218.73.244:7004/DescriptionSortedPrice/ JSON:: { "restaurants": [ { "Sl_no": 1, "Person_Name": "salmanKhan", "Image_Name": "image.jpg" }, Adapter.java public class A

这是我的JSON结构

URL::

http://54.218.73.244:7004/DescriptionSortedPrice/
JSON::

{
    "restaurants": [
        {
            "Sl_no": 1,
            "Person_Name": "salmanKhan",
            "Image_Name": "image.jpg"
        },
Adapter.java

public class Adapter extends BaseAdapter {

    // Declare Variables
    Context context;
    LayoutInflater inflater;
    ArrayList<HashMap<String, String>> data;
    HashMap<String, String> resultp = new HashMap<String, String>();

    public Adapter(Context context,
            ArrayList<HashMap<String, String>> arraylist) {
        this.context = context;
        data = arraylist;
    }

    @Override
    public int getCount() {
        return data.size();
    }

    @Override
    public Object getItem(int position) {
        return null;
    }

    @Override
    public long getItemId(int position) {
        return 0;
    }

    public View getView(final int position, View convertView, ViewGroup parent) {
        // Declare Variables
        TextView name;

        inflater = (LayoutInflater) context
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);

        View itemView = inflater.inflate(R.layout.single_item, parent, false);
        // Get the position
        resultp = data.get(position);

        // Locate the TextViews in listview_item.xml
        name = (TextView) itemView.findViewById(R.id.title_textView_id);

        // Capture position and set results to the TextViews
        name.setText(resultp.get(MainActivity.NAME));


        return itemView;
    }
}
public class MainActivity extends Activity{
    // Declare Variables
    JSONObject jsonobject;
    JSONArray jsonarray;
    ListView listview;
    Adapter adapter;
    ProgressDialog mProgressDialog;
    ArrayList<HashMap<String, String>> arraylist;
    static String NAME = "rank";


    String TYPE_FILTER;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // Get the view from listview_main.xml
        setContentView(R.layout.activity_main);

        listview = (ListView) findViewById(R.id.listView_id);

        // Execute DownloadJSON AsyncTask
        new DownloadJSON().execute();
    }

    // DownloadJSON AsyncTask
    private class DownloadJSON extends AsyncTask<Void, Void, Void> {

        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            // Create a progressdialog
            mProgressDialog = new ProgressDialog(MainActivity.this);
            // Set progressdialog title
            //mProgressDialog.setTitle("Fetching the information");
            // Set progressdialog message
            mProgressDialog.setMessage("Loading...");
            mProgressDialog.setIndeterminate(false);
            // Show progressdialog
            mProgressDialog.show();
        }

        @Override
        protected Void doInBackground(Void... params) {
            // Create an array
            arraylist = new ArrayList<HashMap<String, String>>();

            // Retrieve JSON Objects from the given URL address
            jsonobject = Parser.getJSONfromURL("http://54.218.73.244:7004/DescriptionSortedPrice/");

            try {
                // Locate the array name in JSON
                jsonarray = jsonobject.getJSONArray("restaurants");

                for (int i = 0; i < jsonarray.length(); i++) {
                    HashMap<String, String> map = new HashMap<String, String>();
                    jsonobject = jsonarray.getJSONObject(i);
                    // Retrive JSON Objects
                    map.put(MainActivity.NAME, jsonobject.getString("Person_Name"));

                    // Set the JSON Objects into the array
                    arraylist.add(map);
                }
            } catch (JSONException e) {
                Log.e("Error", e.getMessage());
                e.printStackTrace();
            }
            return null;
        }

        @Override
        protected void onPostExecute(Void args) {
            // Pass the results into ListViewAdapter.java
            adapter = new Adapter(MainActivity.this, arraylist);
            // Set the adapter to the ListView
            listview.setAdapter(adapter);
            // Close the progressdialog
            mProgressDialog.dismiss();
        }
    }
}
public class Parser {

    public static JSONObject getJSONfromURL(String url) {
        InputStream is = null;
        String result = "";
        JSONObject jArray = null;

        // Download JSON data from URL
        try {
            HttpClient httpclient = new DefaultHttpClient();
            HttpGet httpget = new HttpGet(url);
            HttpResponse response = httpclient.execute(httpget);
            HttpEntity entity = response.getEntity();
            is = entity.getContent();

        } catch (Exception e) {
            Log.e("log_tag", "Error in http connection " + e.toString());
        }

        // Convert response to string
        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(
                    is, "iso-8859-1"), 8);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line + "\n");
            }
            is.close();
            result = sb.toString();
        } catch (Exception e) {
            Log.e("log_tag", "Error converting result " + e.toString());
        }

        try {

            jArray = new JSONObject(result);
        } catch (JSONException e) {
            Log.e("log_tag", "Error parsing data " + e.toString());
        }

        return jArray;
    }
}
日志::

01-01 12:13:14.600: E/log_tag(715): Error in http connection java.net.SocketException: Permission denied
01-01 12:13:14.610: E/log_tag(715): Error converting result java.lang.NullPointerException
01-01 12:13:14.620: E/log_tag(715): Error parsing data org.json.JSONException: End of input at character 0 of 
01-01 12:13:14.660: W/dalvikvm(715): threadid=7: thread exiting with uncaught exception (group=0x4001d800)
01-01 12:13:14.690: E/AndroidRuntime(715): FATAL EXCEPTION: AsyncTask #1
01-01 12:13:14.690: E/AndroidRuntime(715): java.lang.RuntimeException: An error occured while executing doInBackground()
01-01 12:13:14.690: E/AndroidRuntime(715):  at android.os.AsyncTask$3.done(AsyncTask.java:200)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.FutureTask.run(FutureTask.java:137)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.lang.Thread.run(Thread.java:1096)
01-01 12:13:14.690: E/AndroidRuntime(715): Caused by: java.lang.NullPointerException
01-01 12:13:14.690: E/AndroidRuntime(715):  at com.example.singleitemlistview.MainActivity$DownloadJSON.doInBackground(MainActivity.java:71)
01-01 12:13:14.690: E/AndroidRuntime(715):  at com.example.singleitemlistview.MainActivity$DownloadJSON.doInBackground(MainActivity.java:1)
01-01 12:13:14.690: E/AndroidRuntime(715):  at android.os.AsyncTask$2.call(AsyncTask.java:185)
01-01 12:13:14.690: E/AndroidRuntime(715):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
01-01 12:13:14.690: E/AndroidRuntime(715):  ... 4 more
01-01 12:13:17.215: E/WindowManager(715): Activity com.example.singleitemlistview.MainActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@45fbe1e8 that was originally added here
01-01 12:13:17.215: E/WindowManager(715): android.view.WindowLeaked: Activity com.example.singleitemlistview.MainActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@45fbe1e8 that was originally added here
01-01 12:13:17.215: E/WindowManager(715):   at android.view.ViewRoot.<init>(ViewRoot.java:247)
01-01 12:13:17.215: E/WindowManager(715):   at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
01-01 12:13:17.215: E/WindowManager(715):   at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
01-01 12:13:17.215: E/WindowManager(715):   at android.view.Window$LocalWindowManager.addView(Window.java:424)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.Dialog.show(Dialog.java:241)
01-01 12:13:17.215: E/WindowManager(715):   at com.example.singleitemlistview.MainActivity$DownloadJSON.onPreExecute(MainActivity.java:58)
01-01 12:13:17.215: E/WindowManager(715):   at android.os.AsyncTask.execute(AsyncTask.java:391)
01-01 12:13:17.215: E/WindowManager(715):   at com.example.singleitemlistview.MainActivity.onCreate(MainActivity.java:41)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.ActivityThread.access$2300(ActivityThread.java:125)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
01-01 12:13:17.215: E/WindowManager(715):   at android.os.Handler.dispatchMessage(Handler.java:99)
01-01 12:13:17.215: E/WindowManager(715):   at android.os.Looper.loop(Looper.java:123)
01-01 12:13:17.215: E/WindowManager(715):   at android.app.ActivityThread.main(ActivityThread.java:4627)
01-01 12:13:17.215: E/WindowManager(715):   at java.lang.reflect.Method.invokeNative(Native Method)
01-01 12:13:17.215: E/WindowManager(715):   at java.lang.reflect.Method.invoke(Method.java:521)
01-01 12:13:17.215: E/WindowManager(715):   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
01-01 12:13:17.215: E/WindowManager(715):   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
01-01 12:13:17.215: E/WindowManager(715):   at dalvik.system.NativeStart.main(Native Method)
01-01 12:13:14.600:E/log_标记(715):http连接中出错java.net.SocketException:权限被拒绝
01-01 12:13:14.610:E/log_标记(715):转换结果java.lang.NullPointerException时出错
01-01 12:13:14.620:E/log_标记(715):解析数据org.json.JSONException时出错:输入结束,字符0处
01-01 12:13:14.660:W/dalvikvm(715):threadid=7:线程以未捕获异常退出(组=0x4001d800)
01-01 12:13:14.690:E/AndroidRuntime(715):致命异常:AsyncTask#1
01-01 12:13:14.690:E/AndroidRuntime(715):java.lang.RuntimeException:执行doInBackground()时出错
01-01 12:13:14.690:E/AndroidRuntime(715):在android.os.AsyncTask$3.done(AsyncTask.java:200)
01-01 12:13:14.690:E/AndroidRuntime(715):在java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
01-01 12:13:14.690:E/AndroidRuntime(715):位于java.util.concurrent.FutureTask.setException(FutureTask.java:124)
01-01 12:13:14.690:E/AndroidRuntime(715):位于java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
01-01 12:13:14.690:E/AndroidRuntime(715):在java.util.concurrent.FutureTask.run(FutureTask.java:137)
01-01 12:13:14.690:E/AndroidRuntime(715):位于java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
01-01 12:13:14.690:E/AndroidRuntime(715):位于java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
01-01 12:13:14.690:E/AndroidRuntime(715):在java.lang.Thread.run(Thread.java:1096)处
01-01 12:13:14.690:E/AndroidRuntime(715):由以下原因引起:java.lang.NullPointerException
01-01 12:13:14.690:E/AndroidRuntime(715):位于com.example.singleitemlistview.MainActivity$DownloadJSON.doInBackground(MainActivity.java:71)
01-01 12:13:14.690:E/AndroidRuntime(715):位于com.example.singleitemlistview.MainActivity$DownloadJSON.doInBackground(MainActivity.java:1)
01-01 12:13:14.690:E/AndroidRuntime(715):在android.os.AsyncTask$2.call(AsyncTask.java:185)
01-01 12:13:14.690:E/AndroidRuntime(715):在java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
01-01 12:13:14.690:E/AndroidRuntime(715):。。。4更多
01-01 12:13:17.215:E/WindowManager(715):Activity com.example.singleitemlistview.Main活动已泄漏window com.android.internal.policy.impl.PhoneWindow$DecorView@45fbe1e8原来是加在这里的
01-01 12:13:17.215:E/WindowManager(715):android.view.WindowLeaked:Activity com.example.singleitemlistview.main活动已泄漏window com.android.internal.policy.impl.PhoneWindow$DecorView@45fbe1e8原来是加在这里的
01-01 12:13:17.215:E/WindowManager(715):在android.view.ViewRoot(ViewRoot.java:247)
01-01 12:13:17.215:E/WindowManager(715):在android.view.WindowManagerImpl.addView(WindowManagerImpl.java:148)
01-01 12:13:17.215:E/WindowManager(715):在android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
01-01 12:13:17.215:E/WindowManager(715):在android.view.Window$LocalWindowManager.addView(Window.java:424)
01-01 12:13:17.215:E/WindowManager(715):在android.app.Dialog.show(Dialog.java:241)
01-01 12:13:17.215:E/WindowManager(715):位于com.example.singleitemlistview.MainActivity$DownloadJSON.onPreExecute(MainActivity.java:58)
01-01 12:13:17.215:E/WindowManager(715):在android.os.AsyncTask.execute(AsyncTask.java:391)
01-01 12:13:17.215:E/WindowManager(715):位于com.example.singleitemlistview.MainActivity.onCreate(MainActivity.java:41)
01-01 12:13:17.215:E/WindowManager(715):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
01-01 12:13:17.215:E/WindowManager(715):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
01-01 12:13:17.215:E/WindowManager(715):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
01-01 12:13:17.215:E/WindowManager(715):在android.app.ActivityThread.access$2300(ActivityThread.java:125)
01-01 12:13:17.215:E/WindowManager(715):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
01-01 12:13:17.215:E/WindowManager(715):在android.os.Handler.dispatchMessage(Handler.java:99)上
01-01 12:13:17.215:E/WindowManager(715):在android.os.Looper.loop(Looper.java:123)
01-01 12:13:17.215:E/WindowManager(715):在android.app.ActivityThread.main(ActivityThread.java:4627)上
01-01 12:13:17.215:E/WindowManager(715):位于java.lang.reflect.Method.Invokenactive(本机方法)
01-01 12:13:17.215:E/WindowManager(715):位于java.lang.reflect.Method.invoke(Method.java:521)
01-01 12:13:17.215:E/WindowManager(715):位于com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
01-01 12:13:17.215:E/WindowManager(715):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
01-01 12:13:17.215:E/WindowManager(715):在dalvik.system.NativeStart.main(本机方法)

从日志引用

  • 第58行::mProgressDialog.show()
  • line41::新建下载JSON().execute()
  • line71::map.put(MainActivity.NAME,jsonobject.getString(“人名”)


问题::我无法在我的listview上显示已解析的项目

使用此代码块更新您的解析器

try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(is, HTTP.UTF_8));
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line);
            }
            is.close();
            result = sb.toString();
        } catch (Exception e) {
            Log.e("log_tag", "Error converting result " + e.toString());
        }
从您的日志显示:

Error in http connection java.net.SocketException: Permission denied
Error converting result java.lang.NullPointerException
Error parsing data org.json.JSONException: End of input at character 0 of 
确保您已在清单中授予互联网权限

 <uses-permission android:name="android.permission.INTERNET" />

你在你的舱单上有许可吗

<uses-permission android:name="android.permission.INTERNET" />

当您没有授予internet权限并尝试访问internet时,会发生这种情况。

首先,您只需检查将响应字符串打印到logcat中,然后让我知道。您可以记录json响应吗?您是否授予了权限,因为您从日志中获得了
<uses-permission android:name="android.permission.INTERNET" />
http connection java.net.SocketException: Permission denied