NodeJs之服务搭建与数据库连接

一,介绍与需求分析

1.1,介绍

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境。 Node.js 使用了一个事件驱动、非阻塞式 I/O 的模型,使其轻量又高效。Node.js 的包管理器 npm,是全球最大的开源库生态系统。

二,node服务搭建

2.1,安装创建项目服务

第一步:安装NODE

第二步:安装express,使用熟悉的命令安装,

 npm install -g express

第三步:最新express版本中将命令工具分家出来了(项目地址:https://github.com/expressjs/generator),所以我们还需要安装一个命令工具,命令如下:

 npm install -g express-generator

第四步:使用express创建一个工程:

 express myervice

第五步:安装包并启动

 cd myervice
npm install //安装包
npm start //启动服务

第六步:访问http://localhost:3000/就看到熟悉的页面了

2.2,配置node服务器

具体的代码如下:

 var express = require('express');//引入express模块
var app = express();//初始化化
var settingConfig = require('./config/settingConfig.js');//引入配置文件
var allow_Orgin = settingConfig.getValueByKey("Access_Control_Allow_Origin");//解析
// Access Control Allow
var cors = require('cors');//引入跨域资源共享
var whitelist = allow_Orgin.split(';'); var hostName = '127.0.0.1';//设置主机名
var port = 8080;//设置端口 var corsOptions = {//配置
credentials: true,
origin: function (origin, callback) {
if (origin==undefined || whitelist.indexOf(origin) !== -1) {
callback(null, true)
} else {
console.log(origin);
callback(new Error('Not allowed by CORS'))
}
}
}
app.use(cors(corsOptions));
app.use('/api', require('./routes/dbWebApi.js')); // catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
var result = {
httpCode: 404,
message: err.message,
}
res.status(404).json(result);
next();
}); // error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500).json({
httpCode: err.status || 500,
message: err.message,
});
}); app.listen(port,hostName,function(){//监听
console.log(`服务器运行在http://${hostName}:${port}`);
});

解析配置文件的代码settingConfig.js如下:

 var xml2js = require('xml2js');//xml解析
var fs = require('fs');//文件处理系统 function getValueByKey(key) {
var path = './config/settingConfig.xml';//xml配置文件
var result = '';
var data;
try {
data = fs.readFileSync(path, 'utf8');
}
catch (err) {
throw err;
}
var xmlDoc = xml2js.parseString(data, { explicitArray: true }, function (err, json) { };
});
return result;
}

配置文件settingConfig.xml如下:

 <?xml version="1.0" encoding="utf-8" ?>
<appSettings>
<add key="Access_Control_Allow_Origin" value="http://localhost:8080;http://localhost:3000"/>
<add key="dbName" value="test"/>
<add key="WhetherNeedAuth" value="true"/>
</appSettings>

如需完整代码,请先留言评论加关注

三,node连接数据库

3.1,连接数据库的配置与解析

目前只支持两种类型的数据库:MySQL sql server

