ivqBlog 开源博客 (angularjs + express + mongodb)

时间:2022-11-04 05:42:17

转向做全职前端差不多一年的时间了,其中学习了构建工具grunt,gulp,angularjs,coffeescript,less,sass,自己想要做全栈开发,所以自学了mongodb,nodejs,express后端开发。

这个博客是对前段时间的学习做一个总结,整理需求,架构,开发,测试,部署大概花了一个半月的时间,代码水平是入门级别。

线上地址:http://www.ivqblog.com/

项目源码:https://github.com/TerryChenUI/ivqBlog

系统环境和部署

环境版本:

  1. NodeJS:v0.12.2

  2. Express:4.0

  3. MongoDB:3.04

  4. bower:1.72

  5. gulp:3.9

安装:

  1. MongoDB官网下载后,修改ivqBlog\scripts\mongodb目录下的配置项,安装MongoDB服务并启动。

  2. 创建ivqBlog数据库,创建users数据表,并且导入ivqBlog\db\users.json数据,账号和密码都为admin。

  3. webui和www目录下执行npm run prebuild安装相关包。(若相关的包安装失败,请将它删掉再重新安装。gulp-sass总是安装失败,有解决办法请指教)

启动:

在webui目录下执行gulp命令即可启动项目。

项目架构

本项目采用前后端开发分离的方式。根据gulp任务配置,会将webui编译到www目录下,分为开发版本和产品版本。

ivqBlog 开源博客 (angularjs + express + mongodb)

组件开发,模块包含模板html,sass样式,js脚本,单元测试spec,自动化测试等。

ivqBlog 开源博客 (angularjs + express + mongodb)

任务配置

具体可查看build相关配置。

dev:

  1. copy

  2. 编译sass文件为css

  3. 编译模板文件html为angularjs模块

  4. 动态为index.html,admin/index.html,admin/login.html 注入css文件,js文件

prod:

  1. copy

  2. 编译sass文件为css

  3. 合并并压缩css和js

  4. 编译模板文件html为angularjs模块

  5. 动态为index.html,admin/index.html,admin/login.html 注入css文件,js文件

default:

  1. dev

  2. nodemon启动express

  3. watch sass,html,js文件

  4. browser-sync,设置proxy端口与express的保持一致,自动打开浏览器

debug:

  1. dev

  2. watch sass,html,js文件

  3. browser-sync,设置proxy端口与express的保持一致,自动打开浏览器

身份验证

nodejs使用jwt-simple生成token输出到客户端,根据这个token作身份验证,相关使用请查看以下链接。

http://www.sitepoint.com/using-json-web-tokens-node-js/

https://www.npmjs.com/package/jwt-simple

https://cnodejs.org/topic/53c652bfc9507b404446ee40

调试

使用webstrom调试nodejs,如下图配置,执行gulp debug即可调试。

ivqBlog 开源博客 (angularjs + express + mongodb)