摘要:注僅做記錄使用又不舍得刪除推薦使用相關(guān)資料很多的運行環(huán)境構(gòu)建基于全局安裝安裝過程略配置的淘寶鏡象全局安裝官方腳手架工具官網(wǎng)文檔創(chuàng)建項目基于模板創(chuàng)建創(chuàng)建配置按需,我除了安裝之外其他都選了運行與打包測試安裝依賴包運行打包配
注(2018-2-12):僅做記錄使用,又不舍得刪除,推薦使用koa2,koa2相關(guān)資料很多的~
1. 運行環(huán)境構(gòu)建(基于macOS Sierra 10.12.4)
全局安裝node(v6.9.4)
安裝過程略
配置cnpm(npm的淘寶鏡象)
sudo npm install -g cnpm --registry=https://registry.npm.taobao.org`
全局安裝vue官方腳手架工具vue-cli(vue官網(wǎng)文檔)
cnpm install --global vue-cli2. 創(chuàng)建項目
基于 webpack 模板創(chuàng)建
vue init webpack tifi-music
創(chuàng)建配置按需,我除了安裝router之外其他都選了no
運行與打包測試
cd tifi-misic //安裝依賴包 cnpm i //運行 npm run dev //打包 npm run build3. 配置express
在項目根目錄下創(chuàng)建server.js文件,內(nèi)容如下
//用于獲取路徑 const path = require("path") //用于讀寫文件流 const fs = require("fs") const express = require("express") //無需cnpm安裝,因為是express的中間件bodyParser //用于解析客戶端請求的body中的內(nèi)容,內(nèi)部使用JSON編碼處理,url編碼處理以及對于文件的上傳處理. //bodyParse可以接受客戶端ajax提交的json數(shù)據(jù),以及url的處理,不使用這個中間件將導(dǎo)致無法接收客戶端的json數(shù)據(jù) const bodyParser = require("body-parser") //需要cnpm安裝,cookieParser中間件用于獲取web瀏覽器發(fā)送的cookie中的內(nèi)容. //在使用了cookieParser中間件后,代表客戶端請求的htto.IncomingMessage對象就具有了一個cookies屬性 //該屬性之為一個對象的數(shù)組,其中存放了所有web瀏覽器發(fā)送的cookie,每一個cookie為cookies屬性值數(shù)組中的一個對象. const cookieParser = require("cookie-parser") //serve-favicon中間件用于請求網(wǎng)站的icon用法如下 //express().use(favicon(__dirname + "/public/images/favicon.ico")) const favicon = require("serve-favicon") //morgan中間件是日志中間件,用于node的日志輸出 //進階用法見http://www.cnblogs.com/chyingp/p/node-learning-guide-express-morgan.html const logger = require("morgan") //獲取后端路由.我設(shè)置在根目錄下的server文件,讀取下面的index.js const routes = require("./server/router") //用于管理配置的插件.統(tǒng)一管理后端服務(wù)端口和數(shù)據(jù)庫連接地址等,默認(rèn)配置在config目錄下的default.js中 const config = require("config-lite") //compression 中間件用于壓縮和處理靜態(tài)內(nèi)容 //例子:app.use(express.static(path.join(__dirname, "public"))) const compression = require("compression") //實例化express對象,用于連接中間件 const app = express() app.use(logger("dev")); app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: false })); app.use(cookieParser()); app.use(compression({ threshold: 0 })) app.use("/api", routes) app.use(express.static(path.resolve(__dirname, "./dist"))) // 因為是單頁應(yīng)用 所有請求都走/dist/index.html app.get("*", function(req, res) { const html = fs.readFileSync(path.resolve(__dirname, "./dist/index.html"), "utf-8") res.send(html) }) app.listen(config.port, function () { console.log(`Server running in port ${config.port}`) })
解決npm run dev時即開發(fā)模式下跨域問題
打開根目錄下的config目錄下的index文件,配置proxyTable如下:
proxyTable: { "/api": { //這里的target填服務(wù)端的端口的接口地址 target: "http://localhost:3000/api/", changeOrigin: true, pathRewrite: { "/api": "" } } }
創(chuàng)建router
server.js文件中寫了const routes = require("./server/router")
這里require的路徑就是我們需要創(chuàng)建router的路徑
在根目錄下創(chuàng)建server文件夾,并在其目錄下創(chuàng)建router.js文件,內(nèi)容如下:
//express的路由中間件,引入等待從controller中添加路由 const router = require("express").Router() //引入node的文件路徑模塊path和文件處理模塊fs const path = require("path") const fs = require("fs") //讀取controller文件下的所有控制器,為了實現(xiàn)動態(tài)讀取控制器,有空再研究更好的寫法 const controllers = fs.readdirSync(path.resolve(__dirname, "./controller")) //遍歷獲取到的文件,動態(tài)添加express的路由信息:url、type、response即請求路徑、請求方式、響應(yīng)處理函數(shù) controllers.forEach((file) => { //獲取到具體到控制器 let controller = require("./controller/" + file) //遍歷控制器攜帶的信息 for (let o in controller) { //獲取請求路徑,未取到則取默認(rèn)路徑 為"/"+文件名(不包括后綴) let url = controller[o].url ? controller[o].url : ("/" + o) //獲取請求方式,未取到則取默認(rèn)方式 為"get" let type = controller[o].type ? controller[o].type : "get" //響應(yīng)處理函數(shù),未取到則使用默認(rèn)的處理 let response = controller[o].response ? controller[o].response : (req, res) => { res.json({ success: false, info: "沒有處理響應(yīng)的無效路由" }) } //設(shè)置路由信息 router[type](url, response) } }) //使用動態(tài)設(shè)置好的路由 router.use(router) //輸出路由 module.exports = router
創(chuàng)建controller
router.js文件中寫了獲取同級目錄controller下的所有文件
所以我們只需要在server文件夾下的controller中創(chuàng)建一個user的控制器
即創(chuàng)建user.js文件,內(nèi)容如下:
const userName = [{ name: "測試用戶名0" }, { name: "測試用戶名1" } ] //"輸出待添加的路由信息對象 //每個對象中可設(shè)置三個屬性:url、type、response(不設(shè)置的話均做了默認(rèn)處理) module.exports = { users: { response: (req, res) => { res.json(userName) } }, reg: { type: "post", response: (req, res) => { res.json("reg") } } }
運行express
前面文件創(chuàng)建完成之后,要運行express首先安裝依賴包
cnpm i cookie-parser morgan serve-favicon morgan config-lite –save-dev
另外修改文件時需要頻繁的重啟服務(wù)器,全局安裝nodemon可以實現(xiàn)自動重啟
cnpm install -g nodemon
然后配置package.json中的scripts添加start命令
"scripts": { "dev": "node build/dev-server.js", "build": "node build/build.js", "start": "nodemon server.js" }
執(zhí)行npm run build打包項目用于生產(chǎn)環(huán)境
最后命令行里輸入node start就可以運行了,命令行輸出Server running in port 3000表示express成功啟動了,瀏覽器訪問http://localhost:3000/api/users看到輸出的測試數(shù)據(jù)就是成功配置好express了
配置mongoose安裝mongodb并啟動(過程省略)
安裝mongoose
cnpm install mongoose --save-dev
連接mongodb
編寫入口:在server文件下新建一個文件夾名為db,并在其下新建一個文件db.js,內(nèi)容如下:
//引入node的文件路徑模塊path和文件處理模塊fs const path = require("path") const fs = require("fs") const mongoose = require("mongoose") // mongodb 連接? mongoose.connect("mongodb://localhost/tifi-music") // 此處防止 node.js - Mongoose: mpromise 錯誤 mongoose.Promise = global.Promise; let db = mongoose.connection; db.on("error", console.error.bind(console, "Connect error")) db.once("open", function() { console.log("Mongodb started successfully") }) //聲明待添加的model對象 let model = {} //讀取方式和router一樣 const schemas = fs.readdirSync(path.resolve(__dirname, "./model")) schemas.forEach((file) => { //設(shè)置數(shù)據(jù)庫表名為讀取到的文件名(去除后綴名) let name = file.substring(0,file.lastIndexOf(".")) //獲取到的對象就是數(shù)據(jù)庫字段 let schema = require("./model/" + file) //使用mongoose.Schema和mongoose.model完成對數(shù)據(jù)庫表和字段的創(chuàng)建 model[name] = mongoose.model(name, mongoose.Schema(schema)) }) //輸出model對象 module.exports = model
編寫model:也在db文件夾下新建一個文件夾名為model,并在其下新建user.js,內(nèi)容如下:
module.exports = { //設(shè)計數(shù)據(jù)庫字段,先簡單的設(shè)置一些常用的字段 name: String, phone: String, email: String, password: String, createTime: Date }
修改controller:修改controller文件下單user.js為:
//"引入mongoose的model const model = require("../db/db") //加密用戶的密碼 const sha1 = require("sha1") //mogodb會自動的為我們添加_id字段,類型為objectid,我們要把它轉(zhuǎn)換成創(chuàng)建該用戶的時間 const objectIdToTimestamp = require("objectid-to-timestamp") module.exports = { //獲取所有用戶 users: { response: (req, res) => { model.User.find({}, (err, doc) => { if (err) console.log(err) res.send(doc) }) } }, //用戶注冊 reg: { type: "post", response: (req, res) => { console.log(req.body); let userRegister = new model.User({ email: req.body.email, password: sha1(req.body.password), }) // 將 objectid轉(zhuǎn)換為用戶創(chuàng)建時間,使用是的UTC國際標(biāo)準(zhǔn)時間 userRegister.createTime = objectIdToTimestamp(userRegister._id) //查詢郵箱是否已存在于數(shù)據(jù)庫 model.User.findOne({ email: (userRegister.email) .toLowerCase() }, (err, doc) => { if (err) console.log(err) if (doc) { res.json({ success: false, info: "該郵箱已被注冊" }) } else { userRegister.save(err => { if (err) console.log(err) console.log(new Date(), "register success") res.json({ success: true, data: { email: userRegister.email } }) }) } }) } } }
運行mongoose與測試查詢與插入
確定連接mongod成功,如果之前配置好nodemon的話,控制臺會有Mongodb started successfully
測試插入數(shù)據(jù),打開postman進行post請求,成功之后如下圖:
![圖片描述][3] - 測試查詢數(shù)據(jù),打開[postman][2]進行g(shù)et請求,成功之后如下圖: ![圖片描述][5] - 如果前面都成功了,說明已經(jīng)成功的連接了mongoose,說明全部的基礎(chǔ)建設(shè)已經(jīng)搞好了,可以進行下一步的開發(fā)了!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/82401.html
摘要:使用內(nèi)在模塊發(fā)送響應(yīng)數(shù)據(jù)監(jiān)聽端口終端打印如下信息使用框架本項目使用的框架來起服務(wù)器。數(shù)據(jù)庫中文檔每一行的數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)和基本一樣,所有存儲在集合中的數(shù)據(jù)都是格式,是一種類的一種二進制形式的存儲格式,簡稱。 前言 經(jīng)過上一篇經(jīng)濟基礎(chǔ)構(gòu)建的完成,那么現(xiàn)在正式開始碼代碼吧! 項目架構(gòu) showImg(https://segmentfault.com/img/bVNkQM?w=322&h=58...
摘要:使用內(nèi)在模塊發(fā)送響應(yīng)數(shù)據(jù)監(jiān)聽端口終端打印如下信息使用框架本項目使用的框架來起服務(wù)器。數(shù)據(jù)庫中文檔每一行的數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)和基本一樣,所有存儲在集合中的數(shù)據(jù)都是格式,是一種類的一種二進制形式的存儲格式,簡稱。 前言 經(jīng)過上一篇經(jīng)濟基礎(chǔ)構(gòu)建的完成,那么現(xiàn)在正式開始碼代碼吧! 項目架構(gòu) showImg(https://segmentfault.com/img/bVNkQM?w=322&h=58...
摘要:在實際開發(fā)過程中發(fā)現(xiàn),考試系統(tǒng)各個表集合都是需要關(guān)聯(lián),這種非關(guān)系型數(shù)據(jù)庫,做起來反而麻煩了不少。數(shù)據(jù)中既有試卷的信息,也有很多題目。題目都屬于該試卷,改試卷又屬于當(dāng)前登錄系統(tǒng)的老師即創(chuàng)建試卷的老師。 這是我畢業(yè)項目,從0到1,前后臺獨立開發(fā)完成。功能不多,在此記錄,溫故而知新!項目github地址:https://github.com/FinGet/Exam ,博客地址:https:/...
摘要:本文源碼簡介之前剛?cè)腴T并做好了一個簡而全的純?nèi)彝暗捻椖?,?shù)據(jù)都是本地模擬請求的詳情請移步這里為了真正做到數(shù)據(jù)庫的真實存取,于是又開始入門了并以此來為之前的頁面寫后臺數(shù)據(jù)接口。 本文源碼:Github 簡介: 之前剛?cè)腴Tvue并做好了一個簡而全的純vue2全家桶的項目,數(shù)據(jù)都是本地 json 模擬請求的;詳情請移步這里:vue-proj-demo 為了真正做到數(shù)據(jù)庫的真實存取,于是又...
閱讀 3469·2019-08-30 13:15
閱讀 1405·2019-08-29 18:34
閱讀 833·2019-08-29 15:18
閱讀 3490·2019-08-29 11:21
閱讀 3253·2019-08-29 10:55
閱讀 3707·2019-08-26 10:36
閱讀 1876·2019-08-23 18:37
閱讀 1832·2019-08-23 16:57