在学习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事务学习源码(使用的工具类也在此项目里)