以下為通過node.js連線本機mysql資料庫的方法:

var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'xxxx',//此處的xxxx替換為你的mysql登入使用者名稱
password : 'xxxx',//此處的xxxx替換為你的mysql登入密碼
database : 'xxxx',//此處的xxxx替換為你要連線database名稱
socketPath : '/Applications/XAMPP/xamppfiles/var/mysql/mysql.sock',
port:3306
}); connection.connect(function(err) {
if (err) {
console.error('error connecting: ' + err.stack);
return;
} console.log('connected as id ' + connection.threadId);
}); 這裡的重點是要配置socketPath,否則會報以下這個錯: error connecting: Error: connect ECONNREFUSED

不好意思  上面的是我从网上找的,照着写改来改去没起作用~~  依然连不上

最后解决办法是,

在服务器搞MYSQL服务,搭建数据库,或者是内网其他电脑起一个MYSQL服务,这边调用

MAC本地代码  不需要添加socketPath,即可完美调用本地nodejs接口

简单版代码如下

var express = require('express');
var app = express();
const routes = require('./routers'); const index=require('./routers/index');
app.get('/', (req, res) => res.send('App is working')); // app.use('/', routes);
// app.use('/api/idToken', routes); app.use('/api/index',index);
app.get('/aa', (req, res) => {
res.send('hello')
// res.sendFile(__dirname + '/dist/index.html')
})
app.listen(5000, () => {
console.log("server up");
}); module.exports = {
app
};

完整版可参考代码如下

app.js

const express=require('express');
// const bodyParser=require('body-parser');
const session = require('express-session')
var MySQLStore = require('express-mysql-session')(session); //创建web服务器
var server=express();
var options = {
host: '22.22.12.122',
port: 3306,
user: 'root',
password: 'root',
database: 'cake'
};
var sessionStore = new MySQLStore(options); //引入路由模块
const cors=require('cors');
// const index=require("./routes/index");
const userRouter=require('./routers/user.js');
const cartRouter=require('./routers/cart.js');
const details=require('./routers/detail.js');
const product=require('./routers/product');
const index=require('./routers/index');
const pics=require('./routers/pics');
const login=require('./routers/login');//本接口仅供测试使用
const find=require('./routers/find');
const kind=require('./routers/kind');
const captcha=require('./routers/captcha');
const portal=require('./routers/portal'); //托管静态资源到public下;
server.use(express.static('public'));
server.use(express.static('dist'));
//跨域请求cors
server.use(cors
(
{
origin:"*" ,
// origin:"http://localhost:8080" ,
// origin:"http://localhost:4200" ,
// origin:"http://127.0.0.1:5500" ,
credentials: true
}
)
);
// server.writeHead(200,{"Access-Control-Allow-Credentials":true});
server.use(express.json())
server.use(express.urlencoded({
extended:false
})); //session 启用会话中间件,用来保存用户登录状态以及验证码
server.use(session({
name: 'sessionId',
resave: true,
saveUninitialized: true,
secret: 'APP_SESSION_SECRET',
store: sessionStore // 将会话存到数据库
})) server.use('/api/user',userRouter);
server.use('/api/cart',cartRouter); server.use('/api/product',product);
server.use('/api/details',details);
server.use('/api/index',index);
server.use('/api/pics',pics);
// server.use('/api/login',login);本接口仅供测试使用
server.use('/api/find',find);
server.use('/api/kind',kind);
server.use('/api/captcha',captcha);
server.use('/api/portal',portal); // server.get('*', (req, res) => {
// res.sendFile(__dirname + '/dist/index.html')
// })
// server.get('/aa', (req, res) => {
// res.send('hello')
// // res.sendFile(__dirname + '/dist/index.html')
// })
// 异常处理器
server.use((req,res,next,err)=>{
console.log(err.message)
res.sendStatus(500);
}) server.listen(3006, () => {
console.log("server up");
});

pool.js

const mysql=require('mysql');
//创建连接池对象
// var pool=mysql.createPool({
// host:'localhost',
// port:'3306',
// user:'root',
// password:'',
// database:'cake',
// connectionLimit:20
// });
var pool=mysql.createPool({
host: '22.222.12.122',
port: 3306,
user: 'root',
password: 'root',
database:'cake',
connectionLimit:20
});
//到处连接池对象
module.exports=pool;

