• AppClassLoader和WebAppClasssLoader的坑


    最近,打算学习一下spring mvc,为后续做一些积累。

    搭建spring+mybatis,动态创建mapper,mapper的文件名称和类在一个目录,但是我之前犯个

    错误,大小写写错了,结果我用普通的java程序运行,没有问题,结果部署到tomcat下面,总是

    报statement无法找到,奇怪了,java程序可以找到啊。

    可以肯定的是两个程序classloader不一样,一个是system的,一个是tomcat的。

    深入一下找到了mybatis代码,如下:

    private void loadXmlResource() {
            // Spring may not know the real resource name so we check a flag
            // to prevent loading again a resource twice
            // this flag is set at XMLMapperBuilder#bindMapperForNamespace
            if (!configuration.isResourceLoaded("namespace:" + type.getName())) {
                String xmlResource = type.getName().replace('.', '/') + ".xml";
                InputStream inputStream = null;
                try {
                    System.out.println("ClassLoader: " + type.getClassLoader());
                    inputStream = Resources.getResourceAsStream(
                        type.getClassLoader(), xmlResource);
                } catch (IOException e) {
                    // ignore, resource is not required
                }
                if (inputStream != null) {
                    XMLMapperBuilder xmlParser = new XMLMapperBuilder(inputStream,
                        assistant.getConfiguration(), xmlResource,
                        configuration.getSqlFragments(), type.getName());
                    xmlParser.parse();
                }
            }
        }

     奇怪,就是用classloader加载么,按理说没有问题,都是类路径下面的。

    找的是类名称对应的xml,按理说两个行为应该一样啊,都是找不到,不能一个找到,一个没找到。

    后来想起来,在windows平台文件大小写不区分吧,结果果断的把名字改过来,结果正常了。

    我去了,可能是我知识理解的少,这也太坑了。虽然配置错了是我的问题。。。。。

  • 相关阅读:
    查看web访问日志各url shell
    分页公式
    编译hadoop2.6.0源码
    淘宝微信支付
    nodejs hot deployment
    nwjs
    css小技巧
    webpack babel 相关文章
    nodejs web framework
    swiper
  • 原文地址:https://www.cnblogs.com/diyunpeng/p/4047208.html
Copyright © 2020-2023  润新知