MyBatis Generator Configuration

generatorConfig.xml

本Markdown编辑器使用[StackEdit][6]修改而来,用它写博客,将会带来全新的体验哦:

  • DefaultCommentGenerator.java
  • generatorConfig.xml
public class DefaultCommentGenerator implements CommentGenerator {

    private Properties properties;
    private Properties systemPro;
    private boolean suppressDate;
    private boolean suppressAllComments;
    private String currentDateStr;

    public DefaultCommentGenerator() {
        super();
        properties = new Properties();
        systemPro = System.getProperties();
        suppressDate = false;
        suppressAllComments = false;
        currentDateStr = (new SimpleDateFormat("yyyy-MM-dd")).format(new Date());
    }

    @Override
    public void addJavaFileComment(CompilationUnit compilationUnit) {
        // add no file level comments by default
        return;
    }

    /**
     * Adds a suitable comment to warn users that the element was generated, and
     * when it was generated.
     */
    @Override
    public void addComment(XmlElement xmlElement) {
        return;
    }

    @Override
    public void addRootComment(XmlElement rootElement) {
        // add no document level comments by default
        return;
    }

    @Override
    public void addConfigurationProperties(Properties properties) {
        this.properties.putAll(properties);

        suppressDate = isTrue(properties.getProperty(PropertyRegistry.COMMENT_GENERATOR_SUPPRESS_DATE));

        suppressAllComments = isTrue(properties.getProperty(PropertyRegistry.COMMENT_GENERATOR_SUPPRESS_ALL_COMMENTS));
    }

    /**
     * This method adds the custom javadoc tag for. You may do nothing if you do
     * not wish to include the Javadoc tag - however, if you do not include the
     * Javadoc tag then the Java merge capability of the eclipse plugin will
     * break.
     *
     * @param javaElement the java element
     */
    protected void addJavadocTag(JavaElement javaElement, boolean markAsDoNotDelete) {
        javaElement.addJavaDocLine(" *");
        StringBuilder sb = new StringBuilder();
        sb.append(" * ");
        sb.append(MergeConstants.NEW_ELEMENT_TAG);
        if (markAsDoNotDelete) {
            sb.append(" do_not_delete_during_merge");
        }
        String s = getDateString();
        if (s != null) {
            sb.append(' ');
            sb.append(s);
        }
        javaElement.addJavaDocLine(sb.toString());
    }

    /**
     * This method returns a formated date string to include in the Javadoc tag
     * and XML comments. You may return null if you do not want the date in
     * these documentation elements.
     *
     * @return a string representing the current timestamp, or null
     */
    protected String getDateString() {
        String result = null;
        if (!suppressDate) {
            result = currentDateStr;
        }
        return result;
    }

    @Override
    public void addClassComment(InnerClass innerClass, IntrospectedTable introspectedTable) {
        if (suppressAllComments) {
            return;
        }
        StringBuilder sb = new StringBuilder();
        innerClass.addJavaDocLine("/**");
        sb.append(" * ");
        sb.append(introspectedTable.getFullyQualifiedTable());
        sb.append(" ");
        sb.append(getDateString());
        innerClass.addJavaDocLine(sb.toString().replace("\n", " "));
        addJavadocTag(innerClass,true);
        innerClass.addJavaDocLine(" */");
    }

    @Override
    public void addEnumComment(InnerEnum innerEnum, IntrospectedTable introspectedTable) {
        if (suppressAllComments) {
            return;
        }
        StringBuilder sb = new StringBuilder();
        innerEnum.addJavaDocLine("/**");
        sb.append(" * ");
        sb.append(introspectedTable.getFullyQualifiedTable());
        innerEnum.addJavaDocLine(sb.toString().replace("\n", " "));
        innerEnum.addJavaDocLine(" */");
    }

    @Override
    public void addFieldComment(Field field, IntrospectedTable introspectedTable,
                                IntrospectedColumn introspectedColumn) {
        if (suppressAllComments) {
            return;
        }
        StringBuilder sb = new StringBuilder();
        field.addJavaDocLine("/**");
        sb.append(" * ");
        sb.append(introspectedColumn.getRemarks());
        field.addJavaDocLine(sb.toString().replace("\n", " "));
        field.addJavaDocLine(" */");
    }

