本文实例讲述了node链接mongodb数据库的方法。分享给大家供大家参考,具体如下:
一、安装2.6版本以上的mongodb在云服务器上(百度就能查到安装方法,以及验证是否安装成功一般是mongodb –version);
二、因为mongodb的默认开启端口是27017,所以要在Ubuntu上开启这个端口:
ufw allow 27017
ufw enable
ufw reload
ufw status //这是查看这个端口是否开启,iptables --list也可以查看
光在服务器开了端口还不行,还要在阿里云服务器控制台的安全组中添加这个端口:
三、在node项目中利用npm安装mongodb:
npm i mongodb --save
四、链接的具体代码(前提是已经建立了简单的http或者https服务),具体代码:
const http = require('http') , https = require('https'); const express = require('express'); const bodyParser = require('body-parser') const app = express(); const fs = require('fs'); const ejs = require('ejs'); const path = require('path'); const MongoClient = require('mongodb').MongoClient; // 返回信息 const questions = { code: 200, msg: 'success', }; // https证书,开https服务的自验证证书 const options = { key: fs.readFileSync('./privatekey.pem'), cert: fs.readFileSync('./certificate.pem') }; let xltitle = "标题(初始化数据)", xlcontent = '内容(初始化数据)', xlfaceid = '1(初始化数据)'; const url = 'mongodb://127.0.0.1/xlbase'; // 默认端口27017,无需填写 // 也可以修改端口,vim /etc/mongodb.conf // 初始化数据库 MongoClient.connect(url, function (err, db) { if (err) throw err; let database = db.db('xlbase'); console.log('------------数据库初始化成功------------'); // 如果没有face这个集合,会创建一个,所以可以用这个来初始化集合 database.createCollection('face', function (err, res) { if (err) throw err; console.log('------------集合初始化完毕------------'); db.close(); }); }); //设置跨域访问 app.all('*', function (req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header("Access-Control-Allow-Headers", "X-Requested-With"); res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS"); res.header("X-Powered-By", ' 3.2.1'); // res.header("Content-Type", "application/json;charset=utf-8"); next(); }); // parse application/x-www-form-urlencoded 解析 app.use(bodyParser.urlencoded({extended: false})); // parse application/json 解析 app.use(bodyParser.json()); // view engine setup,视图模版 app.set('views', path.join(__dirname, './')); app.set('view engine', 'jade'); // 静态资源解析路径(css,js,图片等) app.use(express.static(path.join(__dirname, './static'))); // 数据接收接口 app.post('/info', function (req, res) { res.header("Content-Type", "application/json;charset=utf-8"); res.status(200); xltitle = req.body.title; xlcontent = req.body.content; xlfaceid = req.body.faceId; let info = { 'faceid': xlfaceid, 'title': xltitle, 'content': xlcontent }; let faceid = { 'faceid': xlfaceid }; let updateInfo = {$set: info};// 组装更新的信息 MongoClient.connect(url, function (err, db) { let database = db.db('xlbase'); database.collection('face').find(faceid).toArray(function (err, result) { if (err) throw err; // 判断集合中faceid和当前传过来的faceid是否相同和存在 // 如果不存在就新插入这条数据 // 如果存在且相同,就更新数据 if (result.length !== 0 && result[0].faceid === xlfaceid) { database.collection("face").updateOne(faceid, updateInfo, function (err, res) { if (err) throw err; console.log("------------数据更新成功------------"); db.close(); }); } else { database.collection('face').insertOne(info, function (err, res) { if (err) throw err; console.log("------------数据添加成功------------"); db.close(); }) } }) }); res.json(questions); // 返回信息 res.end(JSON.stringify(req.body, null, 2)) }); app.get('/index', function (req, res) { res.status(200); res.header("Content-Type", "text/html;charset=utf-8"); // 根据faceId查询数据 MongoClient.connect(url, function (err, db) { if (err) throw err; let dbo = db.db("xlbase"); let face = {"faceid": xlfaceid}; // 查询条件 let xltitle1 = 404; let xlcontent1 = '网页出错!'; dbo.collection("face").find(face).toArray(function (err, result) { if (err) throw err; console.log(result); xltitle1 = result[0].title; xlcontent1 = result[0].content; db.close(); console.log('------------查询完毕------------'); res.send('<h3 style="font-size: 35px">' + xltitle1 + '</h3>' + '<pre style="white-space: pre-wrap;word-wrap: break-word;font-size: 30px">' + xlcontent1 + '</pre>'); res.end(); }); }); }) // 配置服务端口 // http.createServer(app).listen(3001, function () { // console.log('3001') // }); process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0"; // 绕过证书验证 https.createServer(options, app).listen(8009, function () { console.log('port: 8009'); }); // var server = app.listen(3001, function () { // // var host = server.address().address; // // var port = server.address().port; // // console.log('Example app listening at http://%s:%s', host, port); // })
希望本文所述对大家nodejs程序设计有所帮助。
本文向大家介绍详解如何在阿里云服务器安装Mysql数据库,包括了详解如何在阿里云服务器安装Mysql数据库的使用技巧和注意事项,需要的朋友参考一下 前言 由于在学习过程中需要安装zookeeper,我的虚拟机一直有问题,就够买了阿里云服务器。安装完zookeeper后想着把数据库也安装在服务器上,释放一下电脑的压力,在安装数据库的时候遇到了很多问题,通过查看有些大佬的作品终于安装好了数据库。现在就
本文向大家介绍阿里云ECS服务器部署django的方法,包括了阿里云ECS服务器部署django的方法的使用技巧和注意事项,需要的朋友参考一下 参考 服务器安装的是Centos 系统。 uwsgi是使用pip安装的。 nginx是使用yum install nginx安装。 python 2.7, mysql 5.5使用 yum安装。 它们之间的逻辑关系如下: the web client <->
本文向大家介绍Workbench连接不上阿里云服务器Ubuntu的Mysql解决方法(已测),包括了Workbench连接不上阿里云服务器Ubuntu的Mysql解决方法(已测)的使用技巧和注意事项,需要的朋友参考一下 这两天为了解决workbench连接不上阿里云服务器的问题,搞得头大,网上搜到的教程都大同小异,但唯独到我这就是行不通。不过好在最后终于解决了,记录一下这个坑爹的过程。 使用的环境
本文向大家介绍详解阿里云nginx服务器多站点的配置,包括了详解阿里云nginx服务器多站点的配置的使用技巧和注意事项,需要的朋友参考一下 阿里云nginx服务器多站点的配置 今天配置了一下多站点,记录一下配置的过程... 1、首先要找到nginx 配置文件之所在,阿里云上的nginx.conf 文件上 /alidata/server/nginx-1.4.4/conf 中。 2、然后在conf目录
本文向大家介绍阿里云服务器CentOS 6.3下快速安装部署 LAMP 、vsftpd 环境的方法,包括了阿里云服务器CentOS 6.3下快速安装部署 LAMP 、vsftpd 环境的方法的使用技巧和注意事项,需要的朋友参考一下 阿里云论坛上的资源很丰富,查了下安装LAMP环境,很多基础性的东西已经内置了,比如防火墙的配置和端口的开启,统统不需要再做操作,所以安装下来也很简单: 1、MySQL的
本文向大家介绍详解阿里云CentOS Linux服务器上用postfix搭建邮件服务器,包括了详解阿里云CentOS Linux服务器上用postfix搭建邮件服务器的使用技巧和注意事项,需要的朋友参考一下 注:本文的邮件服务器只用于发送邮件,也就是STMP服务器。 一、准备工作 1. 为邮件服务器添加DNS解析 虽然不加DNS解析也能把邮件发出去,但会被大多数邮件服务器当作垃圾邮件。根据我们的实