【问题标题】:Send a value of variable in android studio to php将android studio中的变量值发送到php
【发布时间】:2017-04-24 07:16:37
【问题描述】:

我在将 Android Studio 变量中的值传递给 php 代码时遇到问题。在这种情况下,我想将 Message.java 中变量“group_id”中的值传递给 DbOperation.php。这意味着最后,DbOperation.php 中的函数“getMessages”可以获取变量“group_id”的值并选择 MySQL 数据库中的特定表。我还是 Android Studio 的新手,请帮我解决这个问题。非常好。

例如:变量“group_id”的值为“ABC123”,DbOperation.php中的“getMessages”函数会执行“SELECT a.id, a.message, a.sentat, a.users_id, b.name FROM ABC123_messages a, users b WHERE a.users_id = b.id ORDER BY a.id ASC;"

下面这段代码是Message.java的java类

 SharedPreferences sharedPreferences = getActivity().getSharedPreferences(Config.SHARED_PREF_GROUP, Context.MODE_PRIVATE);
 group_id = sharedPreferences.getString(Config.GROUP_SHARED_PREF, "Not Available");


 private void fetchMessages() {
    StringRequest stringRequest = new StringRequest(Request.Method.POST, URLs.URL_FETCH_MESSAGES,
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    //dialog.dismiss();

                    try {
                        JSONObject res = new JSONObject(response);
                        JSONArray thread = res.getJSONArray("messages");
                        for (int i = 0; i < thread.length(); i++) {
                            JSONObject obj = thread.getJSONObject(i);
                            int userId = obj.getInt("userid");
                            String message = obj.getString("message");
                            String name = obj.getString("name");
                            String sentAt = obj.getString("sentat");
                            Message messagObject = new Message(userId, message, sentAt, name);
                            messages.add(messagObject);
                        }

                        adapter = new ThreadAdapter(getActivity(), messages, AppController.getInstance().getUserId());
                        recyclerView.setAdapter(adapter);
                        scrollToBottom();

                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }
            },
            new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {

                }
            }){
        @Override
        protected Map<String, String> getParams() throws AuthFailureError {
            Map<String, String> params = new HashMap<>();
            params.put("group_id", group_id);
            return params;
        }
    };

    AppController.getInstance().addToRequestQueue(stringRequest);
}

这是 index.php 中 php 代码的一部分

$app->post('/messages', function () use ($app){
verifyRequiredParams(array('group_id'));
$group_id = $app->request()->post('group_id');
$db = new DbOperation();
$messages = $db->getMessages($group_id);
$response = array();
$response['error']=false;
$response['messages'] = array();
while($row = mysqli_fetch_array($messages)){
    $temp = array();
    $temp['id']=$row['id'];
    $temp['message']=$row['message'];
    $temp['userid']=$row['users_id'];
    $temp['sentat']=$row['sentat'];
    $temp['name']=$row['name'];
    array_push($response['messages'],$temp);
}
echoResponse(200,$response);});


function verifyRequiredParams($required_fields){
$error = false;
$error_fields = "";
$request_params = $_REQUEST;
// Handling PUT request params
if ($_SERVER['REQUEST_METHOD'] == 'PUT') {
    $app = \Slim\Slim::getInstance();
    parse_str($app->request()->getBody(), $request_params);
}
foreach ($required_fields as $field) {
    if (!isset($request_params[$field]) || strlen(trim($request_params[$field])) <= 0) {
        $error = true;
        $error_fields .= $field . ', ';
    }
}

if ($error) {
    // Required field(s) are missing or empty
    // echo error json and stop the app
    $response = array();
    $app = \Slim\Slim::getInstance();
    $response["error"] = true;
    $response["message"] = 'Required field(s) ' . substr($error_fields, 0, -2) . ' is missing or empty';
    echoResponse(400, $response);
    $app->stop();
}}

这是 DbOperation.php 中的函数之一

public function getMessages($group_id){
    $stmt = $this->conn->prepare("SELECT a.id, a.message, a.sentat, a.users_id, b.name FROM ?_messages a, users b WHERE a.users_id = b.id ORDER BY a.id ASC;");
    $stmt->bind_param("s",$group_id);
    $stmt->execute();
    $result = $stmt->get_result();
    return $result;}

【问题讨论】:

    标签: java php android mysql bindparam


    【解决方案1】:

    在 Android 代码中看起来不错。但我认为您还没有在 PHP 中捕获发送数据。使用

     $_POST["group_id"]
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-10-17
      • 1970-01-01
      • 2016-08-06
      • 2012-01-01
      • 1970-01-01
      相关资源
      最近更新 更多