How to serve an angular2 app in a node.js server

前端 未结 5 461
你的背包
你的背包 2021-01-01 23:41

I\'m building a web app using Angular2, to create the project I\'m using Angular2 CLI webpack. Angular2 app uses other external packages also (Eg: Firebase). In addition to

相关标签:
5条回答
  • 2021-01-01 23:48

    None of the answers worked properly for me. And if it worked, the Angular routing did not work on reload.
    So this is how I solved it. Angular routing works even on full page reload.

    function getRoot(request, response) {
       response.sendFile(path.resolve('./public/angular/index.html'));
    }
    
    function getUndefined(request, response) {
       response.sendFile(path.resolve('./public/angular/index.html'));
    }
    
    // Note the dot at the beginning of the path
    app.use(express.static('./public/angular'));
    
    app.get('/', getRoot);
    app.get('/*', getUndefined);
    

    NO angular base-href rewrite is required! Just use ng build or ng build --prod.

    0 讨论(0)
  • 2021-01-01 23:52

    Follow the Express node server with Angular 2 CLI document to serve your application through Node.js server. The application is being served Through Node.js and a REST full API. You can design this REST as your requirements.

    E.g.

    Serve application with http://localhost:5000/app

    app.get('/app/*', function(req, res) {
        res.sendFile(path.join(__dirname, 'index.html'))
    });
    

    or

    Serve data from REST calls with http://localhost:5000/rest/contacts

    app.get('/rest/user', function(req, res) {
        res.send({
            "id": 2,
            "name": "Jhon",
        })
    });
    
    0 讨论(0)
  • 2021-01-01 23:54

    Here is full back end code which is working

    const express = require('express');
    var app = express();
    var port = 9999;
    
    function getRoot(request, response) {
        response.sendFile(path.resolve('./public/angular/index.html'));
     }
    
     function getUndefined(request, response) {
         response.sendFile(path.resolve('./public/angular/index.html'));
     }
    
    
     app.use(express.static('./public/angular'));
    
     app.get('/', getRoot);
     app.get('/*', getUndefined);
    
     // Start server
     app.listen(port, function () {
        console.log('server running at port: ' + port);
    }); 
    
    0 讨论(0)
  • 2021-01-01 23:59

    Based on @NTN-JAVA answer, here's a solution to serve an Angular app from NodeJS server.

    Here's the summary from beginning:

    1. npm install -g @angular/cli

    2. ng new PROJECT_NAME

    3. cd PROJECT_NAME

    4. npm install nodemon express cookie-parser body-parser morgan method-override --save

    5.Create app.js:

    var express = require('express');
    var app = express();
    var morgan = require('morgan');
    var bodyParser = require('body-parser');
    var port = process.env.PORT || 3000;
    var methodOverride = require('method-override'); // simulate DELETE and PUT (express4)
    var router = express.Router();
    
    console.log('——————————- Run on port '+ port);
    
    /****************************** Router ***************************/
    router.get('*', function(req, res){
        res.sendFile('index.html', { root: __dirname + '/' });
    });
    
    /****************************** /Router ***************************/
    
    //app.use(morgan('dev')); // log every request to the console
    app.use(express.static(__dirname + '/')); // Static (public) folder
    
    app.use(bodyParser.urlencoded({extended:true}));// get information from html forms
    app.use(bodyParser.json());
    app.use(bodyParser.json({ type: 'application/vnd.api+json' }));
    app.use(methodOverride());
    app.use('/', router); // app.use('/parent', router); call all from localhost:port/parent/*
    
    app.listen(port);
    
    1. Edit package.json file:

      { ... "scripts": { "start": "ng build; cp app.js dist/app.js; node dist/app.js", } ... }  

    2. npm start

    This answer also offers a solution for calling direct URLs from browser and resolving them correctly in your app.

    0 讨论(0)
  • 2021-01-02 00:02
    1. Use ng build to build your app into build directory.
    2. Create nodejs app to server the build directory as static content, then create route for api.

    Following is an example of nodejs app using express that will serve the Angular2 app:

    /*
    Put content of angular2 build into 'public' folder.
    */
    const html = __dirname + '/public';
    
    const port = 4000;
    const apiUrl = '/api';
    
    // Express
    const bodyParser = require('body-parser');
    const compression = require('compression');
    const express = require('express');
    var app = express();
    
    app
        .use(compression())
        .use(bodyParser.json())
        // Static content
        .use(express.static(html))
        // Default route
        .use(function(req, res) {
          res.sendFile(html + 'index.html');
        })
        // Start server
        .listen(port, function () {
            console.log('Port: ' + port);
            console.log('Html: ' + html);
        });
    
    // continue with api code below ...
    
    0 讨论(0)
提交回复
热议问题