2
im angularJs中的新功能,即时尝试使用angularJS和nodejs(服务器端)进行基本登录,现在我不在乎安全性,只是试图学习如何发布。所以我做了一个登录表单,并用角控制器:将angularjs发布到nodejs Express(Bad request)
我的登录表单:
<div class="col-md-4">
<h1>Login</h2>
<form class="form" >
<div class="form-group">
<label>Username</label>
<input type="email" class="form-control" ng-model="login.mail" required>
</div>
<div class="form-group">
<label>Password</label>
<input type="password" class="form-control" ng-model="login.password" required>
</div>
<div>
<button type="text" class="btn btn-default" ng-click="login()">Login</button>
</div>
</form>
</div>
然后我的路由器&控制器Angularjs:
'use strict';
angular.module('login', ['ngRoute'])
.config(['$routeProvider', function($routeProvider) {
$routeProvider.when('/login', {
templateUrl: 'views/login.html',
controller: 'loginCtrl'
});
}])
.controller('loginCtrl', ['$scope', '$http', function ($scope, $http) {
$scope.login = function() {
$http.post('/api/users/login', $scope.login).success(function (response) {
console.log(response);
// refresh();
});
};
}]);
和服务器端我有:
router.post('/login/', function(req, res) {
// here "/login/" means "https://stackoverflow.com/users/login" (in index of controllers)
console.log(req.body.mail);
var usermail = req.body.mail;
var pass = req.body.password;
console.log(usermail + pass);
User.find({mail: usermail}, function(err, user) {
if (err) {
res.send(err);
console.log("ça marche pas")
} else {
res.json(user);
console.log(user);
}
})
});
服务器端:它的工作原理(当我使用DHC铬扩展早报),但是当使用im angularjs查看我得到这个错误:
POST http://localhost:3000/api/users/login 400(错误请求)
请帮我解决这个问题,我想我错过了什么。先谢谢你。
我只是想发送到电子邮件和密码计算在我的服务器的登录表单,我确定我的控制器不工作:现在我试着用你的表达它给了我一个404错误 我忘记告诉你,我有不好的请求400,并在服务器端:无效json – AmenzO
您将不得不调试自己正在发送到服务器的内容。如果您使用浏览器开发工具(F12)。您可以观看发送到您的API的内容。然后,您可以检查您发送的JSON是否有效(例如,在本网站上:http://json.parser.online.fr/)。 –
我已经更新了我的答案,它显示了如何改进您的代码。你有一个函数$ scope.login,你可以指定你的变量。 –