Php Android-通过Http获取json数据并列出它们

Php Android-通过Http获取json数据并列出它们,php,android,mysql,json,Php,Android,Mysql,Json,我需要从服务器上生成的json中获取数据 目前,my json生成以下矩阵: {"success":1,"message":[{"pedidos_id":"1","pedidos_nome":"Teste","pedidos_email":"ygormagrii@gmail.com"},{"pedidos_id":"19","pedidos_nome":"5","pedidos_email":"camiseta"},{"pedidos_id":"75","pedidos_nome":"6","p

我需要从服务器上生成的json中获取数据

目前,my json生成以下矩阵:

{"success":1,"message":[{"pedidos_id":"1","pedidos_nome":"Teste","pedidos_email":"ygormagrii@gmail.com"},{"pedidos_id":"19","pedidos_nome":"5","pedidos_email":"camiseta"},{"pedidos_id":"75","pedidos_nome":"6","pedidos_email":"hdj"},{"pedidos_id":"76","pedidos_nome":"5","pedidos_email":"grhd"},{"pedidos_id":"77","pedidos_nome":"5","pedidos_email":"gdf"}]}
生成此JSON PHP的代码如下所示:

    $user_id=$_REQUEST['user_id'];

$r=mysql_query("select * from tbl_storefinder_pedidos where user_id='$user_id'",$con);

$response= array();
$info=array();
$flag = array();

if( mysql_num_rows( $r ) > 0 ) {
    while($row = mysql_fetch_array($r))
    {
        $flag[pedidos_id]=$row[pedidos_id];
        $flag[pedidos_nome]=$row[pedidos_nome];
        $flag[pedidos_email]=$row[pedidos_email];
        array_push($info, $flag);
    }
        $response["success"] = 1;
        $response["message"] = $info;
        echo json_encode($response);
}
else
{
        $response["success"] = 0;
        $response["message"] = "No entries yet";
        echo json_encode($response);
}
mysql_close($con);
我的活动接收json并试图限制它:

package com.projects.activities;

import android.app.Activity;
import android.app.AlertDialog;
import android.app.ProgressDialog;
import android.content.Intent;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

import com.libraries.usersession.UserAccessSession;
import com.libraries.usersession.UserSession;
import com.projects.storefinder.R;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONArray;
import org.json.JSONObject;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;

/**
 * Created by Ygor on 23/02/2016.
 */
public class FinalizarPedido extends Activity {

    private TextView tvDescricao;
    private TextView tvQuantidade;
    private String Descricao;
    private String Unidade;
    private String Categoria;
    private String Qtd;
    private String pedidos_nome;
    private String pedidos_email;
    private String pedidos_id;
    private AlertDialog alerta;
    String user_id;
    InputStream is=null;
    String result=null;
    String line=null;


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

        Button novoPedido = (Button) findViewById(R.id.novo_pedido);
        Button btnEnd = (Button) findViewById(R.id.buttonFim);

        new select().execute();

        btnEnd.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(FinalizarPedido.this, FormPedidos.class);
                startActivity(intent);
            }
        });


        novoPedido.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(FinalizarPedido.this, InsertNewPedidos.class);
                startActivity(intent);
            }
        });

    }

    class select extends AsyncTask<String, Integer, String> {

        private StringBuilder sb;
        private ProgressDialog pr;
        private HttpResponse req;
        private InputStream is;

        @Override
        protected void onPreExecute() {
            super.onPreExecute();
            Toast.makeText(getApplicationContext(), "Captando ...", Toast.LENGTH_LONG).show();
        }

        @Override
        protected String doInBackground(String... arg0) {
            ArrayList<String> pedidos_nome = new ArrayList<String>();
            ArrayList<String> pedidos_id = new ArrayList<String>();
            ArrayList<String> pedidos_email = new ArrayList<String>();

            UserAccessSession userAccess = UserAccessSession.getInstance(FinalizarPedido.this);
            UserSession userSession = userAccess.getUserSession();
            ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();

            nameValuePairs.add(new BasicNameValuePair("user_id", String.valueOf(userSession.getUser_id())));

            try {
                HttpClient httpclient = new DefaultHttpClient();
                HttpPost httppost = new HttpPost("http://marketingdigitalabc.com.br/buysell/pedidos_show.php");
                httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();
                is = entity.getContent();
                Log.e("pass 1", "connection success ");
            } catch (Exception e) {
                Log.e("Fail 1", e.toString());
                Toast.makeText(getApplicationContext(), "Invalid IP Address",
                        Toast.LENGTH_LONG).show();
            }

            try {
                BufferedReader reader = new BufferedReader
                        (new InputStreamReader(is, "iso-8859-1"), 8);
                StringBuilder sb = new StringBuilder();
                while ((line = reader.readLine()) != null) {
                    sb.append(line + "\n");
                }
                is.close();
                result = sb.toString();
                Log.e("pass 2", "connection success ");
            } catch (Exception e) {
                Log.e("Fail 2", e.toString());
            }

            try {

                JSONObject json_data = new JSONObject(result);
                JSONArray arr =  json_data.getJSONArray("message");
                for (int i=0; i < arr.length(); i++) {
                    JSONObject  json_dat = arr.getJSONObject(i);

                    pedidos_nome.add((json_dat.getString("pedidos_nome")));
                    pedidos_id.add((json_dat.getString("pedidos_id")));
                    pedidos_email.add((json_dat.getString("pedidos_email")));

                    pedidos_nome.get(i);
                    pedidos_id.get(i);
                    pedidos_email.get(i);
                }


            } catch (Exception e) {
                Log.e("Fail 3", e.toString());
            }
            return user_id;
        }

        @Override
        protected void onPostExecute(String result) {
            super.onPostExecute(result);

            String[] lista = {"Produtos:" +pedidos_id};
            final ListView listaPedido = (ListView) findViewById(R.id.lista);
            ArrayAdapter<String> adapter = new ArrayAdapter<String>(FinalizarPedido.this, android.R.layout.simple_list_item_1, lista);
            listaPedido.setAdapter(adapter);

            listaPedido.setOnItemClickListener(new AdapterView.OnItemClickListener() {
                @Override
                public void onItemClick(AdapterView<?> lista, View item, int posicao, long id) {
                    listaPedido.getItemAtPosition(posicao);
                    AlertDialog.Builder builder = new AlertDialog.Builder(FinalizarPedido.this);//Cria o gerador do AlertDialog
                    builder.setTitle("Pedido: " + pedidos_nome);
                    builder.setMessage("Pedido id: " + pedidos_id + "\nPedido E-mail: " + pedidos_email+ "\nPedido Nome: " + pedidos_nome);
                    builder.setNegativeButton("Fechar", null);
                    alerta = builder.create();
                    alerta.show();
                }
            });


        }

    }
}
包com.projects.activities;
导入android.app.Activity;
导入android.app.AlertDialog;
导入android.app.ProgressDialog;
导入android.content.Intent;
导入android.os.AsyncTask;
导入android.os.Bundle;
导入android.util.Log;
导入android.view.view;
导入android.widget.AdapterView;
导入android.widget.ArrayAdapter;
导入android.widget.Button;
导入android.widget.ListView;
导入android.widget.TextView;
导入android.widget.Toast;
导入com.libraries.usersession.UserAccessSession;
导入com.libraries.usersession.usersession;
导入com.projects.storefinder.R;
导入org.apache.http.HttpEntity;
导入org.apache.http.HttpResponse;
导入org.apache.http.NameValuePair;
导入org.apache.http.client.HttpClient;
导入org.apache.http.client.entity.UrlEncodedFormEntity;
导入org.apache.http.client.methods.HttpPost;
导入org.apache.http.impl.client.DefaultHttpClient;
导入org.apache.http.message.BasicNameValuePair;
导入org.json.JSONArray;
导入org.json.JSONObject;
导入java.io.BufferedReader;
导入java.io.InputStream;
导入java.io.InputStreamReader;
导入java.util.ArrayList;
/**
*Ygor于2016年2月23日创建。
*/
公共类FinalizarPedido扩展活动{
私有文本视图;
私有文本视图tvQuantidade;
私有字符串描述符;
私有字符串Unidade;
私有字符串范畴;
私有字符串Qtd;
私人字符串pedidos_nome;
私人字符串pedidos_电子邮件;
私有字符串pedidos_id;
私人alerta;
字符串用户标识;
InputStream=null;
字符串结果=null;
字符串行=null;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.Finalizaa_pedido);
按钮novoPedido=(按钮)findViewById(R.id.novo_pedido);
按钮btnEnd=(按钮)findViewById(R.id.buttonFim);
新建select().execute();
btnEnd.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
Intent Intent=新的Intent(finalidatearpedido.this,FormPedidos.class);
星触觉(意向);
}
});
novoPedido.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
Intent Intent=newintent(finalizardarpedido.this,InsertNewPedidos.class);
星触觉(意向);
}
});
}
类选择扩展异步任务{
私家侦探;
私人关系;
专用HttpResponse请求;
私有输入流是;
@凌驾
受保护的void onPreExecute(){
super.onPreExecute();
Toast.makeText(getApplicationContext(),“Captando…”,Toast.LENGTH\u LONG.show();
}
@凌驾
受保护的字符串doInBackground(字符串…arg0){
ArrayList pedidos_nome=新ArrayList();
ArrayList pedidos_id=新的ArrayList();
ArrayList pedidos_email=新建ArrayList();
UserAccessSession userAccess=UserAccessSession.getInstance(FinalizarPedido.this);
UserSession UserSession=userAccess.getUserSession();
ArrayList nameValuePairs=新的ArrayList();
添加(新的BasicNameValuePair(“user_id”,String.valueOf(userSession.getUser_id()));
试一试{
HttpClient HttpClient=新的DefaultHttpClient();
HttpPost HttpPost=新的HttpPost(“http://marketingdigitalabc.com.br/buysell/pedidos_show.php");
setEntity(新的UrlEncodedFormEntity(nameValuePairs));
HttpResponse response=httpclient.execute(httppost);
HttpEntity=response.getEntity();
is=entity.getContent();
Log.e(“通过1”,“连接成功”);
}捕获(例外e){
Log.e(“Fail 1”,e.toString());
Toast.makeText(getApplicationContext(),“无效IP地址”,
Toast.LENGTH_LONG).show();
}
试一试{
BufferedReader reader=新的BufferedReader
(新的InputStreamReader(is,“iso-8859-1”),8);
StringBuilder sb=新的StringBuilder();
而((line=reader.readLine())!=null){
sb.追加(第+行“\n”);
}
is.close();
结果=sb.toString();
Log.e(“通过2”,“连接成功”);
}捕获(例外e){
Log.e(“Fail 2”,e.toString());
}
试一试{
JSONObject json_data=新的JSONObject(结果);
JSONArray arr=json_data.getJSONArray(“消息”);
对于(int i=0;i  protected String doInBackground(String... arg0) {

        UserAccessSession userAccess = UserAccessSession.getInstance(FinalizarPedido.this);
        UserSession userSession = userAccess.getUserSession();
        ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();

        nameValuePairs.add(new BasicNameValuePair("user_id", String.valueOf(userSession.getUser_id())));

        try {
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost httppost = new HttpPost("http://marketingdigitalabc.com.br/buysell/pedidos_show.php");
            httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
            HttpResponse response = httpclient.execute(httppost);
            HttpEntity entity = response.getEntity();
            is = entity.getContent();
            Log.e("pass 1", "connection success ");
        } catch (Exception e) {
            Log.e("Fail 1", e.toString());
            Toast.makeText(getApplicationContext(), "Invalid IP Address",
                    Toast.LENGTH_LONG).show();
        }

        try {
            BufferedReader reader = new BufferedReader
                    (new InputStreamReader(is, "iso-8859-1"), 8);
            StringBuilder sb = new StringBuilder();
            while ((line = reader.readLine()) != null) {
                sb.append(line + "\n");
            }
            is.close();
            result = sb.toString();
            Log.e("pass 2", "connection success ");
        } catch (Exception e) {
            Log.e("Fail 2", e.toString());
        }

        try {

            JSONObject json_data = new JSONObject(result);
            JSONArray arr =  json_data.getJSONArray("message");
            for (int i=0; i < arr.length(); i++) {
                JSONObject  json_dat = arr.getJSONObject(i);

                pedidos_nome.add((json_dat.getString("pedidos_nome")));
                pedidos_id.add((json_dat.getString("pedidos_id")));
                pedidos_email.add((json_dat.getString("pedidos_email")));
            }


        } catch (Exception e) {
            Log.e("Fail 3", e.toString());
        }
        return user_id;

    }