    @Override
    public void addFieldComment(Field field, IntrospectedTable introspectedTable) {
        if (suppressAllComments) {
            return;
        }
        StringBuilder sb = new StringBuilder();
        field.addJavaDocLine("/**");
        sb.append(" * ");
        sb.append(introspectedTable.getFullyQualifiedTable());
        field.addJavaDocLine(sb.toString().replace("\n", " "));
        field.addJavaDocLine(" */");
    }

    @Override
    public void addGeneralMethodComment(Method method, IntrospectedTable introspectedTable) {
        if (suppressAllComments) {
            return;
        }
        //      method.addJavaDocLine("/**");
        //      addJavadocTag(method, false);
        //      method.addJavaDocLine(" */");
    }

    @Override
    public void addGetterComment(Method method, IntrospectedTable introspectedTable,
                                 IntrospectedColumn introspectedColumn) {
        if (suppressAllComments) {
            return;
        }
        method.addJavaDocLine("/**");
        StringBuilder sb = new StringBuilder();
        sb.append(" * ");
        sb.append(introspectedColumn.getRemarks());
        method.addJavaDocLine(sb.toString().replace("\n", " "));
        sb.setLength(0);
        sb.append(" * @return ");
        sb.append(introspectedColumn.getActualColumnName());
        sb.append(" ");
        sb.append(introspectedColumn.getRemarks());
        method.addJavaDocLine(sb.toString().replace("\n", " "));
        method.addJavaDocLine(" */");
    }

    @Override
    public void addSetterComment(Method method, IntrospectedTable introspectedTable,
                                 IntrospectedColumn introspectedColumn) {
        if (suppressAllComments) {
            return;
        }
        method.addJavaDocLine("/**");
        StringBuilder sb = new StringBuilder();
        sb.append(" * ");
        sb.append(introspectedColumn.getRemarks());
        method.addJavaDocLine(sb.toString().replace("\n", " "));
        Parameter parm = method.getParameters().get(0);
        sb.setLength(0);
        sb.append(" * @param ");
        sb.append(parm.getName());
        sb.append(" ");
        sb.append(introspectedColumn.getRemarks());
        method.addJavaDocLine(sb.toString().replace("\n", " "));
        method.addJavaDocLine(" */");
    }

    @Override
    public void addClassComment(InnerClass innerClass, IntrospectedTable introspectedTable, boolean markAsDoNotDelete) {
        if (suppressAllComments) {
            return;
        }
        StringBuilder sb = new StringBuilder();
        innerClass.addJavaDocLine("/**");
        sb.append(" * 描述:");
        sb.append(introspectedTable.getFullyQualifiedTable() + "表的实体类");
        innerClass.addJavaDocLine(sb.toString().replace("\n", " "));
        sb.setLength(0);
        sb.append(" * @version");
        innerClass.addJavaDocLine(sb.toString().replace("\n", " "));
        sb.setLength(0);
        sb.append(" * @author:  ");
        sb.append(systemPro.getProperty("user.name"));
        innerClass.addJavaDocLine(sb.toString().replace("\n", " "));
        sb.setLength(0);
        sb.append(" * @创建时间: ");
        sb.append(currentDateStr);
        innerClass.addJavaDocLine(sb.toString().replace("\n", " "));
        addJavadocTag(innerClass,true);
        innerClass.addJavaDocLine(" */");
    }
}

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
        PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
    <!--指定特定数据库的jdbc驱动jar包的位置 -->
    <classPathEntry
            location="D:\apache-maven-3.2.3\jar\1_taobao\mysql\mysql-connector-java\5.1.37\mysql-connector-java-5.1.37.jar"/>
    <context id="default" targetRuntime="MyBatis3">
        <!-- 这里的type里写的是你的实现类的类全路径 -->
        <commentGenerator type="cn.xxxx.DefaultCommentGenerator">
            <property name="suppressAllComments" value="false"/><!-- 是否取消注释 -->
            <property name="suppressDate" value="true"/> <!-- 是否生成注释代时间戳-->
        </commentGenerator>
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://xx.xx.xx.xx:3306/xx"
                        userId="xx"
                        password="xx">
        </jdbcConnection>
        <javaTypeResolver>
            <property name="forceBigDecimals" value="false"/>
        </javaTypeResolver>

