如何进行客户端和服务器端验证?

问题描述 投票:0回答:1

我正在创建一个HTML表单,其中同时进行了客户端和服务器端验证。我使用了以下代码。

<form action='logic.php' method='post' id='login'>
    <input type='text' placeholder='Enter name' name='name'>
    <input type='submit'>
</form>

// Jquery
$(document).ready(function(){

    function validate_name(input_id,error_id,msg="Name"){
        const x = document.getElementById(input_id).value;
        const y = document.getElementById(error_id);
        const pattern = /^[a-zA-Z]+$/
        if(x!==""){
            if(pattern.test(x) ){
                if(x.length<3 || x.length>10){
                    y.innerHTML = msg+' should be between 3 and 10 characters.'
                    return false;
                }
                else{
                    y.innerHTML = '';
                    return true;
                }
            }
            else{
                y.innerHTML = 'Should contain only alphabets.'
                return false;
            }
        }
        else{
            y.innerHTML = "Please Enter Your "+msg;
            return false;
        }
    }


    $('#login').submit(function(e){
        e.preventDefault();
        let name = validate_name('rollno','rerror');
        let subject_name = validate_select('subject_dropdown','serror');
        if(name === true & subject_name === true){
            window.location = 'controller/indexPage_logic.php';
        }
    })
});

我也许可以进行客户端验证,但是如果正确验证了表单,则无法在服务器端PHP中使用$ _POST ['name']访问输入值。我认为这是由于window.location所致。有没有更好的方法可以进行双方验证?

php html jquery
1个回答
0
投票

您的位置更改需要POST时执行GET

© www.soinside.com 2019 - 2024. All rights reserved.