一个Javascript全栈开发:Node+MongoDB+Angular

本文算是本人第一次完成一个全栈式开发,后端基于Node.js,数据库基于MongoDB,前端主要基于Angular来实现的一个Web开发。本文算是第一个跑通的程序,本人也是通过学习JS全栈开发的过程,慢慢的积累,踩坑的过程。在web技术快速发展的现在,采用的依赖也越来越多,版本的更迭导致网上的教程过时,本文采用的库和node版本都是当前最新的,可以让大家少踩坑啦。

本文只是实现了简单的登入的后端逻辑和简单的前端界面,简单又容易上手。功能上支持用户注册,用户登录,用户注销,删除用户等基本功能。并且支持免密码登录一定时间的功能。

后端

后端依赖项

本程序采用当前最新的node版本6.7.0,主要采用如下的依赖项

   "body-parser": "~1.15.2",
    "connect-mongo": "^1.3.2",
    "cookie-parser": "~1.4.3",
    "ejs": "~2.5.2",
    "express": "~4.14.0",
    "express-session": "^1.14.2",
    "mongoose": "^4.7.1",

后端主程序

这节主要介绍配置后端主程序,主要包括设置中间件,建立session连接,数据库配置等。下面是一些主要的代码,完整的代码可以查看文末的连接。


// auth_server
var expressSession = require('express-session');
var mongoStore = require('connect-mongo')({session:expressSession});
var conn =mongoose.connect('mongodb://localhost/myapp');
// 当前版本mongoose已经取消了Promise,需要自己设置
mongoose.Promise = require('bluebird');
app.use(expressSession({
  secret: 'SECRET',
  cookie: {maxAge:60*60*1000},
  resave:true,
  saveUninitialized: true,
    store: new  mongoStore({
      mongooseConnection: conn.connection,
    collection: 'sessions'
  })
}));
require('./routes')(app);
app.listen(3030);

后端路由

路由是后端程序重要的一个环节,本文采用RESTful API 设计,处理登入,注册,详细页面的所有页面的接口。借助于express强大的功能,能够很简单的设置接口。具体可以参考完整的代码routes.js。需要注意的是在登录之后,后台后保存这次session,并且这个过程被写进中间件中去了,那么以后用户每次访问,就会获取信息。然后就可以免密码登录了。主要就是根据req.session.user是否已经存在。

后端业务逻辑处理

后端业务,包括登录,注册,获取用户详情,更新用户信息,删除用户。本文处理简单的业务逻辑。

  1. 登录逻辑:首先根据mongoose查找是否存在用户,如果存在并且密码正确,将用户保存在session里面,存进数据库里面去。下次就可以免密码访问了。
  2. 注册逻辑:首先根据模型生成一个用户,从请求体重获取需要的信息,存入到数据库。保存完成后,保存session,并返回到注册界面。
  3. 更新用户信息:在数据库中设置了用户名为主键,所以设置了用户名无法修改。修改完成返回到主界面
  4. 删除用户:从数据库中删除,返回到登录界面。

数据库

数据库采用MongoDB,通过mongoose建模,在新建用户和登录等操作中,实现了增删查改等基本操作,如下简单代码

// 建模
var userSchema = new schema({
  username:{type:String, unique:true},
  password:String,
  email:String,
  color:String,
  hashed_password:String
}); 
mongoose.model('User',userSchema);

// 添加一条记录
var user = new User({username:req.body.username});
  user.set('email',req.body.email);
  user.set('hashed_password',hashPW(req.body.password));
  user.save(function (err) {
    // to do something
  });
  // 查找,修改
   User.findOne({_id:req.session.user}).exec(function (err,user) {
    if (user) {
    // 修改 
      user.set('email',req.body.email);
      user.set('color',req.body.color);
      // 保存
      user.save(function (err) {
       // to do something
      });
    }
  });
  
  // 删除
    User.findOne({ _id: req.session.user })
      .exec(function (err,user) {
    if (user) {
      user.remove(function (err) {
       // to do something
      });
    } 
  });

实际代码可以参考文章后面链接。

前端

前端简单的写了四个界面。采用AngularJS进行前端开发。只用了ng-model用来动态绑定数据。具体代码可以参考文后代码。

结尾

本文代码放在Github上,有需要的可以下载下来,开启mongoDB,然后切换到auth_server.js目录下运行node auth_server.js即可(其实是我上传前忘记添加.gitignore,导致都上传了,哈哈)。

学生时代对于GitHub,没有什么特别深的感觉,觉得star太做,现在才发现,求赐star。感谢,希望大家能有收获。加油🆙

demo地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,108评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,699评论 1 296
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,812评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,236评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,583评论 3 288
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,739评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,957评论 2 315
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,704评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,447评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,643评论 2 249
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,133评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,486评论 3 256
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,151评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,108评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,889评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,782评论 2 277
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,681评论 2 272

推荐阅读更多精彩内容