Как выполнить проверку на стороне клиента и на стороне сервера? - PullRequest
0 голосов
/ 29 мая 2020

Я создавал форму 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';
        }
    })
});

Я могу выполнить проверку на стороне клиента, но если форма правильно проверена. Я не могу получить доступ к входному значению с помощью $ _POST ['name'] на стороне сервера PHP. Я думаю, что это связано с window.location. Есть ли лучший способ выполнить двустороннюю проверку?

Ответы [ 3 ]

1 голос
/ 29 мая 2020

Задайте правильный файл в параметре действия в форме.

И внутри условия if напишите e.currentTarget.submit();

if(name === true & subject_name === true){
    e.currentTarget.submit();
}
0 голосов
/ 29 мая 2020

Вы должны отправить свои данные на сервер, проблема заключалась в том, что window.location не отправлял никаких запросов на сервер, чтобы иметь возможность сообщника, использующего

$.post('url to the server', { data1 : "Your data", data2 : yourvar }, function(res) {
   console.log(res)
});
0 голосов
/ 29 мая 2020

Изменение вашего местоположения выполняет GET, когда вам нужен POST

Изменить на

$('#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){
        $.post('controller/indexPage_logic.php', {name:rollno}, function(response) { console.log(response)}); // do what you need to do when valid on the server too
    }
})
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...