报错为 java.io.FileNotFoundException: null/skins/ease does not exist. at org.b3log.solo.util.Skins.setDirectoryForTemplateLoading(Skins.java:144) 查找到的错误原因为 org.b3l ..

B3log Solo 0.6.5 在 BAE 部署无法启动 本地正常部署测试没有问题

本贴最后更新于 2019 天前,其中的信息可能已经天翻地覆

报错为 java.io.FileNotFoundException: null/skins/ease does not exist.

      at org.b3log.solo.util.Skins.setDirectoryForTemplateLoading(Skins.java:144)

查找到的错误原因为 org.b3log.solo.util.Skins.setDirectoryForTemplateLoading(String).webRootPath

/b3log/src/org/b3log/solo/util/Skins.java

 final String webRootPath = SoloServletListener.getWebRoot();
 
 无法获取到项目路径,请问是否有其他解决办法
18 回帖
请输入回帖内容...
  • 88250

    嗯,这个问题前几天也有同学报过,以前部署是没有问题的,估计是 BAE Java 容器最近调整过什么。
    你可以尝试在 SoloServletListener 里面实现 getWebRoot() 方法。

  • 88250

    刚刚做了一点调整,不知道有没有用,麻烦帮忙测试一下:http://pan.baidu.com/share/link?shareid=541735&uk=3255126224#dir/path=%2Fb3log-solo%2F0.6.5

  • bcsjava

    @88250 我把那个 getWebRoot() 重写了能定位到他们的 tomcar,不过貌似没用.我读取了他的 webapps 以及 ROOT 目录输出在了日志里,他的加载方式貌似有点变态.可能不是在当前的 Tomcat 下,貌似配置文件也换了.读不到他的 Tomcat 的配置文件, 本来想读了他们的配置文件输出在日志中的,没能成功,可能是修改了权限或者更改了 Tomcat 的设置

  • bcsjava

    @88250 以及部署测试过了,这个修改过的还是不行,问题还是这个

  • bcsjava

    @88250 我读取到的 Tomcat 的路径 /home/admin/runtime/tomcat/lib/ 以及 ROOT 下的文件
    asf-logo-wide.gif
    bg-nav-item.png
    bg-button.png
    tomcat.gif
    tomcat-power.gif
    bg-nav.png
    build.xml
    bg-middle.png
    RELEASE-NOTES.txt
    WEB-INF
    tomcat.css
    favicon.ico
    tomcat.png
    asf-logo.png
    bg-upper.png
    index.jsp
    tomcat.svg

  • 88250

    BAE 的 Java 运行容器不是 Tomcat,是 Jetty,而且应该也是修改过的....
    那个修改不生效的话说明可能因为一些原因,BAE 开发团队改写了 Servlet API 的 servletContext.getRealPath() 的实现,这个不应该返回 null 的 :(

  • bcsjava

    @88250 额 BAE Java 是两个容器,一个 是 Jetty 一个是 Tomcat 我选择的是 Tomcat

  • 88250

    哦,原来如此。这个问题现在搞定了吗?

  • bcsjava

    @88250 我草.现在麻烦越来越大了. 好多包都得重写.你们的模板加载包大部分都得重写,问题已经确定了,不是 BAE 的问题. 是项目打 war 包后的资源访问问题. 最好的解决办法是用 ServletContext.getResourceAsStream() 不过你们 模板加载类 入口 是 file 的抽空改改看看. latke 的 jar 的源码貌似我还没有. 等我找找 改改看

  • 88250

    要不这个问题我来修复吧?

  • bcsjava

    @88250 你先看看, 是 Java 项目 打了 war 包之后 资源路径读取错误问题.我这边也试试.

  • 88250

    嗯,没问题,多谢帮忙了。

  • 88250

    我建了个 issue,这个 bug 这周内解决 :-p

  • 88250

    代码已经提交了,这两天有空的话请帮忙验证一下 BAE 运行。需要先拉 latke 进行构建,然后在拉 solo 进行构建。

  • bcsjava

    @88250 简单调试了下 可以了 不过有两个小的问题 repository.json 文件需要放在 根目录下, 2 是更换皮肤的话需要重启才能生效

  • 88250

    1. 刚刚提交了加载 repository.json 的方式,请更新 latke 再试试
    2. 皮肤重启才能生效的问题估计搞不定 (/ □ )

  • bcsjava

    @88250 我这不用改了,我直接改了源码.已经部署好了 http://bcsjava.duapp.com 重启的应该是 BAE 容器的事. 更新样式, 标题 什么的都的重启下

  • 88250

    嗯,好的。

    多谢帮忙发现这个严重的 bug,非常感谢 :-)

请输入回帖内容 ...