ID 및 어레이 문자열 목록을 volley requset에서 PHP로 보내려고합니다. 하지만 어떻게 제대로 서버에 보낼 수 있는지 모르겠어 그리고 어떻게 PHP로 얻을 수 있습니다. 다음은 서버에 요청을 보낼 수있는 안드로이드 쪽 :발리 요청에서 arraylist 데이터를 보내고 PHP로 들어올 수있는 방법
private void sendMessage() {
StringRequest stringRequest = new StringRequest(Request.Method.POST, Config.NOTIF_URL,
new Response.Listener <String>() {
@Override
public void onResponse(String response) {
Log.d("Response --->", response);
jsonNotif = new ParseJSON(response);
jsonNotif.parseJSON();
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(context, error.getMessage(), Toast.LENGTH_LONG).show();
}
}) {
@Override
protected Map < String, String > getParams() throws AuthFailureError {
Map < String, String > params = new HashMap < >();
//Adding parameters to request
ArrayList <String> courseList = new ArrayList <String> (checkedSet);
String ID = prefProfID.getString(Config.PROFID_SHARED_PREF, "0");
Log.d("ID prof list >>", ID);
params.put(Config.PROFID_SHARED_PREF, ID);
for (int i = 0; i < courseList.size(); i++) {
params.put("courselist", courseList.get(i));
}
//returning parameter
return params;
}
};
RequestQueue requestQueue = Volley.newRequestQueue(context);
requestQueue.add(stringRequest);
}
을 그리고 여기 내 PHP 코드입니다 : 당신이 ArrayList에 데이터를 보내려면
이<?php
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
//Getting values
$courseList = $_POST['courseList'];
$professor_ID = $_POST['Prof_ID'];
require_once('dbConnect.php');
$newcourseList = implode(", ", $courseList);
$sql = "select Stud_ID,student.f_Name,student.l_Name from student,course where course.S_ID = student.Stud_ID and course.P_ID in ($newcourseList)";
$res = mysqli_query($con, $sql);
$result = array();
while ($row = mysqli_fetch_array($res)) {
array_push($result, array(
'id' => $row[0],
'fname' => $row[1],
'lname' => $row[2],
'tag' => 'studlist'
));
}
echo json_encode(array(
"result" => $result
));
mysqli_close($con);
}
?>
는 JSON 형식으로 변환하고 문자열로 전송 – Sush