angular - 如何配置环回来服务 angular4 应用程序?

标签 angular loopbackjs angular-loopback

我使用 angular-cli 生成了 LoopBack 项目和 Angular4 项目。 我的 LoopBack 项目在端口 3000 上提供 html 文件,而我的 Angular4 项目在 4200 上提供服务。

现在我需要知道我是否可以在 3000 上提供这个 Angular 应用程序,就像从 LoopBack 目录提供静态文件一样?

What I am trying to ask is if it is possible to use LoopBack server to serve Angular4 app just like it serves Angularjs app?

谢谢

最佳答案

如果您使用 ngserve 通过 Angular-cli 提供服务,Angular 仅在端口 4200 上运行。

您必须将 Angular middleware.json 文件选项指向 Angular2 应用程序的 dist 目录,或者将 dist 目录内容复制到环回“client”文件夹中。

所以它看起来像这样:

middleware.json

   .
   .
    "files": {
        "loopback#static": {
          "params": "$!../client/"
        }
      }
   .
   .

dist 目录是 Angular 运行时输出文件的位置

ng build

确保环回启动文件夹中没有 router.js 文件。这通常包含一些路由代码,用于将根 URL 重定向到 api 的状态输出,因此/会将您带到 api 状态,而不是 Angular 应用程序的 index.html。

Loopback 为 Angular 应用程序提供服务,但是,当您尝试直接访问链接时,例如/blog/:id 换句话说,类似于/blog/f24382f3y23f9832 ,那么它将失败,因为环回不知道如何处理这些链接,即使环回客户端指向 Angular,但在直接查询这些链接时,Angular 尚未“引导”。

要解决此问题,您必须添加自定义中间件以将环回重定向到 Angular 索引,以便 Angular 的路由器可以从那里获取它。

因此,在您的 middleware.json 文件中,更改以下内容:

"final": {
    "./middleware/custom404": {}
    }

然后在/server/middleware/中添加文件 custom404.js ,使完整路径为/server/middleware/custom404.js 。如果中间件目录不存在,则创建它。

然后在custom404.js文件中:

'use strict';
module.exports = function () {
    var path = require('path');
    return function urlNotFound(req, res, next) {
        let angular_index = path.resolve('client/index.html');
        res.sendFile(angular_index, function (err) {
            if (err) {
                console.error(err);
                res.status(err.status).end();
            }
        });
    };
};

这将重定向回您的 Angular 应用程序,并且 Angular 的路由器将正确路由 URL,同时仍由环回提供服务。

我使用path.resolve,以便首先根据我们的Web路径而不是当前目录解析链接,否则它将被视为恶意调用,您将收到403错误。

我已阅读 angular.io 文档,这是实现此目的的正确方法。看到这里angular.io docs 。阅读标题为“路由应用程序必须回退到index.html”的部分

我在这里发表了自己的帖子 Rewrite requests from loopback to angular2 (Refused to execute script because its MIME type ('text/html') is not executable)我遇到了类似的问题。

关于angular - 如何配置环回来服务 angular4 应用程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44112896/

相关文章:

angular - 与 typescript 、节点和 Angular 共享代码

angular - 我应该在每个路由器导航上重置我的 redux 存储吗?

mysql - 如何在loopback4中添加外键?

node.js - 部署后,我的 Nodejs 应用程序使用环回 api 在 PM2 中遇到错误

node.js - lb-ng 环回命令从异步模块返回 "Cannot read property ' apply' of undefined"

typescript - 使用数据库的环回 4 身份验证

javascript - 如何摆脱页面上不必要的 ng-container 边距?

angular - 在配置文件中为 ng serve 设置默认主机和端口

javascript - 如何继续实现混合移动应用理念?

javascript - Angular-环回-SDK : prototype$updateAttributes is not a function