- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我相信这是一个简单的问题,但我找不到答案,或者至少在搜索中使用了正确的术语。
我正在一起设置 Angular2
和 Springboot
。默认情况下,Angular
将使用 localhost:8080\dashboard
和 localhost:8080\dashboard\detail
等路径。
如果可能的话,我想避免使用路径作为哈希值。作为 Angular documentation状态:
The router's provideRouter function sets the LocationStrategy to the PathLocationStrategy, making it the default strategy. We can switch to the HashLocationStrategy with an override during the bootstrapping process if we prefer it.
然后……
Almost all Angular 2 projects should use the default HTML 5 style. It produces URLs that are easier for users to understand. And it preserves the option to do server-side rendering later.
问题是,当我尝试访问 localhost:8080\dashboard
时,Spring 会寻找一些映射到该路径的 Controller ,而它不会。
Whitelabel Error Page
There was an unexpected error (type=Not Found, status=404).
No message available
我最初想将我的所有服务都放在 localhost:8080\api
下,并将所有静态服务放在 localhost:8080\app
下。但是我如何告诉 Spring 忽略对这个 app
路径的请求呢?
Angular2 或 Boot 是否有更好的解决方案?
最佳答案
在我的 Spring Boot 应用程序(版本 1 和 2)中,我的静态资源位于一个位置:
src/main/resources/static
static
为Spring Boot识别加载静态资源的文件夹。
那么思路就是自定义Spring MVC配置。
更简单的方法是使用 Spring Java 配置。
我实现了 WebMvcConfigurer
来覆盖 addResourceHandlers()
。我将 single ResourceHandler
添加到当前的 ResourceHandlerRegistry
。
处理程序映射到每个请求,我将 classpath:/static/
指定为资源位置值(如果需要,您当然可以添加其他值)。
我添加了一个自定义 PathResourceResolver
匿名类来覆盖 getResource(String resourcePath, Resource location)
。
返回资源的规则如下:如果资源存在并且可读(所以它是一个文件),我返回它。否则,默认情况下我会返回 index.html
页面。这是处理 HTML 5 url 的预期行为。
Spring Boot 1.X 应用程序:
扩展org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter
是办法。
类是WebMvcConfigurer
接口(interface)的适配器使用空方法允许子类仅覆盖他们感兴趣的方法。
这是完整的代码:
import java.io.IOException;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import org.springframework.web.servlet.resource.PathResourceResolver;
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/**/*")
.addResourceLocations("classpath:/static/")
.resourceChain(true)
.addResolver(new PathResourceResolver() {
@Override
protected Resource getResource(String resourcePath,
Resource location) throws IOException {
Resource requestedResource = location.createRelative(resourcePath);
return requestedResource.exists() && requestedResource.isReadable() ? requestedResource
: new ClassPathResource("/static/index.html");
}
});
}
}
Spring Boot 2.X 应用程序:
org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter
已弃用。
直接实现 WebMvcConfigurer
是现在的方式,因为它仍然是一个接口(interface),但它现在具有默认方法(通过 Java 8 基线实现)并且可以直接实现而无需适配器。
这是完整的代码:
import java.io.IOException;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.resource.PathResourceResolver;
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/**/*")
.addResourceLocations("classpath:/static/")
.resourceChain(true)
.addResolver(new PathResourceResolver() {
@Override
protected Resource getResource(String resourcePath,
Resource location) throws IOException {
Resource requestedResource = location.createRelative(resourcePath);
return requestedResource.exists() && requestedResource.isReadable() ? requestedResource
: new ClassPathResource("/static/index.html");
}
});
}
}
编辑以解决一些评论:
对于那些将其静态资源存储在另一个位置作为 src/main/resources/static
的人,因此更改 addResourcesLocations()
的 var args 参数的值。
例如,如果您在 static
和 public
文件夹中都有静态资源(未尝试):
registry.addResourceHandler("/**/*")
.addResourceLocations("classpath:/static/", "/public")
关于Spring Boot/Angular 2 - 如何处理 HTML5 url?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38516667/
我正在尝试在项目中学习和添加 Angular 国际化。我只能理解 Angular 文档 (https://angular.io/guide/i18n-overview) 的编译时翻译。 我需要这样的东
在我的 Angular 应用程序中,基于登录用户,我想通过显示/隐藏不同的菜单项或允许/禁止某些路由来授予或限制功能。 目前成功登录后,我的 .NET Core API 会返回一个 JWT token
我是 Angular 的新手,目前我已经看过 angular.io 网站提供的一些示例。但是在component decorator在文档中的解释,它指出 Angular components are
这里是service employee-service.service.ts的代码 import { Injectable } from '@angular/core'; import { HttpC
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
如何正确安装 PUG/JADE 到 Angular 2 或更高版本 这样在工作和 AOT 和 JiT 的同时 工作单元和集成测试 并且在创建每个新组件时不会受到太多影响 最佳答案 我看到了很多解决方案
我的 Angular 12 应用程序中有一些通用组件,我计划将其创建为一个 Angular 库,以便其他应用程序也可以使用它。我们有一些应用程序在较低版本的 angular(例如 angular 8/
tl;dr; ng build 删除了包含我编译的自定义库的/dist 文件夹。这会使我项目代码中对该库的所有引用无效,从而导致 ng build 最终失败。我做错了什么? 我关注了documenta
我正在将一些“遗留”(非 typescript )js 库导入到我的 Angular SPA 中。 通常我只是从 cdn 添加一个负载到 index.html 就像: 在 Angular 分量中我只
我有这个 angular 应用程序,它基本上使用了库的概念。 我有 2 个名为 的库Lib1 和 lib2 根据他们所服务的微服务分组。 现在我将这些库导入主应用程序,即 应用1 事情一直到现在。 现
我在我的项目中启用了 angular Universal。我现在想完全删除它。我试图删除以下文件 /server.ts /webpack.server.config.js /src/tsconfig.
我已经有一个 AuthService 在登录时对用户进行身份验证,并且 AuthGuard 在未登录的情况下阻止访问。 某些页面我通过 UserProfile/Role 限制访问,但现在我需要阻止页面
我正在尝试使用 angular、TypeORM、SQLite 和其他组件作为 webpack 构建 Electron 应用程序。 我从在 GitHub 上找到的示例开始我的开发:https://git
我在从 Angular 8 更新到 9 并运行时遇到以下错误 ng 更新@angular/material: Package "@angular/flex-layout" has an incompa
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在我的 h1 元素“之前”创建一个小的程式化三 Angular 形图案,但我无法正确地圆 Angular 。右上角没问题,但其他两个有剪裁问题。 这是输出以及形状的放大图像: 使用的代码如下: h
我有一个 Angular 元素,带有自定义标记名 - fancy-button。如何将 fancy-button 嵌入 Angular 应用程序? 我已经尝试了以下方法,但都没有用 - 在 index
我已将我的项目从 angular 5.2.9 升级到 angular 6.0.0-rc.5。 除了包路径中的几个快速 RxJS 修复外,一切看起来都不错。(此链接非常有用:Want to upgrad
我是一名优秀的程序员,十分优秀!