1、背景

根据官网一步步地生成项目,他喵的启动后居然是一个空白页面,这怎么玩啊?还有这种操作的吗?跟说好的不一样啊!关于JHipster资料,国内少的可怜,几乎都是同一样的东西,纯介绍的文章,只好上stackoverflow上查了。

2、相似的情况

stackoverflow找到了一个相似的提问,不过没有具体的解决方法,倒是里面的某个评论给了我很大的提示。

By default, yarn listens on port 9000 (webpack + browser sync) to hot reload frontend code and contents, maven or gradle listens on port 8080 to hot reload server code. You must run both in dev.

在开发阶段,通常使用yarn start来启动angular2,可以在开发过程中热加载修改后的代码,然后通过./mvnw来启动Spring Boot后端的api服务。

那么问题来了,我以后要上线的时候也要这样启动啊?(╯‵□′)╯︵┻━┻

3、解决过程

由于前端是angular2,虽然可以热加载方便开发者开发,但是上线也不会这样做的。

通过了解angular2,可以通过ng build打包好,然后可以直接访问主页。

我在项目的目录下执行ng build后,打包好的代码自动生成到target的www上面。

再次启动项目,还是空白页面,回到原点。

打开浏览器的F12的network,居然只有一个localhost???

不对啊!为什么只会有一个localhost呢?其他资源没有加载吗?有猫腻!

打开生成项目的代码,找到配置web资源的WebConfigurer,通过查看代码,我们可以看到:

public void customize(ConfigurableEmbeddedServletContainer container) {
MimeMappings mappings = new MimeMappings(MimeMappings.DEFAULT);
// IE issue, see https://github.com/jhipster/generator-jhipster/pull/711
mappings.add("html", "text/html;charset=utf-8");
// CloudFoundry issue, see https://github.com/cloudfoundry/gorouter/issues/64
mappings.add("json", "text/html;charset=utf-8");
container.setMimeMappings(mappings);
// When running in an IDE or with ./mvnw spring-boot:run, set location of the static web assets.
setLocationForStaticAssets(container); /*
* Enable HTTP/2 for Undertow - https://twitter.com/ankinson/status/829256167700492288
* HTTP/2 requires HTTPS, so HTTP requests will fallback to HTTP/1.1.
* See the JHipsterProperties class and your application-*.yml configuration files
* for more information.
*/
if (jHipsterProperties.getHttp().getVersion().equals(JHipsterProperties.Http.Version.V_2_0) &&
container instanceof UndertowEmbeddedServletContainerFactory) { ((UndertowEmbeddedServletContainerFactory) container)
.addBuilderCustomizers(builder ->
builder.setServerOption(UndertowOptions.ENABLE_HTTP2, true));
}
}

其中,setLocationForStaticAssets(container);就是设置网站的静态资源的位置。眼看代码是没问题的,唯有debug救我。debug下面的代码:

private void setLocationForStaticAssets(ConfigurableEmbeddedServletContainer container) {
File root;
String prefixPath = resolvePathPrefix();
root = new File(prefixPath + "target/www/");
if (root.exists() && root.isDirectory()) {
container.setDocumentRoot(root);
}
}

通过debug发现,root的路径多了%20的字符导致找不到路径,%20就是空格,将空格去掉再试一试~

果然是这个问题,去掉空格之后就有内容了。

4、结案

看看目录的路径是否带有空格或者中文字符,有的话去掉试试看。

最新文章

  1. 推荐几篇关于EF的好文章
  2. python Windows下的android设备截图工具
  3. Android TabHost使用
  4. Python【8】-分析json文件
  5. 使用supervisor提高nodejs调试效率
  6. 2014-10-28——iframe多层嵌套时获取元素总结
  7. mplayer依赖关系不满足
  8. AngularJs ngIf、ngSwitch、ngHide/ngShow
  9. Codeforce Round #227 Div2
  10. PHP+MYSQL 出现乱码的解决方法
  11. poj 1696 Space Ant 极角排序
  12. bzoj1978
  13. js代码细嚼慢咽
  14. Spark:将RDD[List[String,List[Person]]]中的List[Person]通过spark api保存为hdfs文件时一直出现not serializable task,没办法找到"spark自定义Kryo序列化输入输出API"
  15. javascript语法之函数的定义
  16. 新增和修改页面的用例设计和Bug提交
  17. python+selenium测试
  18. Web、OAuth2/SSO相关拾遗
  19. gitlab git
  20. Web安全之跨站脚本攻击(XSS)

热门文章

  1. Internet History, Technology and Security (Week 7)
  2. 词频统计Web工程
  3. Centos7 django+uwsgi+nginx+python3.6.8部署
  4. python杂谈:Python中\r的用法示例
  5. Java开发中的23种设计模式详解(转载)
  6. 【移动端debug-5】可恶的1px万能实现方案
  7. Java 信号量 Semaphore 介绍
  8. BZOJ 3143 游走 | 数学期望 高斯消元
  9. HIGH-SPEED PACKET PROCESSING USING RECONFIGURABLE COMPUTING
  10. 【ARC074e】RGB sequence