【问题标题】:TypeError: Assignment to constant variableTypeError:分配给常量变量
【发布时间】:2021-03-10 18:08:21
【问题描述】:

请帮我解决错误。我附上了我的 index.js 代码 routes.js 代码和 db.js 代码以及错误描述。 我一直在努力解决这个错误。

index.js

const express = require('express');
const app = express();
const routes = require('./routes');
const path = require('path');

const fileUpload = require('express-fileupload');
const bodyParser = require('body-parser');

const session = require('express-session');
const auth = require('./routes/auth');
const {
  con,
  sessionStore
} = require('./config/db');
const fs = require('fs');

require('dotenv').config({
  path: path.join(__dirname, '.env')
});
const port = process.env.PORT || 3000;


// parse application/json
app.use(bodyParser.json())
// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({
  extended: false
}));


//static files 
app.use(express.static('public'))
app.use('/css' , express.static(__dirname + 'public/css'))
app.use('/imgs' , express.static(__dirname + 'public/imgs'))

var sess = {
    secret: 'keyboard cat',
    store: sessionStore,
    cookie: {
      httpOnly: false,
    },
    resave: false,
    saveUninitialized: false
  }
  
  app.use(session(sess));
  app.use(fileUpload());
//set views
app.set('view engine' , 'ejs');
app.set('views', path.join(__dirname, 'views'))

//
app.use(require('connect-flash')());
app.use((req, res, next) => {
  res.locals.messages = require('express-messages')(req, res);
  next();
});
app.get('/', (req,res) =>{
    res.render('index22')
})
app.get('/login', (req, res) => {
    res.render('login');
   });

   let s;

const loginRequired = (req, res, next) => {
    if (req.session.username) {
    s = req.session;
    next();
    } else {
    res.redirect('/auth/login');
    }
}
// app.get('/new', (req, res) => {
//   res.render('new');
//  });

//  app.get('/show', (req, res) => {
//   res.render('show');
//  });

// app.get('/', loginRequired, (req, res) => {
//     res.redirect('/new');
// });
// app.get('/', loginRequired, (req, res) => {
//   res.redirect('/show');
// });

 
app.get('/new', loginRequired, routes.new);//call for main index page
app.post('/new', loginRequired, routes.new);//call for signup post 
app.get('/show', loginRequired, routes.show);







app.use('/auth', auth);


app.listen(port, () => console.log(`listening on http://${process.env.HOST}:${port}`));

routes.js

const {
   con,
   sessionStore
 } = require('./config/db');
exports.new = function(req, res){
    message = '';
   if(req.method == "POST"){
      const post  = req.body;
      const username= post.username;
      const title= post.title;
      const state= post.state;
      const category= post.category;
      const description= post.description;
 
      if (!req.files)
                return res.status(400).send('No files were uploaded.');
 
        const file = req.files.uploads;
        const img_name=file.name;
 
         if(file.mimetype == "image/jpeg" ||file.mimetype == "image/png"||file.mimetype == "image/gif" ){
                                 
              file.mv('public/imgs/uploads/'+file.name, function(err) {
                             
                  if (err)
 
                    return res.status(500).send(err);
                        const sql = "INSERT INTO `nt_data`(`username`,`title`,`state`,`category`, `img_name` ,`description`) VALUES ('" + username + "','" + title + "','" + state + "','" + category + "','" + image + "','" + description + "')";
 
                            const query = con.query(sql, function(err, result) {
                                 res.redirect('show/'+result.insertUsername);
                            });
                       });
          } else {
            message = "This format is not allowed , please upload file with '.png','.gif','.jpg'";
            res.render('new.ejs',{message: message});
          }
   } else {
      res.render('new');
   }
 
};

exports.show = function(req, res){
    const message = '';
    const username = req.params.username;
    const sql="SELECT * FROM `nt_data` WHERE `username`='"+username+"'"; 
    con.query(sql, function(err, result){
      if(result.length <= 0)
      message = "show not found!";
      
      res.render('show.ejs',{data:result, message: message});
   });
};

db.js

const mysql = require('mysql');
const path = require('path');
const session = require('express-session');
const MySQLStore = require('express-mysql-session')(session);
require('dotenv').config({ path: path.join(__dirname, '../.env') });

// config for your database
const con = mysql.createConnection({
    user: process.env.DB_USER,
    password: process.env.DB_PASSWORD,
    server: process.env.DB_HOST,
    database: process.env.DB_NAME,
    port: parseInt(process.env.DB_PORT)
});

var sessionStore = new MySQLStore({}/* session store options */, con);

// connect to your database
con.connect((err) => {
    if (err) throw err;
    console.log("Connected to database");
});

module.exports = { con, sessionStore };

错误描述:

C:\Users\hp\Desktop\Internship\Nt\node_modules\mysql\lib\protocol\Parser.js:437
      throw err; // Rethrow non-MySQL errors
      ^

TypeError: Assignment to constant variable.
    at Query.<anonymous> (C:\Users\hp\Desktop\Nt\routes.js:50:12)
    at Query.<anonymous> (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\Connection.js:526:10)
    at Query._callback (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\Connection.js:488:16)
    at Query.Sequence.end (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\protocol\sequences\Sequence.js:83:24)
    at Query._handleFinalResultPacket (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\protocol\sequences\Query.js:149:8)
    at Query.EofPacket (C:\Users\hp\Desktop\\Nt\node_modules\mysql\lib\protocol\sequences\Query.js:133:8)
    at Protocol._parsePacket (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\protocol\Protocol.js:291:23)
    at Parser._parsePacket (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\protocol\Parser.js:433:10)
    at Parser.write (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\protocol\Parser.js:43:10)
    at Protocol.write (C:\Users\hp\Desktop\Nt\node_modules\mysql\lib\protocol\Protocol.js:38:16)

我猜主要是在 routes.js 文件中的错误 任何帮助将不胜感激。 谢谢

【问题讨论】:

    标签: javascript mysql node.js database express


    【解决方案1】:

    只需在show 函数中将const 更新为let

    exports.show = function(req, res){
        let message = '';
        const username = req.params.username;
        const sql="SELECT * FROM `nt_data` WHERE `username`='"+username+"'"; 
        con.query(sql, function(err, result){
          if(result.length <= 0)
          message = "show not found!";
          
          res.render('show.ejs',{data:result, message: message});
       });
    };
    

    或者如果您真的不需要重新分配它,只需在 if 语句的情况下在主体内创建变量:

    exports.show = function(req, res){
        const username = req.params.username;
        const sql="SELECT * FROM `nt_data` WHERE `username`='"+username+"'"; 
        con.query(sql, function(err, result){
          if(result.length <= 0)
          const message = "show not found!";
          
          res.render('show.ejs',{data:result, message: message});
       });
    };
    

    希望对您有所帮助!

    【讨论】:

      【解决方案2】:

      一旦你声明了const,你就不能重新分配它。查看MDN docs 了解更多信息。

      这行不通

      const message = ""
      message = "show not found!";
      

      这会

      let message = ""
      message = "show not found!"
      

      【讨论】:

        【解决方案3】:

        connect-mongo 也有类似的问题。仔细检查express-mysql-session 最新文档并检查您是否正在导入您已经意外需要的包。有时,``像Visual Studio Code 这样的IDE 会这样做。它正在通过 IDE 导入 const{express-session} 并将其分配给 mongostore。

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2020-09-15
          • 1970-01-01
          相关资源
          最近更新 更多