0
大家好我試圖從我的網站與nodemailer發送電子郵件和表達路由後按發送按鈕我有info/contactForm 500內部服務器錯誤任何想法如何解決它。節點JS Nodemailer POST內部服務器錯誤500
//app.js
// CONFIG
const express = require('express');
const app = express();
const exphbs = require('express-handlebars');
const compression = require('compression');
const config = require('./src/server/config/config');
const http = require('http');
const path = require('path');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const routes = require('./src/server/routes/index');
const nodemailer = require('./src/server/email/emailTransporter');
// view engine setup
const hbs = exphbs.create({
defaultLayout: 'layout',
extname: '.hbs',
partialsDir: [
'./src/client/views/'
]
});
app.set('views', path.join(__dirname, './src/client/views'));
app.engine('handlebars', hbs.engine);
app.set('view engine', 'handlebars');
/**
* Get port from environment and store in Express.
*/
const port = normalizePort(process.env.PORT || '3000');
const environment = process.env.NODE_ENV;
app.use(compression());
app.set('port', port);
app.use('/', express.static(__dirname, './src/client/views', {
maxage: '1y'
}));
app.use('/', routes);
app.use('/portfolio', routes);
/**
* Create HTTP server.
*/
const server = http.createServer(app);
/**
* Listen on provided port, on all network interfaces.
*/
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
/**
* Normalize a port into a number, string, or false.
*/
function normalizePort(val) {
const port = parseInt(val, 10);
if (isNaN(port)) {
// named pipe
return val;
}
if (port >= 0) {
// port number
return port;
}
return false;
}
/**
* Event listener for HTTP server "error" event.
*/
function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
const bind = typeof port === 'string' ? 'Pipe ' + port : 'Port ' + port;
// handle specific listen errors with friendly messages
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
//index.js - 快速路由
const express = require('express');
const router = express.Router();
const config = require('../config/config');
const sendEmail = require('../email/emailTransporter');
const nodemailer = require('nodemailer');
/* Set HEaders. */
router.use('/*', function(req, res, next) {
res.setHeader('Cache-Control', 'public, max-age=864000');
res.setHeader("Content-Type", "text/html");
next();
});
/* GET home page. */
router.get('/', function(req, res, next) {
var vm = {
title: 'Portfolio'
};
res.render('index.hbs', vm);
});
/* GET portfolio. */
router.get('/portfolio', function(req, res, next) {
var vm = {
title: 'portfolioPage'
};
res.render('portfolio.hbs', vm);
});
/* SEND EMAIL . */
router.post('/contactForm', sendEmail);
module.exports = router;
//角接觸控制器
(function() {
'use strict';
angular
.module('app.layout')
.controller('contactCtrl', contactCtrl);
/* @ngInject */
function contactCtrl(emailService) {
var vm = this;
// CONTACT FORM
vm.data = {};
vm.invalidClass = false;
vm.sendEmail = function(contactForm) {
vm.submitClicked = true;
if (contactForm.$valid) {
emailService.sendEmail(vm.data);
} else {
vm.invalidClass = true;
}
};
}
})();
//角電子郵件服務
(function() {
'use strict';
angular
.module('app.layout')
.factory('emailService', emailService);
/* @ngInject */
function emailService($http, growl) {
var service = {
sendEmail: sendEmail
};
return service;
function sendEmail(emailData) {
return $http.post('/contactForm', emailData)
.then(function(data) {
growl.addSuccessMessage("Your Email was sent");
})
.catch(function(err) {
growl.addErrorMessage("Message not sent");
console.log(err);
});
}
}
})();
對不起,我知道這不是你要找的答案,但如果你的webapp可以返回500,某處出現錯誤消息(可能是某個地方已存在日誌),那麼*那*是您必須解決的問題。如果你不首先處理,你會發瘋。所有的進程管理器(永遠的,nodemon,pm2)都有一些日誌支持,或者是vanilla:'node app.js> app.log 2> err.log',同時檢查你的web服務器日誌。 – ippi