以下是结合自己项目的Maven配置
<!--表示Maven用来在本地储存信息的本地仓库的目录。默认是用户文件夹下面的.m2/repository目录 -->
<localRepository>D:\maven\maven_workspace</localRepository>
<!--表示是否使用交互模式,默认是true;如果设为false,那么当Maven需要用户进行输入的时候,它会使用一个默认值 -->
<interactiveMode>true</interactiveMode>
<!--表示是否离线,默认是false。这个属性表示在Maven进行项目编译和部署等操作时是否允许Maven进行联网来下载所需要的信息-->
<offline>false</offline>
<!--在pluginGroups元素下面可以定义一系列的pluginGroup元素。表示当通过plugin的前缀来解析plugin的时候到哪里寻找。pluginGroup元素指定的是plugin的groupId。默认情况下,Maven会自动把org.apache.maven.plugins和org.codehaus.mojo添加到pluginGroups下-->
<pluginGroups></pluginGroups >
<!--其下面可以定义一系列的proxy子元素,表示Maven在进行联网时需要使用到的代理。当设置了多个代理的时候第一个标记active为true的代理将会被使用-->
<proxies>
<proxy>
<id>xxx</id>
<active>true</active>
<protocol>http</protocol>
<username>用户名</username>
<password>密码</password>
<host>代理服务器地址</host>
<port>代理服务器的端口</port>
<nonProxyHosts>不使用代理的主机</nonProxyHosts>
</proxy>
</proxies>
<!--连接到远程服务器-->
<servers>
<server>
<!--这是server的id(注意不是用户登陆的id)-->
<id>tomcat</id>
<!--用户名-->
<username>admin</username>
<!--密码-->
<password>admin</password>
</server>
<server>
<id>central</id>
<username>admin</username>
<password>admin</password>
</server>
<server>
<id>releases</id>
<username>admin</username>
<password>admin</password>
</server>
<server>
<id>snapshots</id>
<username>admin</username>
<password>admin</password>
</server>
<server>
<id>hbrepos</id>
<username>admin</username>
<password>admin</password>
</server>
</servers>
<!--用于定义一系列的远程仓库的镜像。我们可以在pom中定义一个下载工件的时候所使用的远程仓库。但是有时候这个远程仓库会比较忙,所以这个时候人们就想着给它创建镜像以缓解远程仓库的压力,也就是说会把对远程仓库的请求转换到对其镜像地址的请求。每个远程仓库都会有一个id,这样我们就可以创建自己的mirror来关联到该仓库,那么以后需要从远程仓库下载工件的时候Maven就可以从我们定义好的mirror站点来下载,这可以很好的缓解我们远程仓库的压力。在我们定义的mirror中每个远程仓库都只能有一个mirror与它关联,也就是说你不能同时配置多个mirror的mirrorOf指向同一个repositoryId-->
<mirrors>
<mirror>
<!--是用来区别mirror的,所有的mirror不能有相同的id-->
<id>mirrorId</id>
<!--用来表示该mirror是关联的哪一个仓库,其值为其关联仓库的id。当要同时关联多个仓库时,这多个仓库之间可以用逗号隔开;当要关联所有的仓库时,可以使用“*”表示;当要关联除某一个仓库以外的其他所有仓库时,可以表示为“*,!repositoryId”;当要关联不是localhost或用file请求的仓库时,可以表示为“external:*”-->
<mirrorOf>repositoryId</mirrorOf>
<name>定义一个容易看懂的名称 </name>
<!--表示该镜像的url。当Maven在建立系统的时候就会使用这个url来连接到我们的远程仓库-->
<url>http://my.repository.com/repo/path</url>
</mirror>
</mirrors>
<!--根据环境参数来调整的构件的配置-->
<!--用于指定一系列的profile。profile元素由activation、repositories、pluginRepositories和properties四个元素组成。当一个profile在settings.xml中是处于活动状态并且在pom.xml中定义了一个相同id的profile时,settings.xml中的profile会覆盖pom.xml中的profile-->
<profiles>
<!--所有的约束条件都满足的时候就会激活这个profile-->
<profile>
<id>releases</id>
<!--用于定义远程仓库的,当该profile是激活状态的时候,这里面定义的远程仓库将作为当前pom的远程仓库-->
<repositories>
<repository>
<id>releases</id>
<name></name>
<url>http://maven.XXXXX.net/content/groups/public/</url>
<layout>default</layout>
</repository>
</repositories>
<!--在Maven中有两种类型的仓库,一种是存储工件的仓库,另一种就是存储plugin插件的仓库。pluginRepositories的定义和repositories的定义类似,它表示Maven在哪些地方可以找到所需要的插件-->
<pluginRepositories>
<pluginRepository>
<id>releases</id>
<name></name>
<url>http://maven.XXXXX.net/content/groups/public/</url>
<layout>default</layout>
</pluginRepository>
</pluginRepositories>
</profile>
<profile>
<id>jdk17</id>
<!--是profile中最重要的元素。跟pom.xml中的profile一样,settings.xml中的profile也可以在特定环境下改变一些值,而这些环境是通过activation元素来指定的-->
<activation>
<!--当其值为true的时候表示如果没有其他的profile处于激活状态的时候,该profile将自动被激活-->
<activeByDefault>true</activeByDefault>
<jdk>1.8</jdk>
</activation>
<!--用于定义属性键值对的。当该profile是激活状态的时候,properties下面指定的属性都可以在pom.xml中使用-->
<properties>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
</properties>
</profile>
</profiles>
<!--无论环境如何,激活与之匹配的profiles(pom.xml)-->
<activeProfiles>
<activeProfile>releases</activeProfile>
</activeProfiles>