这是Attendance.java文件

package com.glbwebsim;

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

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TableLayout;
import android.widget.TableRow;`
import android.widget.TextView;
import android.widget.Toast;
import android.widget.TableRow.LayoutParams;

public class Attendance extends Activity
{

    static InputStream iStream = null; 
    static JSONArray jArray = null;
    static String json = "";


     public void onCreate(Bundle savedInstanceState)

     {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.fragment_main7);

            Button details = (Button) findViewById(R.id.mydetails);


            details.setOnClickListener(new View.OnClickListener()
            {
            @SuppressWarnings({ "deprecation", "unused" })
            public void onClick(View view) 
              {
                 String result = null;
                InputStream is = null;

                try{
                        HttpClient httpclient = new DefaultHttpClient();
                        HttpPost httppost = new HttpPost("http://frndz4ever.com/glbsim/attend.php");
                        HttpResponse response = httpclient.execute(httppost); 
                        HttpEntity entity = response.getEntity();
                        is = entity.getContent();

                        Log.e("log_tag", "connection success ");
                     //   Toast.makeText(getApplicationContext(), "pass", Toast.LENGTH_SHORT).show();
                }
                catch(Exception e)
                {
                        Log.e("log_tag", "Error in http connection "+e.toString());
                        Toast.makeText(getApplicationContext(), "Connection fail", Toast.LENGTH_SHORT).show();

                }
                //convert response to string
                StringBuilder sb = new StringBuilder();
                try
                {
                        BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
                        String line = null;
                        while ((line = reader.readLine()) != null) 
                        {
                                sb.append(line + "\n");
                              //  Toast.makeText(getApplicationContext(), "Input Reading pass", Toast.LENGTH_SHORT).show();
                        }
                        is.close();

                        result=sb.toString();
                }
                catch(Exception e)
                {
                       Log.e("log_tag", "Error converting result "+e.toString());
                    Toast.makeText(getApplicationContext(), " Input reading fail", Toast.LENGTH_SHORT).show();

                }

                //parse json data
                try
                {

                JSONArray jArray = new JSONArray("["+result+"]");


                String re=jArray.getString(jArray.length()-1);


                TableLayout tv=(TableLayout) findViewById(R.id.table);
                tv.removeAllViewsInLayout();




                   int flag=1;

                for(int i=0;i<re.length();i++)

                        {




                                TableRow tr=new TableRow(Attendance.this);

                                tr.setLayoutParams(new LayoutParams(
                                           LayoutParams.FILL_PARENT,
                                           LayoutParams.WRAP_CONTENT));

                                  if(flag==1)
                                {

                                    TextView b6=new TextView(Attendance.this);
                                     b6.setText("Roll_no");
                                     b6.setTextColor(Color.BLACK);
                                     b6.setTextSize(18);
                                     tr.addView(b6);


                                    TextView b19=new TextView(Attendance.this);
                                     b19.setPadding(10, 0, 0, 0);
                                     b19.setTextSize(18);
                                     b19.setText("Subjects");
                                     b19.setTextColor(Color.BLACK);
                                     tr.addView(b19);

                                   TextView b29=new TextView(Attendance.this);
                                 b29.setPadding(10, 0, 0, 0);
                                     b29.setText("Present");
                                     b29.setTextColor(Color.BLACK);
                                     b29.setTextSize(18);
                                     tr.addView(b29);

                                     TextView b30=new TextView(Attendance.this);
                                     b30.setPadding(10, 0, 0, 0);
                                         b30.setText("Absent");
                                         b30.setTextColor(Color.BLACK);
                                         b30.setTextSize(18);
                                         tr.addView(b30);


                                 tv.addView(tr);

                                     final View vline = new View(Attendance.this);
                                          vline.setLayoutParams(new TableRow.LayoutParams(TableRow.LayoutParams.FILL_PARENT, 2));
                                          vline.setBackgroundColor(Color.BLUE);



                                tv.addView(vline);



                               }

                                else
                                {



                                   JSONObject json_data = jArray.getJSONObject(i);

                                   Log.i("log_tag","Roll_no: "+json_data.getInt("Roll_no")+
                                              ", Subjects: "+json_data.getString("Subjects")+
                                              ", Present: "+json_data.getInt("Present")+
                                              ",Absent: "+json_data.getInt("Absent"));




                            TextView b=new TextView(Attendance.this);
                                String stime=String.valueOf(json_data.getInt("Roll_no"));
                                  b.setText(stime);
                                b.setTextColor(Color.RED);
                                b.setTextSize(15);
                                tr.addView(b);


                               TextView b1=new TextView(Attendance.this);
                                b1.setPadding(10, 0, 0, 0);
                                b1.setTextSize(15);
                                String stime1=json_data.getString("Subjects");
                                 b1.setText(stime1);
                                b1.setTextColor(Color.WHITE);
                                tr.addView(b1);

                              TextView b2=new TextView(Attendance.this);
                             b2.setPadding(10, 0, 0, 0);
                                String stime2=String.valueOf(json_data.getInt("Present"));
                                b2.setText(stime2);
                                b2.setTextColor(Color.RED);
                                b2.setTextSize(15);
                                tr.addView(b2);

                                TextView b3=new TextView(Attendance.this);
                                b3.setPadding(10, 0, 0, 0);
                                   String stime3=String.valueOf(json_data.getInt("Absent"));
                                   b3.setText(stime2);
                                   b3.setTextColor(Color.RED);
                                   b3.setTextSize(15);
                                   tr.addView(b3);

                                  tv.addView(tr);


                        final View vline1 = new View(Attendance.this);
                      vline1.setLayoutParams(new TableRow.LayoutParams(TableRow.LayoutParams.FILL_PARENT, 1));
                      vline1.setBackgroundColor(Color.WHITE);
                      tv.addView(vline1);       


                                }

                       }}




                catch(JSONException e)
                {
                        Log.e("log_tag", "Error parsing data "+e.toString());
                        Toast.makeText(getApplicationContext(), "JsonArray fail", Toast.LENGTH_SHORT).show();
                }

                    return;


           }
              });
           }}

单击该按钮,我收到JsonArray失败错误。 请帮忙。

logcat的:

04-20 20:54:37.458: D/StrictMode(9281): at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1151) 04-20 20:54:37.458: D/StrictMode(9281): at libcore.io.BlockGuardOs.recvfrom(BlockGuardOs.java:163) 04-20 20:54:37.458: D/StrictMode(9281): at libcore.io.IoBridge.recvfrom(IoBridge.java:506) 

===============>>#1 票数:1 已采纳

请参阅下面的代码以供参考,它可能有错误,只是为了了解其工作原理。

任何网络活动都应在doInBackground执行。 不要在UI上执行任何操作。

一旦doInBackground完成,数据将返回给onPostExecute 现在,您可以在此处执行UI操作。

public class Attendance extends Activity {


    static InputStream iStream = null;
    static JSONArray jArray = null;
    static String json = "";

    @Override
    public void onCreate(Bundle savedInstanceState)

    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button details = (Button) findViewById(R.id.mydetails);

        details.setOnClickListener(new View.OnClickListener() {
            @SuppressWarnings({ "deprecation", "unused" })
            public void onClick(View view) {

                new makeHTTPRequest().execute();

            }
        });
    }

    private class makeHTTPRequest extends AsyncTask<String, String, String> {

    @Override
    protected String doInBackground(String... params) {
        // TODO Auto-generated method stub

        String result = null;
        InputStream is = null;

        try {
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost httppost = new HttpPost("http://frndz4ever.com/glbsim/attend.php");
            HttpResponse response = httpclient.execute(httppost);
            HttpEntity entity = response.getEntity();
            is = entity.getContent();

            Log.i("log_tag", "connection success ");
        } catch (Exception e) {
            Log.e("log_tag", "Error in http connection " + e.toString());
            // Toast.makeText(getApplicationContext(), "Connection fail",
            // Toast.LENGTH_SHORT).show();

        }
        // convert response to string
        StringBuilder sb = new StringBuilder();
        try {
            BufferedReader reader = new BufferedReader(
                    new InputStreamReader(is, "iso-8859-1"), 8);
            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());

        }

        return result;
    }

    protected void onPostExecute(String result) {

        // parse json data
        try {

            JSONArray jArray = new JSONArray(result);
            String re = jArray.getString(jArray.length() - 1);

            int flag = 1;

            for(int i=0;i<jArray.length();i++){

                    JSONObject json_data = jArray.getJSONObject(0);

                    Log.i("log_tag",
                            "Index: "+ i + " Roll_no: " + json_data.getInt("Roll_no")
                                    + ", Subjects: "
                                    + json_data.getString("Subject")
                                    + ", Present: "
                                    + json_data.getInt("Present")
                                    + ",Absent: "
                                    + json_data.getInt("Absent"));

            }

                    // Perform any required actions here


        } 
        catch (JSONException e) {
            Log.e("log_tag", "Error parsing data " + e.toString());
            Toast.makeText(getApplicationContext(), "JsonArray fail",  Toast.LENGTH_SHORT).show();
        }

    }

}

}

我已经更新了私有类makeHTTPRequest

不要忘记添加

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

uses-sdk标签下

这是Logcat输出:

04-21 23:37:13.904: I/log_tag(14032): Index: 0 Roll_no: 70, Subjects: Multimedia, Present: 20,Absent: 10
04-21 23:37:13.905: I/log_tag(14032): Index: 1 Roll_no: 70, Subjects: Multimedia, Present: 20,Absent: 10
04-21 23:37:13.905: I/log_tag(14032): Index: 2 Roll_no: 70, Subjects: Multimedia, Present: 20,Absent: 10
04-21 23:37:13.905: I/log_tag(14032): Index: 3 Roll_no: 70, Subjects: Multimedia, Present: 20,Absent: 10

首先尝试一下,如果可行,请逐步添加代码以增强您的应用程序。

  ask by droidmode translate from so

未解决问题?本站智能推荐:

1回复

尝试从android中的数据库中获取数据时,JSON显示错误403

我正在制作有关在线购物的android应用程序。 直到今天,我都能够使用Android应用程序正确获取数据并将数据插入数据库。 (从过去15天开始,该应用程序运行正常)今天,当我启动它时,它崩溃了,所以我检查了eclipse,发现在尝试向数据库发出http请求时,它显示访问被拒绝。
1回复

使用Json使用MySQL数据库进行实时搜索并在ListView Android中显示结果

我正在使用MySQL,JSON进行实时搜索。 它可以与本地数组值一起正常工作。 但不适用于MySQL。 我担心的是,当用户开始键入内容时,它必须从数据库中搜索并在列表视图中显示。 波纹管是我的搜索适配器 和POJO 还有我的SearchActivity.java
1回复

如何通过将数据插入到表中来显示从MySQL数据库到Android的数据?

我正在创建一个Android应用程序,以显示数据来自MySQL数据库的表。 我的代码正在运行,没有错误。.但是,来自DB的数据未显示在表上。 顺便说一下,我正在使用Eclipse作为编译器。 这是我的数据库: 这是我与Json的PHP代码: 这是我的DB Java代
1回复

在Java中使用Json对象更新数据库

我正在尝试更新数据库中存在的位置。 该位置以包含城市ID和城市名称的城市数组列表的形式存储。 我正在尝试让应用知道位置。 如果用户位置发生更改,则从Home Frame Activity的onCreate()方法调用此函数。 如果您可以看一下这段代码,并让我知道这是更新数据库的过程还是需
2回复

在Fragments中使用JSON时,应用程序在Android开发中没有响应

我在android中使用导航抽屉。 我通过JSON从URL获取数据。 当我在加载片段时运行应用程序时会出现错误 “不幸的是,应用程序没有响应”我从PHP文件中获取JSON数据,它现在从INTERNET中获取,它位于localhost中。 我的片段类是: 而我的JSO
1回复

来自MySQL数据库的数据未显示在Android Textview中

我无法显示MySQL数据库中的数据。 我想从数据库中检索一些数据并将其显示在textview中,但是它不起作用。 Java代码: PHP代码: 我从其他帖子中看到了示例代码,但是我不太了解如何应用它。 你能给我示例代码吗?
1回复

Android:Json无法从mysql数据库中检索任何文件,它是空的

我是Android新手,我正在使用mysql数据库,我连接php文件进行连接工作正常但我的代码没有显示任何东西它只显示背景颜色黑色而不是显示数据库中的数据 从文件夹Android / pictures / image1 json检索图像时出现的另一个错误是不打印部署到数据库中的特定图像
1回复

在Android应用中显示从远程数据库获取的数据? 显示位

可能是一个菜鸟问题,但希望我也能学到将来如何做。 我已经连接到服务器上的mysql数据库,连接正常,一切正常。 问题是我不知道如何将数据放入表格中供我在布局中使用(表格布局是最好的方法吗?我不希望它填满整个布局,我希望能够在表格上方和下方添加文字)。 下面的代码将数据打印到logcat
1回复

我有一个mysql数据库和一个表,我将其编码为json,当我在浏览器中运行php文件时,以及当我从android获取它时,它与众不同

我有一个mysql数据库和一个表,我将其编码为json,当我在浏览器中运行php文件时,我得到了如下内容: 我认为还可以,但是当我在自己的android代码中获取它时,就像下面链接的图片一样: 这是我在android中使用的代码 那我该怎么办? 感谢您的时间。
1回复

Java / Android JSON请求未更新接收到的数据

我从Activity请求一个PHP文件有一个小问题。 似乎可以正常地从JSON检索数据,但是毕竟,它显示了那里的旧数据。 我的意思是,例如,我发出请求以获取表(MySQL)中所有行的名称。 它首先收费,没有任何错误,但是如果我更改表中的行,JSON仍将检索旧的行数据。 我不知道,好像是将