Невозможно получить при использовании навсегда с узлом и экспресс

Мы используем NodeJS и Express в сочетании с навсегда. Это работало нормально, но теперь нам пришлось обновить нашу версию NodeJS, и все перестало работать.

Мы используем angular с ui-routing для маршрутизации веб-интерфейса, поэтому у нас есть статическая папка. Я могу перейти на нашу домашнюю страницу (/) и оттуда я могу перейти на весь сайт. Но когда я обновляю страницу или перехожу прямо на страницу (например, /products), я получаю

Не могу получить / продукты

ошибка. Узел выдает ошибку 404.

Когда я запускаю скрипт напрямую без вечно все работает нормально. Как видите, у нас есть 2 статические папки, настроенные в экспрессе. До обновления все отлично работает.

Мы также используем Apache для перенаправления пользовательских доменных имен на определенные страницы без изменения адреса в браузере, но это работает нормально (вместо страницы отображается только ошибка GET). Кто-нибудь есть идеи, как решить эту проблему?

наш app.js

var path = require('path');
var fs = require('fs');

// Return values from different config files will be added to this object so you can call config.[category].[property].
config = {};

// Save the app root directory to a global variable so it can be used in config files and other parts of the app. global.root is reserved, but global.path.root can be used without problems.
global.path = {root: path.resolve(__dirname)};

// Set environment and initialize environment-specific config variables
config.env = require(path.join(__dirname, 'config', 'env.config'));

// Set up database connection to use throughout the application
config.db = require(path.join(__dirname, 'config', 'db.config'));

// HTTP for development environment, HTTPS for production environment
var http = require('http');
var https = require('https');

// Set up debugging/logging for the development environment
var debug = require('debug')('http');

// Start the app using the Express settings/routines in express.config.
var app = require(path.join(__dirname, 'config', 'express.config'));

// Start GraphQL process
// require(path.join(__dirname, 'config', 'graphql.config'))(app);

var router = require(path.join(__dirname, 'config', 'routes.config'));

router(app);

// Running in production mode: HTTPS only
if(config.env.name === 'production') {
    var credentials = {
        privateKey: fs.readFileSync('privkey'),
        certificate: fs.readFileSync('fullchain')
    };

    var server = https.createServer(credentials, app);
    server.listen(4443);
    server.on('error', onError);
    server.on('listening', onListen);

    var server2 = http.createServer(app);
    server2.listen(8080);

// Running in development mode: HTTP only
} else {
    var server = http.createServer(app);
    server.listen(config.env.port);
    server.on('error', onError);
    server.on('listening', onListen);
}
//some listeners here

Наш express.config.js

var path = require('path');

console.log('Initializing API...');

var express = require('express');
var bodyParser = require('body-parser');
var cookieParser = require('cookie-parser');
var compression = require('compression');
var morgan = require('morgan');
var session = require('express-session');
var MongoStore = require('connect-mongo')(session);
var config =  require(path.join(__dirname, 'db.config'));

// The GraphQL server implementation for Express by the Apollo team.
var graphqlExpress = require('graphql-server-express').graphqlExpress;
var graphiqlExpress = require('graphql-server-express').graphiqlExpress;

var OpticsAgent = require("optics-agent");

var passport = require('passport');

var app = express();

// Handle application/json requests
app.use(bodyParser.json({ limit: '50mb' }));
// Handle application/x-www-form-urlencoded requests (usually POST, PUT, etc.)
app.use(bodyParser.urlencoded({ extended: false, limit: '50mb' }));

app.use(cookieParser());

app.use(session({
    store: new MongoStore({
        url: 'mongodb://' + config.url + ':' + config.port + '/' + config.name
    }),
    secret: 'secret',
    key: 'skey.sid',
    resave: false,
    saveUninitialized: false,
    cookie : {
        maxAge: 604800000 // 7 days in miliseconds
    }
}));

app.use(passport.initialize());
app.use(passport.session());
require(path.join(__dirname, 'auth.config'))(passport); //Load passport config

app.use(function(req, res, next) {
    req.resources = req.resources || {};
   // res.locals.app = config.app;
    res.locals.currentUser = req.user;
    res.locals._t = function (value) { return value; };
    res.locals._s = function (obj) { return JSON.stringify(obj); };
    next();
})

// Use gzip compression (following the Express.js best practices for performance)
app.use(compression());

// Serve frontend and static files like stylesheets and images from the Express server
app.use(express.static(path.join(__dirname, '..', '..', 'app')));
app.use(express.static(path.join(__dirname, '..', '..', 'public')));

// Morgan logger (previously named express-logger)
app.use(morgan("dev"));

// Generate the GraphQL schema
var schema = require(path.join(__dirname, 'graphql.config'))().then(function(schema) {

    /* Use Apollo Optics middleware for query optimization/tracing. */
    OpticsAgent.instrumentSchema(schema);
    app.use('/apiv2', OpticsAgent.middleware());

    console.log('GraphQL schema generated.');

    /* Return params object for Apollo GraphQL Server using a request handler function. */
    app.use('/apiv2', graphqlExpress(function(req) {

        return {
            schema: schema,
            debug: true,
            context: {
                opticsContext: OpticsAgent.context(req)
            }
        };
    }));

    app.use('/graphiql', graphiqlExpress({endpointURL: '/apiv2'}));

    console.log('GraphQL started.');

    /* Handle all other HTTP requests AFTER graphql server API endpoint and other routes are defined. */
    app.use('*', express.static('app'));
});

// Always keep the errorHandler at the bottom of the middleware function stack!

// Returns a user-friendly error message when the server fails to fulfill the request
app.use(function(err, req, res, next) {
    var status = 500, response = {message: 'An internal server error has occurred while trying to load this page. '};

    console.error(err.stack);
    res.status(status).json(response);

    next(err);
});

module.exports = app;

1 ответ

Решение

Не совсем решение этой проблемы, но мы навсегда перешли на PM2 ( https://github.com/Unitech/pm2), и эта программа отлично справляется со своей задачей!

Другие вопросы по тегам