Json object in php is not readable

I want to transfer username

, and password

a PHP script to check the database. On the client side, I use the following script to render json object

and post it to a php file.

var myobj = {};
myobj["usrname"]= $( "#customer option:selected" ).text();
myobj["usrpass"]= $("#psw").val();

var myjson = JSON.stringify(myobj);

$.ajax({
method: "POST",
url: "checkpass.php",
data: myjson
})
.done(function( msg ) {
    alert( msg );
});

      

On the server side, when I see in firebug

, the message is sent as

Application options / x -www-form-urlencodedDo not sort {"Usrname": "XXXXXXX ...
JSON

usrname "XX"

usrpass "just do it" Source {"Usrname": "XXX", "usrpass": "JustDoIt"}

however, when I run the php script to check the request, it returns an error

$usrname = $_POST['usrname'];
$usrpass = $_POST['usrpass'];

$sql = "select count(*) from glusers where EmpName='$usrname' and EmpPass='$usrpass'";
$result = $conn->query($sql);

if($result >0){
$output = 'Success';
} else
{
$output = 'fail';
}

      

I have tried all the posts but cannot get this to work.

Thanks in advance.

Hello,

+3


source to share


5 answers


Echo and cancel statement so ajax has success event

Js file

 var myobj = {};

        myobj["usrname"] = 'myUsername';

        myobj["usrpass"] = 'myPassword';



        $.ajax({
            type: "post",
            url: "url",
            dataType: "json",
            data: {post_data: myobj},
            contentType: "application/x-www-form-urlencoded",
            success: function (responseData) {
                console.log(responseData);
            },
            error: function (errorThrown) {
                console.log(errorThrown);
            }
        });

      



PHP Action File

           /** if we print post we will get the following array * */
//print_r($_Post);
//die()
//Array
//(
//    [post_data] => Array
//        (
//            [usrname] => myUsername
//            [usrpass] => myPassword
//        )
//
//)

if (isset($_Post['post_data'])) {
    $myPost = $_Post['post_data'];
    $usrname = $myPost['usrname'];
    $usrpass = $myPost['usrpass'];

    $sql = "select count(*) from glusers where EmpName='$usrname' and EmpPass='$usrpass'";
    $result = $conn->query($sql);
    $num_row = $result->num_rows;

    if ($num_row > 0) {
        $output = 'Success';
    } else {
        $output = 'fail';
    }
    echo json_encode($output);
    die();
}

      

+2


source


Try this, in your js file:

$(document).on("ready", function(){

            // Create an object using an object literal.
            var ourObj = {};

            // Create a string member called "data" and give it a string.
            // Also create an array of simple object literals for our object.
            ourObj.data = "Some Data Points";
            ourObj.arPoints = [{'x':1, 'y': 2},{'x': 2.3, 'y': 3.3},{'x': -1, 'y': -4}];


            var savedata = JSON.stringify(ourObj)
            $.ajax({
                type:"POST",
                url:"Users.php",
                data: {"points" : JSON.stringify(ourObj)},
               success: function(data) {
                    // Do something with data that came back. 
                    alert(data);
               }

            })
        }); 

      



In PHP file:

if (isset($_POST["points"])) {
$points = json_decode($_POST["points"]);


echo "Data is: " . $points->data . "<br>";
echo "Point 1: " . $points->arPoints[0]->x . ", " . $points->arPoints[0]->y;
}

      

+1


source


Try the following:

var myobj = '{
usrname:'+$( "#customer option:selected" ).text()+',
usrpass:'+$("#psw").val()+'
}';

      

or

var myobj = {};
myobj.usrname= $( "#customer option:selected" ).text();
myobj.usrpass= $("#psw").val();

      

0


source


Use Json2 the following library,

var myobj = {};
myobj["usrname"]= $( "#customer option:selected" ).text();
myobj["usrpass"]= $("#psw").val();

var myjson = JSON2.stringify(myobj);

$.ajax({
 method: "POST",
 url: "checkpass.php",
 data: myjson
})
.done(function( msg ) {
  alert( msg );
});

      

0


source


Well, actually, your php code is not valid because you are passing in a json day not name value pair so that you cannot get it from $ _POST ['username']. You need to get all the message data and decode it like that.

$ data = json_decode (file_get_contents ('php: // input'), true);

Now $ data is a dictionary array of username and password. Also sanitize your data before going to query to avoid sql injection.

0


source







All Articles