Угловой Универсал с внутренними экспресс звонками API - PullRequest
0 голосов
/ 03 декабря 2018

Я проверил несколько учебных пособий и пошаговых руководств о том, как добавить SSR (рендеринг на стороне сервера) в существующие угловые проекты CLI и Express.

Мне удалось запустить узел с SSR, но я не могу сделатьВызовы API.Я хочу запустить один процесс узла, который может обслуживать статический файл (Angular с SSR) и динамический контент с вызовами API, которые обращаются к SQLITE БД с использованием KNEX .

Этоmy server.js file

// These are important and needed before anything else
import 'zone.js/dist/zone-node';
import 'reflect-metadata';

import { enableProdMode } from '@angular/core';

import * as express from 'express';
import { join } from 'path';

// Faster server renders w/ Prod mode (dev mode never needed)
enableProdMode();

// Express server
const app = express();

const PORT = process.env.PORT || 3000;
const DIST_FOLDER = join(process.cwd(), 'bin/dist');

// * NOTE :: leave this as require() since this file is built Dynamically from webpack
const { AppServerModuleNgFactory, LAZY_MODULE_MAP } = require('./bin/dist/server/main');

// Express Engine
import { ngExpressEngine } from '@nguniversal/express-engine';
// Import module map for lazy loading
import { provideModuleMap } from '@nguniversal/module-map-ngfactory-loader';

app.engine('html', ngExpressEngine({
  bootstrap: AppServerModuleNgFactory,
  providers: [
    provideModuleMap(LAZY_MODULE_MAP)
  ]
}));

app.set('view engine', 'html');
app.set('views', join(DIST_FOLDER, ''));

// import * as apiS from './server/index';
// apiS.load(app);
// TODO: implement data requests securely
// app.get('/api/*', (req, res) => {
//   res.status(404).send('data requests are not supported');
// });

import * as LoadRoutes from './server/boot/routes';
LoadRoutes.load(app);


// Server static files from /browser
app.get('*.*', express.static(join(DIST_FOLDER, '')));

// All regular routes use the Universal engine
app.get('*', (req, res) => {
  res.render('index', { req });
});

// Start up the Node server
app.listen(PORT, () => {
  console.log(`Node server listening on http://localhost:${PORT}`);
});

Возможно ли даже выполнить вызовы SSR + API из одного и того же процесса узла, и если это так, кто-то может опубликовать здесь ответ?

1 Ответ

0 голосов
/ 24 июля 2019

Это уже там.Просто раскомментируйте эти строки и расширьте маршруты API с помощью маршрутизатора Express:

app.get('/api/*', (req, res) => {
  res.status(404).send('data requests are not supported');
});

Вместо этого используйте файл маршрутизатора:

app.use('/api/*', appRoutes);

Каждый URL, начинающийся с api /, будет обслуживаться внутренними API.

...