<!--数据表实体类-->
        <javaModelGenerator targetPackage="com.xx.repository.entity" targetProject="src/main/java"/>
    <!--mapper.xml-->
        <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"/>
    <!--mybatis 接口类-->
        <javaClientGenerator targetPackage="com.xx.repository.dao" targetProject="src/main/java"
                             type="XMLMAPPER"/>


        <table schema="xxxx"
               tableName="pre_batch"
               domainObjectName="PreBatch"
               enableCountByExample="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               enableSelectByExample="false"
               selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="SELECT LAST_INSERT_ID()" identity="true"/>
        </table>
        <table schema="xxxx"
               tableName="pre_assign_rule"
               domainObjectName="PreAssignRule"
               enableCountByExample="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               enableSelectByExample="false"
               selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="SELECT LAST_INSERT_ID()" identity="true"/>
        </table>
        <table schema="xxxx"
               tableName="pre_sale_rule"
               domainObjectName="PreSaleRule"
               enableCountByExample="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               enableSelectByExample="false"
               selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="SELECT LAST_INSERT_ID()" identity="true"/>
        </table>

        <table schema="xxxx"
               tableName="pre_code"
               domainObjectName="PreCode"
               enableCountByExample="false"
               enableUpdateByExample="false"
               enableDeleteByExample="false"
               enableSelectByExample="false"
               selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="SELECT LAST_INSERT_ID()" identity="true"/>
        </table>
    </context>
