gpt4 book ai didi

php - 如何从MySQL数据库中检索特定用户数据并显示在 ListView 中?

转载 作者:行者123 更新时间:2023-11-29 10:51:13 24 4
gpt4 key购买 nike

我正在开发Android应用程序,它是食堂自动化系统。我想显示用户下的所有订单以及我存储在订单表中的所有订单。现在的问题是我不知道如何从 MySQL 检索数据并在 ListView 中显示该特定用户订单历史数据。

这是我最后一年的项目。

import android.app.ProgressDialog;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;

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

import java.util.ArrayList;
import java.util.List;
import java.util.Map;


public class OrderScreen extends AppCompatActivity implements View.OnClickListener {

private EditText editTextId;
private Button buttonGet;
private TextView textViewResult;
private ProgressDialog loading;
String result = null;


@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_order_screen);
SharedPreferences sp = getSharedPreferences("login", 0);
String user_id = sp.getString("userid", null);
editTextId = (EditText) findViewById(R.id.editTextId);
editTextId.setText(user_id);
buttonGet = (Button) findViewById(R.id.buttonGet);


buttonGet.setOnClickListener(this);

}

List<Map<String, String>> countryList = new ArrayList<Map<String, String>>();

private void getData() {
String id = editTextId.getText().toString().trim();
if (id.equals("")) {
Toast.makeText(this, "Please enter an id", Toast.LENGTH_LONG).show();
return;
}
loading = ProgressDialog.show(this, "Please wait...", "Fetching...", false, false);

String url = Config.DATA_URL + editTextId.getText().toString().trim();

StringRequest stringRequest = new StringRequest(url, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
loading.dismiss();
showJSON(response);
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(OrderScreen.this, error.getMessage().toString(), Toast.LENGTH_LONG).show();
}
});

RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
}

private void showJSON(String response) {
String name = "";


try {
JSONObject jsonObject = new JSONObject(response);
JSONArray result = jsonObject.getJSONArray(Config.JSON_ARRAY);

for(int i=0; i<result.length(); i++) {
JSONObject collegeData = result.getJSONObject(i);
String[] values = new String[]{collegeData.getString(Config.KEY_NAME)};

// address = collegeData.getString(Config.KEY_ADDRESS);
// vc = collegeData.getString(Config.KEY_VC);


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

ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
android.R.layout.simple_list_item_1, android.R.id.text1, values);
listView.setAdapter(adapter);
}
}



catch (JSONException e) {
e.printStackTrace();

}

}

@Override
public void onClick(View v) {
getData();
}
}

最佳答案

您需要用 PHP 编写后端 API。考虑以下因素:

  • Android 应用需要向该系统发送 HTTP 消息来读取或写入数据。
  • 来自应用的每条消息都必须包含凭据,以证明该应用有权读取或写入数据。
  • 如果安全性对您来说很重要,则 API 应通过 HTTPS 运行,以便第三方更难拦截凭据。
  • API 通常使用 JSON 进行数据输入和输出,但 XML 也可以。
  • 如果您想读取用户下的订单,那么您可以使用以下格式:

    GET /orders?user=<user>&password=<password>

    如果您像这样将凭据放入查询字符串中,则使用 HTTPS 很重要,但我认为对于研究项目来说这并不重要。

  • 然后,您的 API 应针对数据库运行一段 SQL 来读取订单,例如:

    SELECT * FROM order
    INNER JOIN food_item_order ON (order.id = food_item_order.order_id)
    INNER JOIN food_item ON (food_item_order.food_item_id = food_item.id)
    WHERE order.user_id = ?

    我在这里暗示了一个四表数据库,上面的三项形成了多对多关系。

关于php - 如何从MySQL数据库中检索特定用户数据并显示在 ListView 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43698361/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com