ct234
ct234

Reputation: 15

Passport.js authentification on express webapp Error "Cant set headers once already sent"

Hi I am making an express webapp connected to a mysql server on a remote db provided by my college. I am following a tutorial to set up passport.js authentification and have run into a problem when trying to post the data on posting the /regnew request

the error showing up in putty is :

Error: /students/danu7_tc3/project/views/error.hbs: Can't set headers after they are sent. at validateHeader (_http_outgoing.js:491:11) at ServerResponse.setHeader (_http_outgoing.js:498:3) at ServerResponse.header (/students/danu7_tc3/project/node_modules/express/lib/response.js:767:10) at ServerResponse.send (/students/danu7_tc3/project/node_modules/express/lib/response.js:170:12) at done (/students/danu7_tc3/project/node_modules/express/lib/response.js:1004:10) at /students/danu7_tc3/project/node_modules/hbs/lib/hbs.js:93:9 at Object.done (/students/danu7_tc3/project/node_modules/hbs/lib/async.js:74:20) at /students/danu7_tc3/project/node_modules/hbs/lib/hbs.js:88:18 at /students/danu7_tc3/project/node_modules/hbs/lib/hbs.js:69:11 at Object.done (/students/danu7_tc3/project/node_modules/hbs/lib/async.js:74:20)

This is my index.js code

var express = require('express');
var router = express.Router();

var passport = require('passport');

var bcrypt = require('bcrypt');
const saltRounds = 10;


/* GET home page. */
router.get('/', function(req, res, next) {
    res.render('index', {
        title: 'Express'
    });
});

router.get('/home', function(req, res, next) {
    res.render('home', {
        title: 'Home'
    });
});


router.get('/registration', function(req, res, next) {
    res.render('registration');

});
router.post('/regnew', function(req, res, next) {

    var username = req.body.username;
    var email = req.body.email;
    var password = req.body.password;


    console.log(username);


    const db = require('./db_connection.js');

    bcrypt.hash(password, saltRounds, function(err, hash) {
        db.query('INSERT INTO Users (username, email, password) VALUES 
            ( ? , ? , ? )
            ',[username,email,hash], function(error,result,fields) {
                if (error) throw error;

                db.query('SELECT LAST_INSERT_ID() as user_id', function(error,
                    results, fields) {
                    if (error) throw error;

                    const user_id = results[0];


                    console.log(results[0]);
                    req.login(user_id, function(err) {
                        res.redirect('/home');
                    });



                });
                res.render('registration', {
                    title: 'Success'
                });
            });
    });

});
passport.serializeUser(function(user_id, done) { //store user id in 
    session
    done(null, user_id);
});

passport.deserializeUser(function(id, done) { //read from the session

    done(err, user_id);
});



module.exports = router;

Upvotes: 0

Views: 101

Answers (1)

yeya
yeya

Reputation: 2204

You are calling res twice.

  1. res.redirect
  2. res.render

Upvotes: 0

Related Questions