在Mac OS上将Node.js连接到XAMPP MySQL服务器一直报错error connecting: Error: connect ECONNREFUSED
以下為通過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的更多相关文章
- mac OS 安装 Node.js
打开Node.js官网https://nodejs.org/zh-cn/选择你需要的版本 下载安装 安装完成 输入命令 node -v 查看版本号 输入命令 npm -v 查看版本号
- mac OS 卸载node.js及npm
通过homebrew安装的 输入卸载命令 brew uninstall node 通过官网下载pkg安装包的 输入卸载命令 sudo rm -rf /usr/local/{bin/{node,npm} ...
- 【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 ...
- 1.从Node.js链接到MongoDB
MongoDB采用了MongoDB Node.js驱动程序作为标准. 1.安装MongoDB驱动 npm install mongoDB npm install mongoose require('m ...
- mac下配置Node.js开发环境、express安装、创建项目
mac下配置Node.js开发环境.express安装.创建项目 一.node.js的安装 去官网下载对应的平台版本就可以了,https://nodejs.org 二.express安装 sudo n ...
- paip.最好的脚本语言node js 环境搭建连接mysql
paip.最好的脚本语言node js 环境搭建连接mysql #====下载node...走十一个exe..容易的.. 1 #0----Hello world .js 2 #---------模 ...
- Fenix – 基于 Node.js 的桌面静态 Web 服务器
Fenix 是一个提供给开发人员使用的简单的桌面静态 Web 服务器,基于 Node.js 开发.您可以同时在上面运行任意数量的项目,特别适合前端开发人员使用. 您可以通过免费的 Node.js 控制 ...
- node.js中net模块创建服务器和客户端(TCP)
node.js中net模块创建服务器和客户端 1.node.js中net模块创建服务器(net.createServer) // 将net模块 引入进来 var net = require(" ...
- 用Node.js原生代码实现静态服务器
---恢复内容开始--- 后端中服务器类型有两种 1. web服务器[ 静态服务器 ] - 举例: wamp里面www目录 - 目的是为了展示页面内容 - 前端: nginx 2. 应用级服务器[ a ...
- Mac中安装node.js和npm
换了Mac需要安装noed.js和npm记录一下首先访问node.js官网(https://nodejs.org/en/download/) 点击下载完后,一路点安装 就安装完成了 然后打开-终端-输 ...
随机推荐
- 一步一图带你深入理解 Linux 虚拟内存管理
写在本文开始之前.... 从本文开始我们就正式开启了 Linux 内核内存管理子系统源码解析系列,笔者还是会秉承之前系列文章的风格,采用一步一图的方式先是详细介绍相关原理,在保证大家清晰理解原理的基础 ...
- 一篇文章带你了解轻量级Web服务器——Nginx简单入门
一篇文章带你了解轻量级Web服务器--Nginx简单入门 Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件代理服务器 在本篇中我们会简单介绍Nginx的特点,安装,相关指令使用以及配置信 ...
- java判断手机号三大运营商归属的工具类
package com.tymk.front.third; import java.util.regex.Pattern; public class OperatorsUtil { /** * 中国电 ...
- YC-Framework版本更新:V1.0.10
分布式微服务框架:YC-Framework版本更新V1.0.10!!! 本文主要内容: 1.V1.0.10版本更新主要内容2.YC-Framework相关系列文章分享 一.V1.0.10版本更新主要内 ...
- 基于python的数学建模---图论模型(Dijkstra)
from collections import defaultdict from heapq import * # 堆--先进后出 inf = 99999 # 不连通值 mtx_graph = [[0 ...
- Spring Security(3)
您好,我是湘王,这是我的博客园,欢迎您来,欢迎您再来- 前面运行写好的代码之所以没有任何显示,是因为还没有对Spring Security进行配置,当然啥也不显示了.这就好比你坐在车上,却不打开发动机 ...
- C温故补缺(六):C反汇编常用的AT&Tx86语法
C语言反汇编用到的AT&T x86汇编语法 参考:CSDN1,CSDN2 默认gcc -S汇编出的,以及反汇编出的,都是AT&T x86代码,可以用-masm=intel指定为inte ...
- lightdm开机无法自启问题
简述 由于我学习了 systemctl disable 服务 这条命令,然后开始皮,把 lightdm 自启动关了,然后开不开了 解决办法:重置 lightdm 服务配置 sudo dpkg-reco ...
- Pandas_1_预备知识
Chapter1_Python基础 1.1 Python基础 推导式: 两个对象之间的映射关系,类似于实数之间关系变换的函数,只不过对象变成了矩阵. # Ex1-1 vacabulary = ['co ...
- Type Script 在流程设计器的落地实践
流程设计器项目介绍 从事过BPM行业的大佬必然对流程建模工具非常熟悉,做为WFMC三大体系结构模型中的核心模块,它是工作流的能力模型,其他模块都围绕工作流定义来构建. 成熟的建模工具通过可视化的操作界 ...