路由文件举例如下:

./routers/index
const express = require("express");
const router = express.Router();
const pool = require("../pool"); //一次查询返回4条数据
router.get("/", (req, res) => {
var status = req.query.status;
var output = {
product: {}
}
if (status !== undefined) {
var sql1 = `select * from cake_index_product where index_status=?`;
pool.query(sql1, [status], (err, result) => {
if (err) console.log(err);
output.product = result;
// console.log(output);
// console.log("haha1");
res.send(output);
}) }else{
res.send(output);
console.log(444)
}
}) //一次查询返回多条数据
router.get("/insale", (req, res) => {
var status = req.query.insale;
var output = {
product: {}
}
if (status !== undefined) {
var sql1 = `select * from cake_index_product where index_sale_new=?`;
pool.query(sql1, [status], (err, result) => {
if (err) console.log(err);
output.product = result;
res.send(output);
}) }else{
res.send(output);
// console.log(444)
}
})
//首页产品一次性展示+轮播图查询
router.get("/all", (req, res) => {
var output = {
carouselItems:{},
product: {},
pics:{},
kinds:{}
}
var sql1 = `select * from index_img `;
pool.query(sql1,(err, result) => {
if (err) console.log(err);
output.carouselItems = result;
var sql2 = `select * from cake_index_product `;
pool.query(sql2,(err, result) => {
if (err) console.log(err);
output.product = result; var sql3 = `select * from product_pic `;
pool.query(sql3,(err, result) => {
if (err) console.log(err);
output.pics = result; var sql4 = `select * from product_kinds `;
pool.query(sql4,(err, result) => {
if (err) console.log(err);
output.kinds = result;
res.send(output);
})
})})
})
})
// 測試接口aa
router.post("/scan/collect", (req, res) => {
console.log('wolaila11')
let emp_no = req.body.emp_no;
let emp_name = req.body.emp_name;
let card_time = req.body.card_time;
let qrcode = req.body.qrcode;
var output = {
error:0,
message:'success'
}
var err = {
error:1,
message:'參數有誤或者缺失參數'
} if(emp_no&&emp_name&&card_time&&qrcode){
res.send(output);
}else{
res.send(err);
} })
// 測試接口
//一次查询返回多条数据post
router.post("/postStatus", (req, res) => {
console.log('wolaila')
var status = req.body.status;
var output = {
product: {},
lalala:'woshiceshi'
}
if (status !== undefined) {
var sql1 = `select * from cake_index_product where index_sale_new=?`;
pool.query(sql1, [status], (err, result) => {
if (err) console.log(err);
output.product = result;
res.send(output);
}) }else{
res.send(output);
// console.log(444)
}
}) //首页产品轮播图查询
router.get("/img", (req, res) => {
console.log('/img')
var output = {
carouselItems:{}
}
var sql1 = `select * from index_img `;
pool.query(sql1,(err, result) => {
console.log('進入SQL')
if (err) console.log(err);
output.carouselItems = result;
res.send(output);
})
})
module.exports = router;

在Mac OS上将Node.js连接到XAMPP MySQL服务器一直报错error connecting: Error: connect ECONNREFUSED的更多相关文章

  1. mac OS 安装 Node.js

    打开Node.js官网https://nodejs.org/zh-cn/选择你需要的版本 下载安装 安装完成 输入命令 node -v 查看版本号 输入命令 npm -v 查看版本号

  2. mac OS 卸载node.js及npm

    通过homebrew安装的 输入卸载命令 brew uninstall node 通过官网下载pkg安装包的 输入卸载命令 sudo rm -rf /usr/local/{bin/{node,npm} ...

  3. 【Azure 应用服务】App Service 无法连接到Azure MySQL服务,报错:com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure

    问题描述 App Service使用jdbc连接MySQL服务,出现大量的  Communications link failure: com.mysql.cj.jdbc.exceptions.Com ...

  4. 1.从Node.js链接到MongoDB

    MongoDB采用了MongoDB Node.js驱动程序作为标准. 1.安装MongoDB驱动 npm install mongoDB npm install mongoose require('m ...

  5. mac下配置Node.js开发环境、express安装、创建项目

    mac下配置Node.js开发环境.express安装.创建项目 一.node.js的安装 去官网下载对应的平台版本就可以了,https://nodejs.org 二.express安装 sudo n ...

  6. paip.最好的脚本语言node js 环境搭建连接mysql

    paip.最好的脚本语言node js 环境搭建连接mysql #====下载node...走十一个exe..容易的.. 1 #0----Hello world   .js 2 #---------模 ...

  7. Fenix – 基于 Node.js 的桌面静态 Web 服务器

    Fenix 是一个提供给开发人员使用的简单的桌面静态 Web 服务器,基于 Node.js 开发.您可以同时在上面运行任意数量的项目,特别适合前端开发人员使用. 您可以通过免费的 Node.js 控制 ...

  8. node.js中net模块创建服务器和客户端(TCP)

    node.js中net模块创建服务器和客户端 1.node.js中net模块创建服务器(net.createServer) // 将net模块 引入进来 var net = require(" ...

  9. 用Node.js原生代码实现静态服务器

    ---恢复内容开始--- 后端中服务器类型有两种 1. web服务器[ 静态服务器 ] - 举例: wamp里面www目录 - 目的是为了展示页面内容 - 前端: nginx 2. 应用级服务器[ a ...

  10. Mac中安装node.js和npm

    换了Mac需要安装noed.js和npm记录一下首先访问node.js官网(https://nodejs.org/en/download/) 点击下载完后,一路点安装 就安装完成了 然后打开-终端-输 ...

随机推荐

  1. 一步一图带你深入理解 Linux 虚拟内存管理

    写在本文开始之前.... 从本文开始我们就正式开启了 Linux 内核内存管理子系统源码解析系列,笔者还是会秉承之前系列文章的风格,采用一步一图的方式先是详细介绍相关原理,在保证大家清晰理解原理的基础 ...

  2. 一篇文章带你了解轻量级Web服务器——Nginx简单入门

    一篇文章带你了解轻量级Web服务器--Nginx简单入门 Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件代理服务器 在本篇中我们会简单介绍Nginx的特点,安装,相关指令使用以及配置信 ...

  3. java判断手机号三大运营商归属的工具类

    package com.tymk.front.third; import java.util.regex.Pattern; public class OperatorsUtil { /** * 中国电 ...

  4. YC-Framework版本更新:V1.0.10

    分布式微服务框架:YC-Framework版本更新V1.0.10!!! 本文主要内容: 1.V1.0.10版本更新主要内容2.YC-Framework相关系列文章分享 一.V1.0.10版本更新主要内 ...

  5. 基于python的数学建模---图论模型(Dijkstra)

    from collections import defaultdict from heapq import * # 堆--先进后出 inf = 99999 # 不连通值 mtx_graph = [[0 ...

  6. Spring Security(3)

    您好,我是湘王,这是我的博客园,欢迎您来,欢迎您再来- 前面运行写好的代码之所以没有任何显示,是因为还没有对Spring Security进行配置,当然啥也不显示了.这就好比你坐在车上,却不打开发动机 ...

  7. C温故补缺(六):C反汇编常用的AT&Tx86语法

    C语言反汇编用到的AT&T x86汇编语法 参考:CSDN1,CSDN2 默认gcc -S汇编出的,以及反汇编出的,都是AT&T x86代码,可以用-masm=intel指定为inte ...

  8. lightdm开机无法自启问题

    简述 由于我学习了 systemctl disable 服务 这条命令,然后开始皮,把 lightdm 自启动关了,然后开不开了 解决办法:重置 lightdm 服务配置 sudo dpkg-reco ...

  9. Pandas_1_预备知识

    Chapter1_Python基础 1.1 Python基础 推导式: 两个对象之间的映射关系,类似于实数之间关系变换的函数,只不过对象变成了矩阵. # Ex1-1 vacabulary = ['co ...

  10. Type Script 在流程设计器的落地实践

    流程设计器项目介绍 从事过BPM行业的大佬必然对流程建模工具非常熟悉,做为WFMC三大体系结构模型中的核心模块,它是工作流的能力模型,其他模块都围绕工作流定义来构建. 成熟的建模工具通过可视化的操作界 ...