Maven plugin常用配置

本文详细介绍了Maven项目的基础配置及各种插件配置方法,包括字符集统一设置、编译插件配置、测试插件配置等,帮助读者理解并掌握Maven项目构建流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

pom.xml基础配置:

    <properties>  
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>  
        <spring.framework.version>3.0.5.RELEASE</spring.framework.version>  
        <cxf.version>2.3.2</cxf.version>  
        <tiles.version>2.2.2</tiles.version>  
    </properties>  

我需要让整个项目统一字符集编码,就需要设定<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

如果我需要让spring统一版本号,可以设置这么个变量<spring.framework.version>3.0.5.RELEASE</spring.framework.version>

当然,maven不会那么乖乖的自动识别这些配置。

当然,<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>默认还是可以识别的! 


插件配置: 

资源配置插件:

复制代码
    <plugin>  
        <groupId>org.apache.maven.plugins</groupId>  
        <artifactId>maven-resources-plugin</artifactId>  
        <version>2.4.3</version>  
        <configuration>  
            <encoding>${project.build.sourceEncoding}</encoding>  
        </configuration>  
    </plugin>  
复制代码

xml、properties文件都是资源文件,编码的时候遇到中文总要进行转码!用什么编码?

UTF-8,那就记得强制<encoding>${project.build.sourceEncoding}</encoding>

虽然<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>默认可以识别,但是我还是觉得不放心。 

这些插件有时候即便是不配置,它也是默认存在的! 

编译插件: 
这个插件就是个默认配置,不过我还是谨慎的配置了jdk编译版本跟字符集设置:

复制代码
    <plugin>  
        <groupId>org.apache.maven.plugins</groupId>  
        <artifactId>maven-compiler-plugin</artifactId>  
        <version>2.0.2</version>  
        <configuration>  
            <source>1.6</source>  
            <target>1.6</target>  
            <encoding>${project.build.sourceEncoding}</encoding>  
        </configuration>  
    </plugin>  
复制代码

<source>1.6</source>:源代码编译版本; 
<target>1.6</target>:目标平台编译版本; 
<encoding>${project.build.sourceEncoding}</encoding>:字符集编码。 

如果你用eclipse建立maven项目时,新建的项目往往JDK版本很低——1.5!怎么办?修改settings.xml文件:

复制代码
    <profile>  
        <id>jdk-1.6</id>  
        <activation>  
            <activeByDefault>true</activeByDefault>  
            <jdk>1.6</jdk>  
        </activation>  
        <properties>  
            <maven.compiler.source>1.6</maven.compiler.source>  
            <maven.compiler.target>1.6</maven.compiler.target>  
            <maven.compiler.compilerVersion>1.6</maven.compiler.compilerVersion>  
        </properties>  
    </profile>  
复制代码

eclipse会很听话的构建一个JDK1.6版本的maven项目!

测试插件:

复制代码
    <plugin>  
        <groupId>org.apache.maven.plugins</groupId>  
        <artifactId>maven-surefire-plugin</artifactId>  
        <version>2.7.2</version>  
        <configuration>  
            <parallel>methods</parallel>  
            <threadCount>10</threadCount>  
            <argLine>-Dfile.encoding=UTF-8</argLine>  
            <!-- <skip>true</skip> -->  
            <!-- <testFailureIgnore>true</testFailureIgnore> -->  
        </configuration>  
    </plugin>  
复制代码

<parallel>methods</parallel>:方法级并发; 
<threadCount>10</threadCount>:是线程数,当前是10; 
<argLine>-Dfile.encoding=UTF-8</argLine>:就是参数命令行,这一行很关键。

测试插件有个小问题,它不依赖项目的字符集设置,它依赖于操作系统。如果你用命令行操作,看中文提示测试结果还好。

但在win+eclipse(UTF-8设置)下,那就是乱码了; 
<skip>true</skip>是忽略测试; 
<testFailureIgnore>true</testFailureIgnore>:忽略测试异常; 

测试报告插件: 
要测试,就要有报告,知晓测试覆盖率,这就需要clover:

复制代码
    <plugin>  
        <groupId>maven</groupId>  
        <artifactId>maven-clover-plugin</artifactId>  
        <version>2.4.2</version>  
        <configuration>  
            <encoding>${project.build.sourceEncoding}</encoding>  
        </configuration>  
    </plugin>  
