簡體   English   中英

AngularJS,PHP和json_decode

[英]AngularJS, PHP and json_decode

我正在嘗試將值從AngularJS發送到PHP,如下所示

loginService.js

'use strict';

app.factory('loginService',function($http)
{
   return{
       login:function(user){
                var promise = $http.post('data/user.php',user); //send data to user.php
                promise.then(function(msg){
                    if(msg.data=='succes') console.log('succes login');
                    else console.log('error login');   
                })
       }
   }
});

我的PHP文件如下

user.php

<?php
    $user=json_decode(file_get_contents('php://input'));

    if($user->mail=='foysal@gmail.com' && $user->pass=='1234')
    {   
        print 'succes';
    }
    else 
    {   
        print 'error';
    }
 ?>

我的輸出如下

error login

loginCtrl.js

'use strict';

app.controller('loginCtrl',function($scope,loginService)
{
    $scope.login=function()
    {
    loginService.login();
    }
})

誰能說我的錯誤在哪里?

謝謝

我收到這樣的消息“ <br />↵<b>Notice</b>: Trying to get property of non-object in <b>D:\\php\\htdocs\\login_angularjs\\app\\data\\user.php</b> on line <b>14</b><br />↵" ”行

我如何在這里調試? 就像,是php文件獲取值? 是PHP文件發送值?

更新

我想我無法從HTML表單中收集值。 我在這里提供HTML表單代碼。您能幫我解決這個問題嗎?

login.tpl.html

Welcome : {{user.mail}}

<div class="bs-example">
    <form role="form" name="form1">
        <div class="form-group">
            <p>Welcome : {{user.mail}}</p>
            <label for="exampleInputEmail">Mail</label>
            <input type="text" placeholder="Enter name"
class="form-control" required ng-model="user.mail">
        </div>
        <div class="form-group">
            <label for="exampleInputPassword">Password</label>
            <input type="password" placeholder="Password"
id="exampleInputPassword" class="form-control" required
ng-model="user.pass">
        </div>
        <button class="btn btn-default" type="submit"
ng-disabled="form1.$invalid" ng-click="login(user)">Submit</button>
        <p></p>
    </form>
</div>

您在PHP中需要這樣的東西:

幫手:

function getReturnObject ($message, $code) {
    $response = new StdClass();
    $response->message = $message;
    $response->code = $code;
    return $response;
}

主要代碼:

print json_encode(getReturnObject('auth is successull', 200);

要么:

header('HTTP/1.0 403 Forbidden');
print json_encode(getReturnObject('auth is bad', 403);

然后在JavaScript中,您需要這樣做:

var module = angular.module('myApp', []);
module.controller('myCtrl', ['$http', function ($http) {
  var user = null; // some user
  $http.post('data/user.php', user)
    .success(function (data) {
    // handle response there
    })
    .error(function (data) {
      console.log('error');
    });
}]);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM