向mysql数据库添加信息

时间:2014-05-31 20:41:30

标签: php mysql ajax

在我继续之前,我想说我是初学者,我正在尝试使用ajax验证表单,用于用户名可用性。验证完成。但是,每次页面被重定向到表单操作页面时(即使有错误)。我想,如果有错误,我会收到一条警告消息,如果没有错误,则会将数据写入db。我已经尝试了很长一段时间,但我想我搞砸了,我不明白什么是错的。请纠正我的错误。我只是想学习。我在这做错了什么,我该怎么办?

和registration.php

 <!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <!--<link rel="stylesheet" type="text/css" href="css/style.css"/>-->
    <title>Using AJAX</title>
    <script type="text/javascript" src="jquery-2.1.1.js"></script>
    <script type="text/javascript">
        $(document).ready(function() {
            $('#txtUsr').on('keyup', function(){
                var username=$("#txtUsr").val();
                var user_name_avail_result=$('.check');
                var userCorrect=true;
                if(username.length>2)
                {
                    $.ajax({        
                    type : 'POST',
                    cache:'false',
                    data : "username="+username,
                    url  : "usr_available.php",
                    beforeSend: function()
                    {
                        user_name_avail_result.fadeIn(1000).html('<img src="green_ajax-loader.gif" /> ');
                    },
                    success: function(responseText) {
                    if(responseText == 200)
                    {
                        $(".check").html("<img src='available.png'/><span style='color:#59b200;'>Username available</span>");
                    }
                    else if(responseText ==201)
                    {
                        $(".check").html("<img src='not-available.png'/><span style='color:#ff0033;'>Username not available</span>");
                        userCorrect=false;
                    }
                    else if(responseText==202)
                    {
                        $(".check").html("Username too short");
                        userCorrect=false;
                    }
                }
            });
            }
            else
            {
            user_name_avail_result.html('<span style="color:#e50000;">Name too Short!</span>');
            userCorrect=false;
            }   
        if(username.length == 0) {
            user_name_avail_result.html("");
            userCorrect=false;
        }
        var exprUsr=/(^[A-Za-z][A-Za-z0-9]*([._-][a-z0-9]+){3,15})$/;
        if(!exprUsr.test(username))
        {
            userCorrect=false;
        }
    });
    $("#txtPwd").on('keyup',function(){
                var regPwd=/^((?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[@#$%]).{6,12})+$/;
                var passTxt=$('#txtPwd').val();
                var pwdCorrect=true;
                if(!regPwd.test(passTxt))
                {
                    $(".chkPwd").html('<div style="width:200px; height:80px; margin-left:190px; margin-top:-20px; text-align:left;"><span style="font-size:small; color:#ff0033;">Password must contain at least one digit, one lowercase, one uppdercase and one special character</span></div>');
                    pwdCorrect=false;
                }
                else
                {
                    $(".chkPwd").html("");
                }
                if(passTxt.length==0)
                {
                    $(".chkPwd").html("You Must Enter a Password");
                    pwdCorrect=false;
                }

            });

    $("#txtUsr,#txtPwd,#txtMob").keydown(function(e) { <!-- Dont allow users to enter spaces for their username and passwords and Mobile Number-->
        if (e.which == 32) {
            return false;
        }
    });
    $("#txtMob").keydown(function(e){<!--No other keys except number keys and backspace and tab work-->
        if(e.which==8 || e.which==9)
            return true;
        if(e.which<48 || e.which>57)
            return false;
    });
    $("#txtMob").on('keyup',function(){
        var exprMob=/^[789]\d{9}$/;
        var mobNum=$('#txtMob').val();
        var mobCorrect=true;
        if(!exprMob.test(mobNum))
        {
        if(mobNum.length<10)
        {
            $("#span3").html("Number must be minimum 10 characters long");
            mobCorrect=false;
        }
        else
        {
            $("#span3").html("Number in wrong format");
            mobCorrect=false;
        }
        }
        else
        {
        $("#span3").html("");
        }
    }); 
        function Validation(n){
        if(userCorrect==false || pwdCorrect==false || window.mobCorrect==false)
        {
            alert("One or More field(s) is/are unfinished/empty. Please re-check.");
            return false;
        }
        else
        {
            return true;
        }
    }
});
    </script>
    <script type="text/javascript">
        function clearAll()
        {
            document.getElementById("txtUsr").value="";
            document.getElementById("txtPwd").value="";
            document.getElementById("txtMob").value="";
        }
    </script>
    <style>
    .chkPwd
    {
        margin-left:80px;
    }
    .check
    {
        margin-left:90px;       
    }
    .form
   {
        margin:auto;
        text-align:center;
        font-family:Consolas;
        font-size:medium;
   }
   .texts
   {
        font-family:Consolas;
   }
   #userDiv
    {
    background-color:#ccdbff;
    height:320px;
    width:500px;
    border-radius:10px;
    opacity:0.8;
   }
   #mainBody
   {
      background-color:#7a7acc;
    width:100%;
    height:100%;
   }
  </style>
</head>
<body class="form" id="mainBody">
    <h1 style="color:#bfff00;">Registration</h1><br>
    <form class="form" id="regForm" action="registration_success.php" method="POST" onsubmit="return Validation(this)">
    <div class="form" id="userDiv"><br><br>
    Username: <input class="texts" id="txtUsr" name="txtUsr" type="text" placeholder="Type user name here" autocomplete="off" maxlength="15" autofocus="autofocus" title="Please dont enter an aweful username!"/><br>
    <span id="span1" class="check" style="font-size:small; color:"></span>
    <br>
    Password: <input type="password" id="txtPwd" class="texts" name="txtPwd" placeholder="Type password here" autocomplete="off" maxlength="12" title="Password must contain at least one digit, one lowercase, one uppdercase and one special character"/><br>
    <span id="span2" class="chkPwd" style="font-size:small; color:red;">Min 6 and Max 12 Characters</span><br>
    MobileNo.:<input type="text" maxlength="10" id="txtMob" class="texts" name="txtMob" placeholder="Enter your mobile number here" autocomplete="off" title="Please enter numbers only"/><br>
    <span id="span3" class="chkMob" style="font-size:small; margin-left:10px; color:#ff0033; font-size:small;"></span><br>
    <pre class="texts"> <input type="button" value="Back To LogIn" id="register" class="texts" name="register"/>   <input type="submit" value="Submit" id="submit" class="texts" name="send"/>   <input type="button" value="Reset" id="clear" onclick="clearAll()"/></pre>
    </div>
    </form>
</body>
</html>

user_available.php

<?php
if($_SERVER['REQUEST_METHOD']==='POST'){
    if(!empty($_POST['username'])){
            mysql_connect("localhost", "root","") or die ("Oops! Server not connected"); // Connect to the host
            mysql_select_db("db_chkAJAX") or die ("Oops! DB not connected"); // select the database
        // Check for the username posted
            $username= mysql_real_escape_string($_POST["username"]); // Get the username values & prevent SQL-Injection
            if(strlen($username)>2){
            $check_query= mysql_query('SELECT Username FROM LoginRecord WHERE Username = "'.$username.'" ') or die("Cannot get data from table"); // Check the database
            if(mysql_num_rows($check_query)<1){ // check num or rows 0 or greater than 0
                echo 200;//Username doesnot exist in database
                }
            else{
                echo 201;//Username exists in databse
                }
            } else {
                echo 202;//Too short username
                }
        }
        mysql_close($link);
        return;//Stop execution
    }   
?>

registration_success.php

<!--Writing to the database-->
<?php
    if(isset($_POST['send']) && !empty($_POST['txtUsr']) && !empty($_POST['txtPwd']) && !empty($_POST['txtMob']))
    {
    //Connecting to databse
        $usr_name=test_input(strtolower($_POST['txtUsr']));
        $pwd=$_POST['txtPwd'];
        $mob=test_input($_POST['txtMob']);
        $db_host='localhost';
        $db_user='root';
        $db_pwd='';
        $conn=mysql_connect($db_host, $db_user, $db_pwd,true);
        if(!$conn)
        {
            echo "Database connection Unsuccessful".mysql_error($conn)."<br>";
        }   
        else
        {
            echo "Database connection Successful"."<br>";
        }   
    //Creating a new database
        $sql="CREATE DATABASE IF NOT EXISTS db_chkAJAX";
        if (mysql_query($sql,$conn))
        {
              echo "Database db_student created successfully"."<br>";
        } 
        else
        {
              echo "Error creating database: "."<br>";
        }
    //Creating a Table
        $dataselect=mysql_select_db("db_chkAJAX",$conn);
        if(!$dataselect)
        {
            die("Database not Selected".mysql_error()."<br>");
        }
        else
        {
            echo "Database Selected"."<br>";
        }
        $sql_create="CREATE TABLE IF NOT EXISTS LoginRecord (Username varchar (50), Password varchar(15), MobileNumber bigint(10))";
        $qry=mysql_query($sql_create);
        if(!$qry)
        {
            die("Table not created".mysql_error()."<br>");
        }
        else
        {
            echo "Table Created Successfully"."<br>";
        }
    //Inserting values into table
        $data_insert="INSERT INTO LoginRecord(Username, Password, MobileNumber) VALUES('$usr_name', '$pwd', '$mob')";
        $data_insert_query=mysql_query($data_insert);
        if(!$data_insert_query)
        {
            die(" Unsuccessful data Insertion into table".mysql_error()."<br>");
        }
        else
        {
            echo "Data inserted into table successfully"."<br>";
        }
    //Closing the connection
        mysql_close($conn);
    }
    function test_input($data) {
   $data = trim($data);
   $data = stripslashes($data);
   $data = htmlspecialchars($data);
   return $data;
}

?>

1 个答案:

答案 0 :(得分:0)

一个问题是,您在javascript而不是javascript评论中使用html评论,请使用//

http://www.jshint.com

此外,您似乎需要将检查变量设置为全局,因为您在函数外部验证它们是否有效。

我认为您不需要将this置于Validate()

之内

http://www.w3schools.com/js/js_form_validation.asp