复制代码

安全起见,我还是要强制写遍字符集编码设置:

<encoding>${project.build.sourceEncoding}</encoding> 

可以使用 mvn cobertura:cobertura 产生测试覆盖率报告! 

eclipse插件: 
在eclipse下进行maven项目开发,还是需要eclipse相应的插件:

复制代码
    <plugin>  
        <groupId>org.apache.maven.plugins</groupId>  
        <artifactId>maven-eclipse-plugin</artifactId>  
        <version>2.8</version>  
        <configuration>  
            <wtpmanifest>true</wtpmanifest>  
            <wtpapplicationxml>true</wtpapplicationxml>  
            <wtpversion>2.0</wtpversion>  
            <downloadSources>true</downloadSources>  
            <downloadJavadocs>true</downloadJavadocs>  
        </configuration>  
    </plugin>  
复制代码

 

<wtpmanifest>true</wtpmanifest>:产生manifest文件 
<wtpapplicationxml>true</wtpapplicationxml>:产生web.xml文件 
<wtpversion>2.0</wtpversion>:这是eclipse里面的wtp版本 
<downloadSources>true</downloadSources>:下载源代码 
<downloadJavadocs>true</downloadJavadocs>:下载源码文档 

虽然这么配置了,但是由maven项目转为eclipse的wtp类型的项目时,所产生的文件根本没有实际意义。

web.xml文件的servlet版本很低,也许是我没有配置。对应的xml字符集的头标识也没有。 

war包插件: 
既然是web项目,就需要打war包,那就需要这个插件:

复制代码
    <plugin>  
        <groupId>org.apache.maven.plugins</groupId>  
        <artifactId>maven-war-plugin</artifactId>  
        <version>2.1.1</version>  
        <configuration>  
            <encoding>${project.build.sourceEncoding}</encoding>  
            <warName>platform</warName>  
            <webappDirectory>${project.build.directory}/platform</webappDirectory>  
            <warSourceDirectory>WebContent</warSourceDirectory>  
        </configuration>  
    </plugin>  
复制代码

<encoding>${project.build.sourceEncoding}</encoding>强制字符集编码 
<warName>platform</warName>war包名字——platform.war 
<webappDirectory>${project.build.directory}/platform</webappDirectory>产生war前,用于存放构建war包的目录——target/platform。 
<warSourceDirectory>WebContent</warSourceDirectory>:我把web工程搞成了eclipse下的WTP类型。我不喜欢maven产生的webapp目录,更喜欢WebContent! 

tomcat插件: 
我习惯于用tomcat作为JSP容器,对jetty多少有点陌生。不但如此,我还通过在Bamboo中配置命令让这个应用可以在tomcat中定时部署:

复制代码
    <plugin>  
        <groupId>org.codehaus.mojo</groupId>  
        <artifactId>tomcat-maven-plugin</artifactId>  
        <configuration>  
            <charset>${project.build.sourceEncoding}</charset>  
            <url>http://localhost:8080/manager</url>  
            <server>tomcat.server</server>  
            <path>/platform</path>  
            <port>8080</port>  
            <warFile>${project.build.directory}/platform.war</warFile>  
            <warSourceDirectory>WebContent</warSourceDirectory>  
            <uriEncoding>${project.build.sourceEncoding}</uriEncoding>  
        </configuration>  
    </plugin>  
复制代码

<charset>${project.build.sourceEncoding}</charset>:字符集强制编码 
<url>http://localhost:8080/manager/text</url>:我这里已经使用了Tomcat7,如果是Tomcat6就不需要/text! 
<server>tomcat.server</server>这是个用户名设置,需要配置maven的settings.xml文件:

复制代码
    <servers>  
        <server>  
            <id>tomcat.server</id>  
            <username>admin</username>  
            <password>123456</password>  
        </server>  
    </servers>  
复制代码

别急,这时候还没完! 
在tomcat的tomcat-users.xml中补充相关内容:

    <role rolename="manager-gui"/>  
    <role rolename="magager-script"/>  
    <user username="admin" password="123456" roles="manager-gui,manager-script" />  

这是Tomat7的配置,在Tomcat6中应该是:

    <role rolename="manager"/>  
    <user username="admin" password="123456" roles="manager" />  

