在学习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配置通常如下:
运行时就会发生找不到RoleMapper.xml
文件的异常。
解决办法当然我们可以将映射文件及其目录放在该maven项目resources目录下,然后MyBatis配置如下:
我们也可以不改变原来的习惯,不移动映射文件,修改pom.xml文件,如下:
src/main/java
**/*.xml
true
这样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包,如下:
org.dom4j
dom4j
2.1.0
com.alibaba
fastjson
1.2.47
org.jsoup
jsoup
1.8.3
最后我们测试一下我们的工具类,现目录F:\书籍\ssm\project-lib
下有该项目依赖的几十个jar包:
运行我们的工具类后,会将这些依赖打印在控制台上,我们只要将其拷贝到pom.xml文件里,再用IDEA格式化一下就好了。
当然这个工具类会一些小bug,可能根据某些jar包文件名生成的依赖有错误,不过我们可以手动去修改那些错误生成的依赖。
通过以上步骤我们就可以将一个普通的java项目转发为maven项目。
参考:
工具类原文参见:https://my.oschina.net/zhhzhfya/blog/735050
我的Spring事务学习源码(使用的工具类也在此项目里)