java - Android 使用 AsyncTask 连接 MySql 并以 JSON 或 String 的形式返回数据

标签 java android mysql json android-asynctask

我一直在努力将 MySql 数据库连接到我的 android 应用程序并在互联网上搜索。一些解决方案适用于一个问题。问题在于该函数以 String 形式返回数据,而 String 的内容为:

[{"id":1,"username":"admin","password":"root","email":"admin@localhost.com","fullname":"Site Admin"}]

但我想要某种数组形式的数据,通过它我可以分别获取所有用户数据,如电子邮件、全名。我试图实现一个功能,但没有成功。以下是代码:

BackgroundWorker.java

public class BackgroundWorker extends AsyncTask<String,Void,String> {
Context context;
AlertDialog alertDialog;
String tresult;


BackgroundWorker (Context ctx){
    context = ctx;
}
@Override
protected String doInBackground(String... params) {
    String type = params[0];
    String username = params[1];
    String password = params[2];

    String login_url = "http://192.168.1.18/myproj/api/query1.php";
    if (type.equals("login")){
        try {
            URL url = new URL(login_url);
            HttpURLConnection httpURLConnection = (HttpURLConnection)url.openConnection();
            httpURLConnection.setRequestMethod("POST");
            httpURLConnection.setDoOutput(true);
            httpURLConnection.setDoInput(true);
            OutputStream outputStream = httpURLConnection.getOutputStream();
            BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream,"UTF-8"));
            String post_data = URLEncoder.encode("username","UTF-8")+"="+URLEncoder.encode(username,"UTF-8")+"&"+
                    URLEncoder.encode("password","UTF-8")+"="+URLEncoder.encode(password,"UTF-8");
            bufferedWriter.write(post_data);
            bufferedWriter.flush();
            bufferedWriter.close();

            outputStream.close();

            InputStream inputStream = httpURLConnection.getInputStream();
            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream,"iso-8859-1"));
            String line="";
            String result="";

            while((line = bufferedReader.readLine())!= null){
                result+=line;
            }

            bufferedReader.close();
            inputStream.close();
            httpURLConnection.disconnect();

            return result;

        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    return null;
}

@Override
protected void onPreExecute() {
    super.onPreExecute();
    alertDialog = new AlertDialog.Builder(context).create();
    alertDialog.setTitle("Login Status");
}

@Override
protected void onPostExecute(String result) {
    alertDialog.setMessage(result);
    alertDialog.show();
    tresult = result;
    //return tresult;
}

@Override
protected void onProgressUpdate(Void... values) {
    super.onProgressUpdate(values);
}


}

BackgroundWorker 是一个在后台工作并连接数据库的类。在 MainActivity 中它被调用如下:

主 Activity

public void onLogin(View view, String user, String pass){
    String type = "login";
    BackgroundWorker backgroundWorker = new BackgroundWorker(this);
    backgroundWorker.execute(type,user,pass);
}

函数的调用:

        loginbtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            String username = user_edittext.getText().toString();
            String password = pass_edittext.getText().toString();
            onLogin(v,username,password);


        }
    });

简而言之,我想从 MainActivity 中的 protected void onPostExecute(String result) 返回变量 result 或 tresult,并将其转换为数组。谢谢你!等待专家意见。

最佳答案

看来你有两个问题:

  1. 将 Json 字符串转换为更友好的格式
  2. 将这种友好的格式返回给另一个 Activity

在 1 上: 在 Java 中没有内置的解析 JSON 字符串的方法,但是有很多简单的库选项可用 - 查看 How to parse JSON in Java讨论这些的地方。

关于 2: 一般情况下,数据会转换为一个包并作为 Intent 系统的一部分返回到您的主要 Activity

关于java - Android 使用 AsyncTask 连接 MySql 并以 JSON 或 String 的形式返回数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40355517/

相关文章:

java - 为什么 Spring 项目导出的可运行 JAR 不能在另一个系统中工作?

java - Android + jfreeSVG : inheritance issues

android - 无法实例化一个或多个类 Android Studio

mysql - 我怎样才能对数据透视列的一部分进行 AVG 值计算?

java - Java中的unicode换行符(\u000d)

java - 请推荐一个基于 Java 的图形 PDF 生成器

android - 应用程序如何只供用户读取并且只有管理员有权发布(使用 firestorm 数据服务器)

php - 用 PHP 连接两个 MySQL 表

php - 如何显示存储在我的数据库中的所有图像?

java - 从 AsyncTask 返回对象时出现问题