<port>8080</port>:运行时端口 
<path>/platform</path>:是运行时路径——http://host:port/platform 
<warFile>${project.build.directory}/platform.war</warFile>:我们以war包方式发布,需要指定war包路径。 
<warSourceDirectory>WebContent</warSourceDirectory>:同时要指定war包源码路径。这里我使用eclipse的WTP类型工程WebContent目录。 
<uriEncoding>${project.build.sourceEncoding}</uriEncoding>:强制字符集编码! 

插件命令:

复制代码
    #Run Tomcat  
    mvn tomcat:run  
    #Stop Tomcat  
    #Deploy Tomcat  
    mvn tomcat:deploy  
    #Undeploy Tomcat  
    mvn tomcat:undeploy  
    #Redeploy Tomcat  
    mvn tomcat:redeploy  
复制代码

对于我来说,我最常用的就是mvn tomcat:run 跟 mvn tomcat:redeploy,而且我会把他们配置在eclipse中:

加上个-X,我可以清楚的知道每一个插件的配置,以及详细的Debug信息!

<think>好的,用户现在问的是“Maven Plugin导入”,看起来他可能在使用Maven插件时遇到了问题,或者想了解如何正确导入和配置Maven插件。之前他遇到了关于MyBatis Generator插件实例化失败的问题,现在可能想更深入地理解如何正确使用Maven插件。 首先,我需要确认用户的具体需求。他可能是在导入插件时遇到了错误,比如依赖问题或者配置错误,或者他可能只是需要一般性的指导如何导入和使用Maven插件。根据他之前的提问历史,可能还是和MyBatis Generator相关,但也有可能扩展到其他插件。 接下来,我应该回顾Maven插件的基础知识。Maven插件通常通过在pom.xml中的<plugins>部分进行配置。每个插件有groupId、artifactId和version,可能还需要配置executions和configuration。用户可能需要知道如何正确添加这些配置,避免常见的错误,比如版本不匹配或缺少必要配置。 用户之前遇到的错误是“Cannot instantiate”,这可能和插件的依赖或类路径有关。所以在解释导入插件时,需要强调依赖管理、作用域(scope)以及如何确保插件的正确引入。此外,可能还需要提到如何解决版本冲突,或者如何添加自定义插件。 另外,用户可能需要知道如何执行插件的目标(goals),无论是绑定到生命周期阶段还是手动执行。例如,MyBatis Generator插件通常绑定到generate-sources阶段,但用户可能需要手动触发。 还要考虑常见的错误场景,比如插件配置错误、依赖缺失、版本不兼容等,并在指南中提供相应的解决方案。例如,检查插件版本是否与项目其他依赖兼容,确保插件的依赖项在类路径中,或者正确配置<executions>部分。 同时,用户可能对Maven插件的工作原理不太清楚,需要简要解释插件生命周期和阶段,以及如何通过命令行执行插件目标。例如,使用mvn mybatis-generator:generate来手动运行生成器。 最后,需要提供实际的配置示例,展示正确的pom.xml片段,并解释每个部分的作用。例如,配置文件的路径、是否覆盖现有文件、详细日志等。同时,可以给出常见插件的例子,如Spring Boot插件、编译器插件等,帮助用户理解不同插件的配置方式。 总结来说,用户需要一个从基础到进阶的Maven插件导入和配置指南,涵盖基本配置、依赖管理、常见错误解决和实际示例。需要结构清晰,分步骤讲解,确保用户能够一步步解决问题或正确配置插件。</think>--- ### **Maven插件导入完整指南** --- #### **一、Maven插件基础概念** **核心作用**: Maven插件是用于扩展构建流程的工具,可执行代码生成、资源处理、测试等任务。每个插件对应一个或多个**目标(Goal)**,例如: - `compiler:compile`(编译Java代码) - `surefire:test`(执行单元测试) - `mybatis-generator:generate`(生成MyBatis代码) --- #### **二、插件导入标准流程** **步骤1:在`pom.xml`中添加插件声明** ```xml <build> <plugins> <!-- 示例:添加MyBatis Generator插件 --> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.4.2</version> <configuration> <configurationFile>src/main/resources/generatorConfig.xml</configurationFile> </configuration> </plugin> </plugins> </build> ``` **关键参数说明**: - `<groupId>`: 插件所属组织标识(类似Java包名) - `<artifactId>`: 插件的唯一名称 - `<version>`: 必须精确指定的版本号 - `<configuration>`: 插件运行时的自定义配置 --- #### **三、插件绑定到构建生命周期** **典型场景**:将插件目标关联到Maven生命周期阶段(`compile`, `test`, `package`等) **示例**:在`generate-sources`阶段自动执行代码生成 ```xml <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.4.2</version> <executions> <execution> <id>generate-code</id> <phase>generate-sources</phase> <goals> <goal>generate</goal> </goals> </execution> </executions> </plugin> ``` --- #### **四、手动执行插件目标** **命令格式**: ```bash mvn <插件前缀>:<目标> [参数] # 或 mvn <groupId>:<artifactId>:<version>:<目标> ``` **示例**: ```bash # 使用插件前缀执行 mvn mybatis-generator:generate # 使用完整坐标执行 mvn org.mybatis.generator:mybatis-generator-maven-plugin:1.4.2:generate ``` --- #### **五、依赖管理技巧** **场景**:当插件需要额外依赖时(如自定义模板、数据库驱动) **正确配置方式**: ```xml <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.4.2</version> <dependencies> <!-- 添加MySQL驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.33</version> </dependency> <!-- 添加自定义模板 --> <dependency> <groupId>com.company</groupId> <artifactId>mybatis-templates</artifactId> <version>1.0.0</version> </dependency> </dependencies> </plugin> ``` --- #### **六、常见问题解决方案** **问题1:插件无法下载** - **现象**:`Could not find artifact ... in central` - **解决方案**: 1. 检查Maven镜像配置(`settings.xml`) 2. 确认插件版本是否存在 3. 手动添加第三方仓库配置: ```xml <pluginRepositories> <pluginRepository> <id>custom-repo</id> <url>https://repo.example.com</url> </pluginRepository> </pluginRepositories> ``` **问题2:插件版本冲突** - **现象**:`NoSuchMethodError` 或 `ClassNotFoundException` - **解决方案**: ```xml <dependencyManagement> <dependencies> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.4.2</version> </dependency> </dependencies> </dependencyManagement> ``` --- #### **七、企业级最佳实践** 1. **统一版本管理** 在父POM中集中管理插件版本: ```xml <pluginManagement> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.11.0</version> </plugin> </plugins> </pluginManagement> ``` 2. **多环境配置** 使用Maven profiles实现环境隔离: ```xml <profiles> <profile> <id>dev</id> <build> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <configuration> <jdbcURL>jdbc:mysql://dev-db:3306/test</jdbcURL> </configuration> </plugin> </plugins> </build> </profile> </profiles> ``` 3. **安全配置** 敏感信息(数据库密码)通过外部文件注入: ```xml <configuration> <properties>${basedir}/src/main/resources/generator.properties</properties> </configuration> ``` --- #### **八、调试与优化** **调试命令**: ```bash mvn -X clean install # 显示完整调试信息 mvn help:effective-pom # 查看合并后的最终POM # 生成依赖树分析冲突 mvn dependency:tree -Dincludes=org.mybatis.generator ``` **性能优化**: ```xml <configuration> <skip>${skip.generator}</skip> <!-- 通过参数控制执行 --> </configuration> ``` 运行时添加参数跳过插件: ```bash mvn install -Dskip.generator=true ``` --- ### **附:常用核心插件列表** | 插件名称 | 作用 | 示例坐标 | |---------------------------|---------------------------------|-----------------------------------------| | Maven Compiler Plugin | Java源码编译 | `org.apache.maven.plugins:maven-compiler-plugin:3.11.0` | | Maven Surefire Plugin | 执行单元测试 | `org.apache.maven.plugins:maven-surefire-plugin:3.1.2` | | Spring Boot Maven Plugin | 打包可执行JAR | `org.springframework.boot:spring-boot-maven-plugin:3.1.0` | | Jacoco Maven Plugin | 代码覆盖率分析 | `org.jacoco:jacoco-maven-plugin:0.8.10` | --- 通过以上规范化的插件导入方式,可确保构建流程的稳定性和可维护性。如遇特殊问题,建议通过`mvn -X`获取详细日志进行深度分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值