0
我有一個名爲admin的路由的快速v4服務器。當用戶向管理員路由發佈密碼時,我想通過在用戶瀏覽器上設置一個cookie併發送一個小json來做出響應。出於某種原因,服務器在嘗試響應時不斷返回錯誤500。我假設這與cookie有關,因爲我可以在沒有任何問題的情況下執行「res.send()」。我新來表達/ nodejs,所以任何幫助表示讚賞。爲什麼我的服務器在嘗試設置cookie時返回錯誤500?
admin.js
var express = require('express');
var router = express.Router();
var cookieParser = require('cookie-parser');
/* POST HANDLER */
router.post('/', function(req, res) {
var on = {'admin' : "on"};
res.cookie(cookie , 'cookie_on').send(on);
});
module.exports = router;
app.js
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var routes = require('./routes/index');
var admin = require('./routes/admin');
var blogposts = require('./routes/blogposts');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/admin', admin);
app.use('/blogposts', blogposts);
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handlers
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
module.exports = app;
支票上的錯誤500服務器日誌的詳細信息 –
@devlincarnate它只是說「POST/admin 500 582.134ms -1260」。有沒有辦法獲得更多信息(再次,我是新來表達的)?每個'res.status(err.status || 500)之後的 – user2997154
;'只需添加'console.log(err)'並調查問題。快遞不能說你什麼,因爲它是你的代碼生成錯誤 – vmkcom