我不得不处理一个类似的问题:我正在使用 Angular 6 前端和 Java 后端(REST Web 服务、Spring 和 MyBatis)开发一个 Web 应用程序。
对于 Spring 配置,我还是使用 XML 配置文件。
在开发模式下,我在客户端部分使用4200 端口,在后端使用 8080(在 Tomcat 上)。在这种情况下没有问题。
然后我在 war 中合并了 Angular 应用程序,特别是在 public 文件夹中。之后,当我运行应用程序并点击 F5 按钮时,我会收到一个404 error。
对于 Spring 端的 public 文件夹,我进行以下配置:
<mvc:resources mapping="/public/**" location="/public/">
<mvc:resource-chain resource-cache="false">
<mvc:resolvers>
<bean class="com.example.web.AngularResourceResolver" />
</mvc:resolvers>
</mvc:resource-chain>
</mvc:resources>
AngularResourceResolver 是这样定义的:
import org.springframework.core.io.Resource;
import org.springframework.web.servlet.resource.PathResourceResolver;
public class AngularResourceResolver extends PathResourceResolver {
@Override
protected Resource getResource(String resourcePath, Resource location) throws IOException {
Resource requestedResource = location.createRelative(resourcePath);
Resource defaultResource=location.createRelative("/index.html");
Resource resource = requestedResource.exists() && requestedResource.isReadable() ? requestedResource : defaultResource;
return resource;
}
}
应用此配置后,即使在 Tomcat 上一切正常,即使按下 F5。
希望对你有帮助。