解析配置文件:operateXML.js:

 function params(){//简单配置
this.server="";
this.database="";
this.user="";
this.password="";
this.sp_name = "";
this.sp_output = "";
}
function mysqlparams(){
this.host="";
this.port="";
this.database="";
this.user="";
this.password="";
this.sp_name="";
this.sp_output = "";
}
function getMsSQLParamObj(appName,spName){ //sql server
var xml2js = require('xml2js');
var fs=require('fs');
var path='./config/databaseConfig.xml';
var param=new params();
var data;
try{
data= fs.readFileSync(path, 'utf8');
}
catch(err){
throw err;
}
var xmlDoc = xml2js.parseString(data, { explicitArray: true }, function (err, json) { });
return param;
} function getMySQLParamObj(appName,spName){ //mysql
var xml2js = require('xml2js');
var fs=require('fs');
var path='./config/databaseConfig.xml';
var param=new mysqlparams();
var data;
try{
data= fs.readFileSync(path, 'utf8');
}
catch(err){
throw err;
}
var xmlDoc = xml2js.parseString(data, { explicitArray : true },function(err, json) { //解析 });
return param;
}

XML配置文件:databaseConfig:

 <?xml version="1.0" encoding="UTF-8"?>
<root>
<sqlserver>
<database name="TEST" server="localhost\MSSQL" database="test" user="sa" pwd="908">
<!--登录注册-->
<storedProcedure name="RegisterToUser" value="[Auth].[usp_RegisterToUser]" description="注册"/>
</database>
</sqlserver>
<mysql>
<database name="test" host="localhost" port="3306" database="test" user="root" pwd="root">
<storedProcedure name="getUserPages" value="sp_getUserPages" output="total"/>
<storedProcedure name="getUserCount" value="sp_getUserCount"/>
</database>
</mysql>
</root>

3.2,连接数据库

连接数据库:db_mssql.JS

 var sql = require("mssql");
var xml = require('../config/operateXML.js');//加载解析配置文件 function operateDatabase(appName, spName, json, callback) {
var paraarr = {}
if ((typeof json) == "string")
parr = JSON.parse(json);
else
parr = json;
var config = xml.getMsSQLParamObj(appName, spName);
try {//连接数据库
new sql.ConnectionPool(config).connect().then(function (pool) { } catch (err) { }
}

3.2,get与post请求

定义请求方式:dbWebApi.js

 var express = require('express');
var router = express.Router();
var dbservice = require('../services/db_mssql.js'); router.get('/readData/:appName/:spName/:json', function (req, res) {
dbservice.operateDatabase(appName, spName, json, function (data) { });
}); router.post('/postData', function (req, res) {
dbservice.operateDatabase(appName, spName, json, function (data) { });
});

下一章:NodeJs连接操作MongoDB数据库

NodeJs之服务搭建与数据库连接的更多相关文章

  1. 使用nodejs和express搭建http web服务

    目录 简介 使用nodejs搭建HTTP web服务 请求nodejs服务 第三方lib请求post 获取http请求的正文 Express和使用express搭建http web服务 express ...

  2. 57.NodeJS入门--环境搭建 IntelliJ IDEA

    转自:https://blog.csdn.net/wang19891106/article/details/51127133 NodeJS入门–环境搭建 IntelliJ IDEA 本人也刚开始学习N ...

  3. NodeJS入门--环境搭建 IntelliJ IDEA

    NodeJS入门–环境搭建 IntelliJ IDEA 本人也刚开始学习NodeJS,所以以此做个笔记,欢迎大家提出意见. 1.首先 下载安装NodeJS,下载安装IntelliJ IDEA 2.接下 ...

  4. 借助Nodejs在服务端使用jQuery采集17173游戏排行信息

    Nodejs相关依赖模块介绍 Nodejs的优势这里就不做介绍啦,这年头相信大家对它也不陌生了.这里主要介绍一下用到的第三方模块. async:js代码中到处都是异步回调,很多时候我们需要做同步处理, ...

  5. ServiceStack.Hello——跨平台.net REST api服务搭建

    ServiceStack.Hello--跨平台.net REST api服务搭建 自己创建: https://github.com/ServiceStack/ServiceStack/wiki/Cre ...

  6. WCFRESTFul服务搭建及实现增删改查

    WCFRESTFul服务搭建及实现增删改查 RESTful Wcf是一种基于Http协议的服务架构风格,  RESTful 的服务通常是架构层面上的考虑. 因为它天生就具有很好的跨平台跨语言的集成能力 ...

  7. 微信小程序语音识别服务搭建全过程解析(项目开源在github)

    silk v3录音转olami语音识别和语义处理的api服务(ubuntu16.04服务器上实现) ## 重要的写在前面 重要事项一: 目前本文中提到的API已支持微信小程序录音文件格式:silk v ...

  8. 微信小程序语音识别服务搭建全过程解析(https api开放,支持新接口mp3录音、老接口silk录音)

    silk v3(或新录音接口mp3)录音转olami语音识别和语义处理的api服务(ubuntu16.04服务器上实现) 重要的写在前面 重要事项一: 所有相关更新,我优先更新到我个人博客中,其它地方 ...

  9. Git服务搭建及github使用教程

    .pos { position: fixed; top: 35%; left: 90% } .pos a { border: 2px solid white; background: #99CCFF; ...

随机推荐

  1. Java注解(Annotation):请不要小看我!

    Java注解是一系列元数据,它提供数据用来解释程序代码,但是注解并非是所解释的代码本身的一部分.注解对于代码的运行效果没有直接影响. 网络上对注解的解释过于严肃.刻板,这并不是我喜欢的风格.尽管这样的 ...

  2. ASP.NET Core DevOps

    一.本系列教程说明 源代码管理工具:Gogs 持续集成工具:Jenkins 容器:Docker 本教程选用轻量级的 Git 管理工具 Gogs,搭建简单. 三.教程目录 1.配置免费HTTPS证书 ( ...

  3. matlab常用目录操作

    总结matlab下常用到的目录操作 添加当前文件夹及其子文件夹至搜索路径 % add path rootDir = fileparts(mfilename('fullpath')); addpath( ...

  4. nodejs 开发企业微信第三方应用入门教程

    最近公司要开发企业微信端的 Worktile,以前做的是企业微信内部应用,所以只适用于私有部署客户,而对于公有云客户就无法使用,所有就准备开发企业微信的第三方应用,本文主要介绍在调研阶段遇到的山珍海味 ...

  5. Redis 小白指南(二)- 聊聊五大类型:字符串、散列、列表、集合和有序集合

    Redis 小白指南(二)- 聊聊五大类型:字符串.散列.列表.集合和有序集合 引言 开篇<Redis 小白指南(一)- 简介.安装.GUI 和 C# 驱动介绍>已经介绍了 Redis 的 ...

  6. 【开源分享】微信营销系统(第三方微信平台)github 开源

    升讯威微信营销系统(微信第三方平台) 在线体验:http://wxcm.eeipo.cn/开源地址GitHub:https://github.com/iccb1013/Sheng.WeixinCons ...

  7. Spring Boot Security OAuth2 实现支持JWT令牌的授权服务器

    概要 之前的两篇文章,讲述了Spring Security 结合 OAuth2 .JWT 的使用,这一节要求对 OAuth2.JWT 有了解,若不清楚,先移步到下面两篇提前了解下. Spring Bo ...

  8. Spring Boot 入门(五):集成 AOP 进行日志管理

    本篇文章是接着 Spring boot 入门(四):集成 Shiro 实现登陆认证和权限管理写的,按照前面几篇博客的教程,可以搭建一个简单的项目,主要包含了 Pagehelper+MyBatis 分页 ...

  9. Spring boot 入门(四):集成 Shiro 实现登陆认证和权限管理

    本文是接着上篇博客写的:Spring boot 入门(三):SpringBoot 集成结合 AdminLTE(Freemarker),利用 generate 自动生成代码,利用 DataTable 和 ...

  10. 从0到1搭建AI中台

    文章发布于公号[数智物语] (ID:decision_engine),关注公号不错过每一篇干货. 转自 | 宜信技术学院 作者 | 井玉欣 导读:随着“数据中台”的提出和成功实践,各企业纷纷在“大中台 ...