最近在寫一個通用工具的java版sdk柒爵,在構(gòu)建jar包時接觸到了maven友扰。
一彤叉、Maven是什么
最初對maven的印象,是覺得它和php的composer很像村怪,因為自己主要用了pom.xml的dependency功能秽浇。逐漸了解之后發(fā)現(xiàn)maven要比composer強大很多,composer主要用來管理php項目的依賴包甚负,相對于maven來說柬焕,管理依賴只是maven提供的其中一項功能货抄。
依照官方說法稚疹,Maven是一個軟件項目管理和綜合工具侣滩,基于項目對象模型(pom.xml)的概念掺涛,可以完成創(chuàng)建項目、管理依賴居夹、運行測試嚎京、生成文檔等一系列工作诚隙。
二没宾、Maven項目目錄結(jié)構(gòu)
maven構(gòu)建的項目目錄結(jié)構(gòu)是固定的:
src
----main
--------java
--------resources
----test
--------java
--------resources
main中java存放源代碼凌彬,resources存放配置文件;test中java存放測試源碼循衰,resources中存放配置文件。
三褐澎、Maven核心pom.xml
maven的核心是pom.xml会钝,通過在pom中填寫配置來管理依賴、編譯等工作工三,自己在項目中目前只用了一部分功能迁酸。
管理項目依賴,是通過在pom.xml中增加dependency配置來完成的俭正,如:
<dependencies>
<dependency>
<groupId>com.googlecode.libphonenumber</groupId>
<artifactId>libphonenumber</artifactId>
<version>8.8.9</version>
</dependency>
<dependency>
<groupId>net.sf.json-lib</groupId>
<artifactId>json-lib</artifactId>
<version>2.3</version>
<classifier>jdk15</classifier>
</dependency>
</dependencies>
通過上面的配置奸鬓,我的項目成功導(dǎo)入了libphonenumber和json-lib。
默認(rèn)情況下掸读,Maven從Maven中央倉庫下載所有依賴關(guān)系串远。但是有些依賴可能是中央倉庫沒有的宏多,是需要從其他地方下載的,此時需要通過repositories配置澡罚。
<repositories>
<repository>
<id>java.net</id>
<url>https://maven.java.net/content/repositories/public/</url>
</repository>
</repositories>
四伸但、常用命令
- mvn compile在根目錄生成target文件
- mvn clean將根目錄下生成的target文件移除
- mvn install將本地工程打包成jar包,放入到本地倉庫中留搔。
- mvn deploy將最終版本的jar包拷貝到遠程的repository
五更胖、開發(fā)中遇到的問題
1、用Intellij創(chuàng)建maven項目后隔显,每次更新pom.xml后却妨,jdk自動變?yōu)?.5
解決方法:intellij創(chuàng)建maven默認(rèn)會使用jdk1.5版本,需要在pom中指定build時想用的jdk版本括眠。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<source>1.9</source>
<target>1.9</target>
</configuration>
</plugin>
</plugins>
</build>
2彪标、依賴中引入了log4j,編譯執(zhí)行時一直報log4j的錯誤哺窄。
解決方法:在src/main/resources下新建log4j.properties配置文件捐下,設(shè)置log4j的一些參數(shù)。
#定義輸出級別
log4j.rootLogger=DEBUG,Console,File
#日志輸出方式:控制臺輸出
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target=System.out
log4j.appender.Console.Encoding=GBK
#可以靈活地指定布局模式
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
#log4j.appender.Console.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss.SSS} -%p (%F\:%L)- %m%n
#打印格式栗子:2017-08-11 15:36 -DEBUG (HttpServletBean.java:174)- Servlet 'mvc' configured successfully
log4j.appender.Console.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm} -%p (%F\:%L)- %m%n
### 打印SQL ###
#log4j.logger.com.ibatis=DEBUG
#log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG
#log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG
#log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
#log4j.logger.java.sql.Connection=DEBUG
#log4j.logger.java.sql.Statement=DEBUG
#log4j.logger.java.sql.PreparedStatement=DEBUG
#log4j.logger.java.sql.ResultSet=DEBUG
log4j.appender.File = org.apache.log4j.FileAppender
log4j.appender.File.File = log4j.log
log4j.appender.File.layout = org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
3萌业、Intellij下編譯生成jar包
- 菜單中選擇File->project structure
- 選擇Artifacts坷襟,點擊+號,選擇jar生年,再選擇from modules with dependencies
- 選擇一個Main class
- 菜單中選擇Build->make project
- 生成的jar包在out目錄下