我想使用volley创建用户注册页面,但我无法将数据发送到服务器。这是我第一次使用凌空抽射。我已经包含了所有权限,服务器也正常运行,我只是无法将数据发送到在线数据库。
当我运行它时,它会给出以下消息:“警告mysqli prepare()要求参数1为mysqli,在家中给出布尔值...”
请帮忙。 这是我的android代码: 用户类包含名称,用户名,移动设备,密码的字符串。
private void registerUser(final User user) {
StringRequest stringRequest = new StringRequest(Request.Method.POST, SERVER_ADDRESS + "Register.php",
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Toast.makeText(Register.this,response,Toast.LENGTH_LONG).show();
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(Register.this,error.toString(),Toast.LENGTH_LONG).show();
}
}){
@Override
protected Map<String,String> getParams(){
Map<String,String> params = new HashMap<String, String>();
params.put("name",user.name);
params.put("username", user.username);
params.put("mobile", user.mobile);
params.put("password", user.password);
Log.d(name+username+"her", "her");
return params;
}
};
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
}
}
这是php文件:
<?php
if($_SERVER['REQUEST_METHOD']=='POST'){
$con=mysqli_connect("localhost","dbName","pass","userName");
$name = $_POST["name"];
$username = $_POST["username"];
$mobile = $_POST["mobile"];
$password = $_POST["password"];
$statement = mysqli_prepare($con, "INSERT INTO UserDetails (name, username, mobile, password) VALUES (?, ?, ?, ?)");
mysqli_stmt_bind_param($statement, "ssss", $name, $username, $mobile, $password);
mysqli_stmt_execute($statement);
echo $name, $username, $mobile, $password;
mysqli_stmt_close($statement);
mysqli_close($con);}
?>
答案 0 :(得分:0)
您需要在向其添加任何请求之前启动队列。
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.start()
requestQueue.add(stringRequest);
请确保只调用一次start()。因此创建一个单例类VolleyManager,当你创建这个类的实例时,它应该创建一个请求队列并启动它。对于每个API调用,只需调用VolleyManager.getInstance()。getQueue()。add(stringRequest)
答案 1 :(得分:0)
添加
全球$ con
在你的php文件中。