const Koa = require('koa'); const app = new Koa(); const axios = require('axios'); const sql = require('mssql'); // const sql = require('../utils/db') // const Wechat = require('co-wechat'); // const api = require('./wechat/api'); // const config = require('./config'); // let creatMenu = async (ctx, next) =>{ // await api.creatMenu(menu); // console.log('res:',res); // } // creatMenu() // app.use(Wechat(config).middleware(async (message,ctx)=>{ // if (message.Content === 'junxin') { // return { // type:"text", // content:'是一个非常棒的公司' // } // }else{ // return '正在发展中~~~' // } // })) // 创建数据库连接配置 const config = { server: 'CRMTEST', user: 'sa', password: 'Servo01', database: 'demo' } // 创建注册信息对象 const { name, email, password } = request.body; // 创建连接池并连接数据库 sql.connect(config, (err) => { if (err) { console.log(err); return; } // 创建 request 对象 const request = new sql.Request(); // 执行插入操作 request.query(`INSERT INTO username (name, email, password) VALUES ('${name}', '${email}', '${password}')`, (err, result) => { if (err) { console.log(err); return; } console.log('用户信息已成功插入数据库'); }); }); app.listen(8280, () => { console.log('8280端口号被监听'); }) 这代码后台显示request未定义
时间: 2023-08-20 15:54:58 浏览: 145
在你的代码中,`request`变量是在创建注册信息对象时被使用,但是在这之前的位置,它还未被定义。你需要将创建连接池和连接数据库的代码块放在创建注册信息对象之后。
以下是修复后的代码示例:
```javascript
const Koa = require('koa');
const app = new Koa();
const axios = require('axios');
const sql = require('mssql');
// 创建数据库连接配置
const config = {
server: 'CRMTEST',
user: 'sa',
password: 'Servo01',
database: 'demo'
}
app.use(async (ctx) => {
// 创建注册信息对象
const { name, email, password } = ctx.request.body;
// 创建连接池并连接数据库
sql.connect(config, (err) => {
if (err) {
console.log(err);
return;
}
// 创建 request 对象
const request = new sql.Request();
// 执行插入操作
request.query(`INSERT INTO username (name, email, password) VALUES ('${name}', '${email}', '${password}')`, (err, result) => {
if (err) {
console.log(err);
return;
}
console.log('用户信息已成功插入数据库');
});
});
});
app.listen(8280, () => {
console.log('8280端口号被监听');
});
```
请注意,我还将代码块包装在了 Koa 的中间件函数中,以便在请求时执行。你可以根据实际需求进行调整。
阅读全文