解析MyBatis配置文件mybatis-config.xml(一)

mybatis 配置文件 mybatis-config.xmljava

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<!-- 配置文件的根元素 -->
<configuration>
    <!-- 属性:定义配置外在化 -->
    <properties></properties>
    <!-- 设置:定义mybatis的一些全局性设置 -->
    <settings>
        <!-- 具体的参数名和参数值 -->
        <setting name="" value=""/>
    </settings>
    <!-- 类型名称:为一些类定义别名 -->
    <typeAliases></typeAliases>
    <!-- 类型处理器:定义Java类型与数据库中的数据类型之间的转换关系 -->
    <typeHandlers></typeHandlers>
    <!-- 对象工厂 -->
    <objectFactory type=""></objectFactory>
    <!-- 插件:mybatis的插件,插件能够修改mybatis的内部运行规则 -->
    <plugins>
        <plugin interceptor=""></plugin>
    </plugins>
    <!-- 环境:配置mybatis的环境 -->
    <environments default="">
        <!-- 环境变量:能够配置多个环境变量,好比使用多数据源时,就须要配置多个环境变量 -->
        <environment id="">
            <!-- 事务管理器 -->
            <transactionManager type=""></transactionManager>
            <!-- 数据源 -->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://120.78.83.28:3306/test?useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false"/>
                <property name="username" value="root"/>
                <property name="password" value="Dsk741852!"/>
            </dataSource>
        </environment>
    </environments>
    <!-- 数据库厂商标识 -->
    <databaseIdProvider type=""></databaseIdProvider>
    <!-- 映射器:指定映射文件或者映射类 -->
    <mappers></mappers>
</configuration>

 

Mybatis 在初始化过程当中处理mybatis-Config.xml 配置文件以及映射文件时,使用的是DOM解析,并结合XPath 解析XML配置文件。DOM会将整个XML文档加载到内存并造成数据结构。XPath 是XML查询语句,实现对XML的解析,功能相似SQL语句。EntityResolver 用于加载本地dtd。mysql

Mybatis 提供的XpathParser 类封装 前面涉及的XPath,Document 和EntityResolversql

public class XPathParser {

  private Document document;
  private boolean validation;
  private EntityResolver entityResolver;
  private Properties variables;
  private XPath xpath;

默认状况下,对XML文档进行验证时,会根据XML文档开始位置指定的网址加载对应的DTD文件或XSD文件。当网络比较慢时,在实践中提早设置EntityResolver 接口对象加载本地DTD文件。数据库

package xml;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.parsing.XPathParser;
import org.xml.sax.EntityResolver;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;

import java.io.IOException;
import java.io.InputStream;
import java.util.Locale;

/**
 * Created by dingshuangkun on 2017/12/10.
 */
public class XMLMapperEntityResolver implements EntityResolver {

    private static final String IBATIS_CONFIG_SYSTEM="ibatis-3-cofig.dtd";
    private static final String IBATIS_MAPPER_SYSTEM="ibatis-3-mapper.dtd";
    private static final String MYBATIS_CONFIG_SYSTEM="mybatis-3-cofig.dtd";
    private static final String MYBATIS_MAPPER_SYSTEM="mybatis-3-mybatis.dtd";
    private static final String MYBATIS_CONFIG_DTD="org/apache/ibatis/builder/xml/mybatis-3-cofig.dtd";
    private static final String MYBATIS_MAPPER_DTD="org/apache/ibatis/builder/xml/mybatis-3-mapper.dtd";
    @Override
    public InputSource resolveEntity(String publicId, String systemId) throws SAXException, IOException {
        if(systemId!=null){
            String lowerCaseSystemId=systemId.toLowerCase(Locale.ENGLISH);
            if(lowerCaseSystemId.contains(MYBATIS_CONFIG_SYSTEM) || lowerCaseSystemId.contains(IBATIS_CONFIG_SYSTEM)){
              return getInputSource(MYBATIS_CONFIG_DTD,publicId,systemId);
            }else if(lowerCaseSystemId.contains(MYBATIS_MAPPER_SYSTEM) || lowerCaseSystemId.contains(IBATIS_MAPPER_SYSTEM)){
                return getInputSource(MYBATIS_MAPPER_DTD,publicId,systemId);
            }

        }
        return null;
    }

    public InputSource getInputSource(String path,String publicId,String systemId){
        InputSource source=null;
        try {
            InputStream in= Resources.getResourceAsStream(path);
            source=new InputSource(in);
            source.setPublicId(publicId);
            source.setSystemId(systemId);
        }catch (Exception e){
            e.printStackTrace();
        }
        return source;
    }
}
相关文章
相关标签/搜索