在学习Spring事务时,我参考的书的源码不是maven项目,整本书依赖的100多个jar包都在一个文件夹里,我本来对spring每个模块的学习源码都放在一个Github仓库里,每一个项目都是maven项目,这样想要将项目转化为maven项目,就要做很大的工作量来写项目的依赖。不过经过查找,在网上找到了一个大神写的工具类能根据依赖的jar文件名转化为maven依赖,过程如下。
将项目转化为maven项目
在IDEA里,右键单击项目->Add Framework Supprot->Maven->OK
会自动将项目转化成Maven的项目结构,并自动生成pom.xml文件。
我们知道src目录是我们的源文件目录,项目源文件经过IDE(不管是IDEA还是eclipse)将编译后都会放到classes目录下,但IDEA编译源文件后,默认不会把src目录下的任何.xml文件放到classes目录下,而我们在使用MyBatis持久层框架时,映射文件都习惯放到src目录相应的包下。
然后MyBatis配置通常如下:
<mapper resource="com/ssm/chapter13/sqlMapper/RoleMapper.xml"/>
运行时就会发生找不到RoleMapper.xml
文件的异常。
解决办法当然我们可以将映射文件及其目录放在该maven项目resources目录下,然后MyBatis配置如下:
<mapper resource="sqlMapper/RoleMapper.xml"/>
我们也可以不改变原来的习惯,不移动映射文件,修改pom.xml文件,如下:
<build><resources><resource><directory>src/main/java</directory><includes><include>**/*.xml</include></includes><filtering>true</filtering></resource></resources>
</build>
这样IDEA在编译我们的源代码时,就会把映射文件也拷到classes目录下。
一个生成依赖的工具类
虽然IDEA为我们生成了pom.xml文件,但我们的项目依赖的jar文件并没有在pom.xml文件里生成,如果我们项目依赖的jar包非常多的话,那么我们就得到maven中央仓库里一个个地查找,工作量很大。下面是一个小工具类,能够根据jar包文件名,生成格式良好的maven依赖。
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包,如下:
<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格式化一下就好了。
当然这个工具类会一些小bug,可能根据某些jar包文件名生成的依赖有错误,不过我们可以手动去修改那些错误生成的依赖。
通过以上步骤我们就可以将一个普通的java项目转发为maven项目。
参考:
工具类原文参见:https://my.oschina.net/zhhzhfya/blog/735050
我的Spring事务学习源码(使用的工具类也在此项目里)