摘要:搭建后臺的全過程近期基于搭建前端項目,搭建后臺,遇到了不少問題,總結博客如下,有什么不正確的地方,請大家批評指正是非關系型數據庫。是用來啟動的,是的命令行客戶端。
Node + mongoDB 搭建后臺的全過程
近期基于 vue-cil 搭建前端項目, express + mongoose 搭建后臺,遇到了不少問題,總結博客如下,有什么不正確的地方,請大家批評指正^?_?^!
mongodb 是 NoSQL 非關系型數據庫。 mongoose是 mongodb 的一個對象模型工具,是基于 node-mongodb-native 開發(fā)的 mongodb 的 nodejs 驅動,可以在異步的環(huán)境下執(zhí)行。同時它也是針對 mongodb 操作的一個對象模型庫,封裝了 mongodb 對文檔的一些增刪改查等常用方法,讓nodejs操作 mongodb 數據庫變得更加容易。一、Mac下mongodb的安裝與配置
1、 安裝mongodb:
brew install mongodb
2、安裝成功之后,啟動 mongodb
mongod
3、執(zhí)行 mongod ,啟動 mongodb 失敗,顯示如下:
原因 : 啟動 mongodb 之前,要先新建一個mongodb默認的數據寫入目錄:
sudo mkdir -p /data/db
給剛才新建的數據庫目錄賦予權限
sudo chown -R 用戶名 /data
如下圖所示:
4、再次啟動
mongod
5、若啟動成功,可以通過http訪問該數據庫,mongodb使用了27017端口,因此在瀏覽器中打開 http://localhost:27017
出現如下圖所示提示,即說明連接成功。默認的情況下,關閉shell,mongodb就停止運行了 如果想在后臺運行,啟動時只需添加 --fork函數即可
小結:
mongod 是用來連接到mongodb數據庫服務器的,即服務器端。 mongo 是用來啟動MongoDB shell的,是mongodb的命令行客戶端。二、安裝 MongoDB可視化工具 RoboMongo
下載地址:https://robomongo.org/download
三、連接數據庫dbase.js
let mongoose = require("mongoose"); /** * 連接 */ mongoose.connect("mongodb://127.0.0.1:27017/learning",{useNewUrlParser: true}); /** * 連接成功 */ mongoose.connection.on("connected", function () { console.log("Mongoose connection succuss" ); }); /** * 連接異常 */ mongoose.connection.on("error",function (err) { console.log("Mongoose connection error: " + err); }); /** * 連接斷開 */ mongoose.connection.on("disconnected", function () { console.log("Mongoose connection disconnected"); }); module.exports = mongoose;四、啟動 node 服務
server.js
const fs = require("fs") const path = require("path") const express = require("express") const session = require("express-session") const bodyParser = require("body-parser") const app = express() require("./dbase") app.use(bodyParser.json()) //解析json類型的請求體 app.get("*", function (req, res) { res.sendFile(path.join(__dirname, "../Learning/index.html")); }) app.listen(process.env.PORT || 8000, function () { console.log("Listen port:8000...") });
小結:
問題: 啟動node服務連接數據庫時,報錯如下圖所示:
解決辦法:在 mongoose 5.x 版本中,連接數據庫時,不再使用 {useMongoClient: true}),而是 { useNewUrlParser: true }
五、 vue-cil 搭建的項目跨域問題Vue-cli 創(chuàng)建的項目,可以直接利用 Node.js 代理服務器,通過修改proxyTable接口實現跨域請求。在vue-cli項目中的config文件夾下的index.js配置文件中,修改 dev 里面的proxyTable: {}項,如下所示:
proxyTable: { "/api": { //代理地址 target: "http://127.0.0.1:8000/", //需要代理的地址 changeOrigin: true, //是否跨域 secure: false, pathRewrite: { "^/api": "/" //本身的接口地址沒有 "/api" 這種通用前綴,所以要rewrite,如果本身有則去掉 } } }
重啟項目npm run dev ,接口前加上“/api”即可實現跨域請求
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.hztianpu.com/yun/19346.html
摘要:利用中間件實現異步請求,實現兩個用戶角色實時通信。目前還未深入了解的一些概念。往后會寫更多的前后臺聯通的項目。刪除分組會連同組內的所有圖片一起刪除。算是對自己上次用寫后臺的一個強化,項目文章在這里。后來一直沒動,前些日子才把后續(xù)的完善。 歡迎訪問我的個人網站:http://www.neroht.com/? 剛學vue和react時,利用業(yè)余時間寫的關于這兩個框架的訓練,都相對簡單,有的...
摘要:文件這個是項目的入口文件,這邊有著項目的一下配置,也在此整合了項目的模塊,其中要注意的就是里面關于路由模塊的配置了。后面要再想加其他路由模塊的時候,就按照上面先引入路由模塊,再用設置好地址,后面就可以用了。 前言 想必很多小伙伴開始學 node 的時候想搞個項目出來卻不知道怎么下手吧,這個教程的話就是教大家用 express 框架簡單粗暴搭建一個可以用的后臺出來,然后關于 node 和...
閱讀 1221·2021-09-22 15:26
閱讀 2817·2021-09-09 11:52
閱讀 2151·2021-09-02 09:52
閱讀 2389·2021-08-12 13:28
閱讀 1332·2019-08-30 15:53
閱讀 658·2019-08-29 13:47
閱讀 3550·2019-08-29 11:00
閱讀 3241·2019-08-29 10:58