app.post('/user/signin',function(req,res){
var user=req.body.user;
var {name,password}=user;
User.findOne({name:name},function(err,user){
if(err) console.log(err);
if(!user) return res.json({state:1});
user.comparePassword(password,function(err,isMatched){
if(err) console.log(err);
if(isMatched) {
res.json({state:3});
}
else res.json({state:2});
});
});
});
$('#signinModal .btn-success').on('click',function(e){
$.ajax({
type:'POST',
url:'/user/signin',
data:$('#signinModal form').serialize(),
success:function(data){
switch(data.state){
case 1:$('#errorName').css({opacity:1});break;
case 2:$('#errorPassword').css({opacity:1});break;
case 3:location.href='/';break;
}
}
});
});
你可以通过req.session.user = userInfo将用户信息赋值给req.session.user
这个当你跳转到主页时你可以通过req.session.user获取用户信息。
如果你的前端页面需要的话,你可以在渲染的时候传值过去,比如
如果你使用的是express框架的话可以使用res.locals.user = req.session.user;
这样你的页面直接使用user这个变量就可以获取了,比如:
(举java后台为例)前端ajax提交表单后(
var loader = new net.AjaxRequest(url, deal_data, onerror, "POST", params);
)[注:net.AjaxRequest是预定义好的一个函数,其中deal_data为ajax请求成功后的回调处理函数],后台进行业务处理后,使用JSONArray放置需返回的结果,httpservletresponse写进去,返回给前端,由ajax的回调函数处理:获得返回文本,解析成json数据,按需处理。