在學習Spring事務時,我參考的書的源碼不是maven項目,整本書依賴的100多個jar包都在一個文件夾裏,我原本對spring每一個模塊的學習源碼都放在一個Github倉庫裏,每個項目都是maven項目,這樣想要將項目轉化爲maven項目,就要作很大的工做量來寫項目的依賴。不過通過查找,在網上找到了一個大神寫的工具類能根據依賴的jar文件名轉化爲maven依賴,過程以下。java
在IDEA裏,右鍵單擊項目->Add Framework Supprot->Maven->OK
會自動將項目轉化成Maven的項目結構,並自動生成pom.xml文件。node
咱們知道src目錄是咱們的源文件目錄,項目源文件通過IDE(無論是IDEA仍是eclipse)將編譯後都會放到classes目錄下,但IDEA編譯源文件後,默認不會把src目錄下的任何.xml文件放到classes目錄下,而咱們在使用MyBatis持久層框架時,映射文件都習慣放到src目錄相應的包下。
而後MyBatis配置一般以下:git
<mapper resource="com/ssm/chapter13/sqlMapper/RoleMapper.xml"/>
運行時就會發生找不到RoleMapper.xml
文件的異常。
解決辦法固然咱們能夠將映射文件及其目錄放在該maven項目resources目錄下,而後MyBatis配置以下:github
<mapper resource="sqlMapper/RoleMapper.xml"/>
咱們也能夠不改變原來的習慣,不移動映射文件,修改pom.xml文件,以下:spring
<build> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> <filtering>true</filtering> </resource> </resources> </build>
這樣IDEA在編譯咱們的源代碼時,就會把映射文件也拷到classes目錄下。sql
雖然IDEA爲咱們生成了pom.xml文件,但咱們的項目依賴的jar文件並無在pom.xml文件裏生成,若是咱們項目依賴的jar包很是多的話,那麼咱們就獲得maven中央倉庫裏一個個地查找,工做量很大。下面是一個小工具類,可以根據jar包文件名,生成格式良好的maven依賴。json
package top.sqmax; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.util.jar.JarInputStream; import java.util.jar.Manifest; import org.dom4j.Element; import org.dom4j.dom.DOMElement; import org.jsoup.Jsoup; import com.alibaba.fastjson.JSONObject; public class MakePomFromJars { public static void main(String[] args) throws FileNotFoundException, IOException { Element dependencys = new DOMElement("dependencys"); File dir = new File("F:\\書籍\\ssm\\project-lib"); for (File jar : dir.listFiles()) { JarInputStream jis = new JarInputStream(new FileInputStream(jar)); Manifest mainmanifest = jis.getManifest(); jis.close(); if (mainmanifest == null) { System.err.println(jar.getName()); continue; } String bundleName = mainmanifest.getMainAttributes().getValue("Bundle-Name"); String bundleVersion = mainmanifest.getMainAttributes().getValue("Bundle-Version"); Element ele = null; System.out.println(jar.getName()); StringBuffer sb = new StringBuffer(jar.getName()); if (bundleName != null) { bundleName = bundleName.toLowerCase().replace(" ", "-"); sb.append(bundleName+"\t").append(bundleVersion); ele = getDependices(bundleName, bundleVersion); System.out.println(sb.toString()); System.out.println(ele.asXML()); } if (ele == null || ele.elements().size() == 0) { bundleName = ""; bundleVersion = ""; String[] ns = jar.getName().replace(".jar", "").split("-"); for (String s : ns) { if (Character.isDigit(s.charAt(0))) { bundleVersion += s + "-"; } else { bundleName += s + "-"; } } if (bundleVersion.endsWith("-")) { bundleVersion = bundleVersion.substring(0, bundleVersion.length() - 1); } if (bundleName.endsWith("-")) { bundleName = bundleName.substring(0, bundleName.length() - 1); } ele = getDependices(bundleName, bundleVersion); sb.setLength(0); sb.append(bundleName+"\t").append(bundleVersion); System.out.println(sb.toString()); System.out.println(ele.asXML()); } ele = getDependices(bundleName, bundleVersion); if (ele.elements().size() == 0) { ele.add(new DOMElement("groupId").addText("not find")); ele.add(new DOMElement("artifactId").addText(bundleName)); ele.add(new DOMElement("version").addText(bundleVersion)); } dependencys.add(ele); System.out.println(); } System.out.println(dependencys.asXML()); } public static Element getDependices(String key, String ver) { Element dependency = new DOMElement("dependency"); // 設置代理 // System.setProperty("http.proxyHost", "127.0.0.1"); // System.setProperty("http.proxyPort", "8090"); try { String url = "http://search.maven.org/solrsearch/select?q=a%3A%22" + key + "%22%20AND%20v%3A%22" + ver + "%22&rows=3&wt=json"; org.jsoup.nodes.Document doc = Jsoup.connect(url).ignoreContentType(true).timeout(30000).get(); String elem = doc.body().text(); JSONObject response = JSONObject.parseObject(elem).getJSONObject("response"); if (response.containsKey("docs") && response.getJSONArray("docs").size() > 0) { JSONObject docJson = response.getJSONArray("docs").getJSONObject(0); Element groupId = new DOMElement("groupId"); Element artifactId = new DOMElement("artifactId"); Element version = new DOMElement("version"); groupId.addText(docJson.getString("g")); artifactId.addText(docJson.getString("a")); version.addText(docJson.getString("v")); dependency.add(groupId); dependency.add(artifactId); dependency.add(version); } } catch (Exception e) { e.printStackTrace(); } return dependency; } }
注意這個工具類還要依賴3個jar包,以下:app
<dependency> <groupId>org.dom4j</groupId> <artifactId>dom4j</artifactId> <version>2.1.0</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.47</version> </dependency> <dependency> <groupId>org.jsoup</groupId> <artifactId>jsoup</artifactId> <version>1.8.3</version> </dependency>
最後咱們測試一下咱們的工具類,現目錄F:\書籍\ssm\project-lib
下有該項目依賴的幾十個jar包:框架
運行咱們的工具類後,會將這些依賴打印在控制檯上,咱們只要將其拷貝到pom.xml文件裏,再用IDEA格式化一下就行了。dom
固然這個工具類會一些小bug,可能根據某些jar包文件名生成的依賴有錯誤,不過咱們能夠手動去修改那些錯誤生成的依賴。
經過以上步驟咱們就能夠將一個普通的java項目轉發爲maven項目。
參考:
工具類原文參見:https://my.oschina.net/zhhzhfya/blog/735050
個人Spring事務學習源碼(使用的工具類也在此項目裏)