在 php 中循环遍历 JSONArray 的值

Loop through values of a JSONArray in php

我在 android 应用程序中有 3 个数组列表。我通过 android volley POST 请求将它们发送到 php,例如:

public RequestPostBook(long id, ArrayList<String> bookNames, ArrayList<String> bookAuthors, ArrayList<String> subjects,
                           String date,Response.Listener<String> listener)
    {
        super(Method.POST, REGISTER_REQUEST_URL, listener, null);

        JSONArray bookNamesJSON = new JSONArray(Arrays.asList(bookNames));
        JSONArray bookAuthorsJSON = new JSONArray(Arrays.asList(bookAuthors));
        JSONArray subjectsJSON = new JSONArray(Arrays.asList(subjects));


        params = new HashMap<>();
        params.put("candidateId", id + "");
        params.put("bookName",bookNamesJSON.toString());
        params.put("authorName",bookAuthorsJSON.toString());
        params.put("subjectName",subjectsJSON.toString());
        params.put("reqDate",date);
    }

    @Override
    public Map<String, String> getParams() {
        return params;
    }

现在我必须使用 php 中的 arrayList 中的值来执行一系列类似的查询。我在 php:

中尝试这个
$candidateId=$_POST["candidateId"];
$reqDate=$_POST["reqDate"];
$subjectName=json_decode($_POST["subjectName"]);
$bookName=json_decode($_POST["bookName"]);
$authorName=json_decode($_POST["authorName"]);
$i=0;
foreach($subjectName as $value)
{
    $subject=$subjectName[$i];
    $book=$bookName[$i];
    $author=$authorName[$i];

    $stmt = $conn->prepare("INSERT INTO BookRequisition VALUES (?,?,?,?,?);");

    $stmt->bind_param("dssss", $candidateId, $subject, $book, $author, $reqDate);

    $stmt->execute();

    $i++;
}

当我 运行 通过该应用程序时,这就是我在 BookRequisition table 中得到的内容 table:

12100116050(candidateId)    Array(subjectName)    Array(bookName)    Array(authorName)    2019-03-08(reqDate)

任何人都可以帮助我如何将正确的值发送到 table?提前致谢。

请尝试以下代码。

<?php

$candidateId = $_POST["candidateId"];
$reqDate = $_POST["reqDate"];
$subjectName = json_decode($_POST["subjectName"])[0];
$bookName = json_decode($_POST["bookName"])[0];
$authorName = json_decode($_POST["authorName"])[0];

foreach ($subjectName as $i => $subject) {
    $stmt = $conn->prepare("INSERT INTO BookRequisition VALUES (?,?,?,?,?);");
    $stmt->bind_param("dssss", $candidateId, $subject, $bookName[$i], $authorName[$i], $reqDate);
    $stmt->execute();
}

?>

注意:您应该对从您的设备发布的数据进行适当的验证。