</generatorConfiguration>
<think>嗯,用户现在遇到了两个问题:MyBatis Generator配置文件中URI未注册的问题,以及Tomcat连接器初始化失败的错误。我需要分别分析这两个问题,并给出解决方案。 首先看MyBatis Generator的URI未注册错误。用户提到的mybatis-generator.xml文件中可能存在XML命名空间或DTD/Schema的引用问题。常见的URI如http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd是否正确。可能的原因包括网络问题无法下载DTD文件,或者配置文件中URI拼写错误。解决方案可能需要检查URI的正确性,或者配置本地DTD以避免网络访问。例如,在配置文件中指定正确的DTD位置,或者在IDE中设置本地DTD路径。另外,可能需要在Maven的pom.xml中添加正确的插件配置,确保生成器能正确读取配置文件。 接下来是Tomcat的Connector初始化失败,报LifecycleException。之前用户提到过端口冲突、协议配置错误、类加载冲突等问题。需要检查端口占用情况,使用netstat或lsof命令查看8080端口是否被其他进程占用。如果是,修改server.xml中的端口号。另外,查看协议处理器的配置是否正确,比如是否缺少必要的SSL配置,或者使用了不支持的协议版本。例如,HTTP/2可能需要额外的库或配置。此外,类路径冲突,比如重复的servlet-api.jar,可能导致初始化失败,需要检查WEB-INF/lib和Tomcat的lib目录是否有冲突的jar包。 用户可能同时遇到这两个问题,需要分别处理。对于MyBatis Generator,确保配置文件中的URI正确,并配置本地DTD。对于Tomcat,检查端口和协议配置,解决类加载冲突。可能需要分步骤指导用户操作,例如修改配置文件,运行命令检查端口,清理Tomcat的work目录等。还要考虑用户是否在IDE中运行,或者是否有其他环境因素影响,比如防火墙阻止了DTD下载,或者Tomcat版本与配置不兼容。 用户可能已经尝试过一些方法但未成功,需要更详细的步骤,比如具体的XML配置示例,命令行操作,或者日志分析。同时,用户可能需要如何验证解决方案是否有效,比如重新生成MyBatis代码,或重启Tomcat查看错误是否消失。需要确保回答清晰,步骤具体,避免遗漏关键细节,比如文件路径、配置参数等。</think>### 一、MyBatis Generator配置文件URI未注册问题 #### 1. **验证DTD/Schema引用有效性** 检查$mybatis-generator.xml$头部声明是否包含正确DTD路径: ```xml <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> ``` **修复方案**: - 若存在网络限制,配置本地DTD缓存(IDEA:`Settings > Languages & Frameworks > Schemas and DTDs`添加映射) - 或改用XSD格式声明(推荐): ```xml <generatorConfiguration xmlns="http://mybatis.org/schema/generator" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://mybatis.org/schema/generator http://mybatis.org/schema/generator/mybatis-generator.xsd"> ``` #### 2. **Maven插件配置验证** 在pom.xml中确认插件版本与DTD匹配(以1.4.1版本为例): ```xml <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.4.1</version> <configuration> <configurationFile>src/main/resources/mybatis-generator.xml</configurationFile> <overwrite>true</overwrite> </configuration> </plugin> ``` 执行时添加参数强制下载: ```bash mvn mybatis-generator:generate -Dmybatis.generator.overwrite=true ``` #### 3. **典型配置错误案例** ```xml <!-- 错误示例:缺少数据库驱动类声明 --> <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver" connectionURL="jdbc:mysql://localhost:3306/test" userId="root" password="root"/> ``` **正确要求**: - 驱动包需存在于构建路径(通过`<dependencies>`显式声明) - MySQL 8.x必须使用`cj.jdbc.Driver`而非旧版`mysql.jdbc.Driver` --- ### 二、Tomcat连接器初始化失败(LifecycleException) #### 1. **端口冲突排查(扩展方案)** **动态检测可用端口**: ```bash # Linux/Mac nc -zv localhost 8080 2>&1 | grep succeeded # Windows Test-NetConnection -ComputerName localhost -Port 8080 ``` **server.xml多协议配置示例**: ```xml <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" maxParameterCount="1000"/> <!-- AJP协议备用 --> <Connector protocol="AJP/1.3" address="::1" port="8009" redirectPort="8443" /> ``` #### 2. **协议处理器深度排查** **HTTP/2配置验证**(需APR/native库支持): ```xml <Connector port="8443" protocol="org.apache.coyote.http11.Http11Nio2Protocol" maxThreads="150" SSLEnabled="true"> <UpgradeProtocol className="org.apache.coyote.http2.Http2Protocol"/> <SSLHostConfig> <Certificate certificateKeystoreFile="conf/keystore.p12" certificateKeystorePassword="changeit" type="PKCS12"/> </SSLHostConfig> </Connector> ``` **关键验证步骤**: 1. 检查`$CATALINA_HOME/bin`是否存在`tomcat-native`库(如`tcnative-1.dll`) 2. 确认JVM启动参数包含`-Djava.library.path=$CATALINA_HOME/bin` #### 3. **类加载冲突解决方案** **依赖树分析命令**: ```bash mvn dependency:tree -Dincludes=javax.servlet:* ``` **典型冲突模式**: - Servlet API重复:`javax.servlet:javax.servlet-api`(Tomcat自带)与项目依赖冲突 - 解决方案:在pom.xml中添加`<scope>provided</scope>` ```xml <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> <scope>provided</scope> </dependency> ``` --- ### 三、联合调试策略 #### 1. **日志增强配置** 在$conf/logging.properties$中增加调试级别: ```properties org.apache.catalina.core.ContainerBase.[Catalina].level = FINE org.apache.coyote.http11.level = ALL ``` #### 2. **最小化环境验证** 创建空Web应用测试连接器: ```bash mvn archetype:generate -DgroupId=com.test -DartifactId=minimal-web \ -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false ``` 部署到Tomcat验证基础功能,逐步添加组件定位冲突点。 --- ### 解决方案验证表 | 问题类型 | 验证方法 | 期望结果 | |--------------------------|-----------------------------------|--------------------------| | MyBatis Generator URI | 执行`mvn mybatis-generator:generate` | 无"URI not registered"错误 | | Tomcat端口冲突 | `curl -I http://localhost:8080` | 返回404而非连接拒绝 | | 协议处理器初始化 | 查看catalina.out日志 | 出现`ProtocolHandler [http-nio-8080]`启动成功信息 | --- ### 相关问题 1. 如何配置MyBatis Generator实现多表联合查询的代码生成? 2. Tomcat启用APR原生连接池有哪些性能优化参数? 3. 在Maven多模块项目中如何避免Servlet API的版本冲突?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值