简体   繁体   English

JavaScript向PHP发送空参数

[英]JavaScript sending empty parameters to PHP

I am attempting to create a user area for a website that is accessed by using a username and password. 我正在尝试为使用用户名和密码访问的网站创建用户区。 I am using HTML for the front end, JavaScript for the back end and PHP for the server side. 我在前端使用HTML,在后端使用JavaScript,在服务器端使用PHP。 I am using Xampp to run a local server and PHPMyAdmin to host the database. 我正在使用Xampp运行本地服务器,并使用PHPMyAdmin托管数据库。

The HTML Code: HTML代码:

<!-- the Login Section -->
    <input type="text" name="userName" placeholder="username" id="usernameBar">
    <input type="password" name="passWord" placeholder="password" id="passwordBar">
    <button id="loginButton" onclick="Login();">Login</button>
    <p id="IncorrectP" title="Incorrect Username or Password" style="display: none">Invalid</p>

JavaScript: JavaScript:

function Login(){

    //Connect to the PHP:
    var urlConnect = "checkLogin1.php";
    //Get the username and password:
    var usrUsername = document.getElementById("usernameBar").value;
    var usrPassword = document.getElementById("passwordBar").value;

    //Define the parameters to send to php
    var strParameters = "usrUsername="+usrUsername + "usrPassword="+usrPassword + "&sid=" + Math.random();

        //Define the options for the AJAX request
        var objOptions = {
        method: "post",
        parameters: strParameters,
        onSuccess: function(objXHR) {

            //If objXHR. responseText = Tenant:
            if(objXHR.responseText=='Tenant'){

                //Go to tenant space:
                alert("Success! (Tenant)");
                OpenTenantPage();

            } 
            //Else if objXHR.responseText = Staff:
            else if(objXHR.responseText=='Staff'){

                //Go to staff space:
                alert("Success! (Staff)");
                OpenStaffPage();

            }
            //Else if objXHR.responseText = Admin:
            else if(objXHR.responseText=='Admin'){

                //Go to admin space:
                alert("Success! (Admin)");
                OpenAdminPage();

            }
            else{

                //Run IncorrectLogin:
                alert("Error! No User Account Found!");
                IncorrectLogin();

            }
        }
    }

    // define the AJAX request object
    var objRequest = new Ajax.Request(urlConnect,objOptions);

}

PHP: PHP:

<?php

    //Link the username and password:
    $connect = mysqli_connect("localhost", "admin", "12345", "realestate") or die ('Connection to database failed: ' . mysql_error());
    //Extract variables for request parameters:
    extract($_REQUEST);

    //Try to log in as a tentant:
    $resTenantUser = mysqli_query($connect, "SELECT * FROM tenants WHERE Username='$usrUsername' AND Password='$usrPassword'") or die(mysql_error());
    //$resTenantUser = mysqli_query($connect, "SELECT * FROM tenants WHERE Username='Charb1' AND Password='123456' ") or die(mysql_error());
    //Set intCount to number of rows in result:
    $intCount = mysqli_num_rows($resTenantUser);

    if($intCount == 0){

        echo "Error!";

    }
    else{

        echo "Tenant";

    }

?>

I think that the error my be that the JS is not sending the parameters to the PHP or it is sending empty parameters. 我认为错误是因为JS未将参数发送给PHP或正在发送空参数。 I cannot seam to find my mistake though. 我虽然无法找到我的错误。

parameters必须采用JSON格式,而不是查询字符串格式。如下所示:
parameters:{usrUsername: usrUsername , usrPassword:usrPassword , sid : Math.random()}

Problem is in the query params. 问题出在查询参数中。 You missed & . 您错过了& Try this way. 尝试这种方式。

var strParameters = "usrUsername="+usrUsername + "&usrPassword="+usrPassword + "&sid=" + Math.random();

Or 要么

var strParameters = {"usrUsername" : usrUsername, "usrPassword" : usrPassword, "sid" : Math.random()}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM