maven打包生成doc文档和打包源码
在pom.xml中加入如下插件
<build> <plugins> <!-- 文档 插件 --> <plugin> <groupId> or下g.apache.maven.plugins </groupId> <artifactId> maven-javadoc-plugin </artifactId> <version> 2.7 </version> <executions> <execution> <id> attach-javadocs </id> <goals> <goal> jar </goal> </goals> <configuration> <additionalparam> -Xdoclint:none </additionalparam> </configuration> </execution> </executions> </plugin> <!-- 打包源码插件 --> <plugin> <groupId> org.apache.maven.plugins </groupId> <artifactId> maven-source-plugin </artifactId> <version> 2.1.2 </version> <configuration> <attach> true </attach> </configuration> <executions> <execution> <phase> compile </phase> <goals> <goal> jar </goal> </goals> </execution> </executions> </plugin> </plugins> </build>
如上的此种打包方式打包成如下这种分为3个包,源码包,文档包,和不包含源码的war包
如果想把源码和编译后的打包到一个war里面,
将打包源码插件改为 如下插件
<plugin> <groupId> org.apache.maven.plugins </groupId> <artifactId> maven-resources-plugin </artifactId> <version> 2.3 </version> <executions> <execution> <id> copy-resources </id> <phase> process-resources </phase> <goals> <goal> copy-resources </goal> </goals> <configuration> <outputDirectory> ${project.build.outputDirectory} </outputDirectory> <resources> <resource> <directory> src/main/java </directory> <includes> <include> **/*.java </include> </includes> </resource> </resources> </configuration> </execution> </executions> </plugin>
插件maven-resources-plugin默认处理资源和测试资源,把资源加入到文件夹${project.build.outputDirectory},这个引用表示项目的输出文件夹。
一般是项目的WEB-INF\classes文件夹。等到打包的时候,就把这个文件夹里面的内容打包成jar文件。所以想要把源代码打包到jar文件里面
就需要把源代码当作资源文件添加到文件夹${project.build.outputDirectory}。
打包完成只会生成一个war包,
而查看war包中包含源码的方式如下
maven 打包报错 生成javadoc 时有问题
项目是基于maven管理的,一直打包都好着呢,
今天打包莫名奇妙的报了一大堆错误
[ ERROR ] java . lang . ClassCastException : com . sun . tools . javadoc . ClassDocImpl cannot be cast to com . sun . javadoc . AnnotationTypeDoc [ ERROR ] at com . sun . tools . javadoc . AnnotationDescImpl . annotationType ( AnnotationDescImpl . java : 46 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . util . Util . isDeprecated ( Util . java : 811 ) [ ERROR ] at com . sun . tools . doclets . formats . html . TagletWriterImpl . deprecatedTagOutput ( TagletWriterImpl . java : 85 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . taglets . DeprecatedTaglet . getTagletOutput ( DeprecatedTaglet . java : 40 ) [ ERROR ] at com . sun . tools . doclets . formats . html . MethodWriterImpl . writeDeprecated ( MethodWriterImpl . java : 166 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . MethodBuilder . buildDeprecationInfo ( MethodBuilder . java : 183 ) [ ERROR ] at sun . reflect . GeneratedMethodAccessor3 . invoke ( Unknown Source ) [ ERROR ] at sun . reflect . DelegatingMethodAccessorImpl . invoke ( DelegatingMethodAccessorImpl . java : 25 ) [ ERROR ] at java . lang . reflect . Method . invoke ( Method . java : 597 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . MethodBuilder . invokeMethod ( MethodBuilder . java : 109 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . AbstractBuilder . build ( AbstractBuilder . java : 90 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . AbstractMemberBuilder . build ( AbstractMemberBuilder . java : 56 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . MethodBuilder . buildMethodDoc ( MethodBuilder . java : 150 ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke0 ( Native Method ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke ( NativeMethodAccessorImpl . java : 39 ) [ ERROR ] at sun . reflect . DelegatingMethodAccessorImpl . invoke ( DelegatingMethodAccessorImpl . java : 25 ) [ ERROR ] at java . lang . reflect . Method . invoke ( Method . java : 597 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . MethodBuilder . invokeMethod ( MethodBuilder . java : 109 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . AbstractBuilder . build ( AbstractBuilder . java : 90 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . AbstractMemberBuilder . build ( AbstractMemberBuilder . java : 56 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . ClassBuilder . buildMethodDetails ( ClassBuilder . java : 322 ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke0 ( Native Method ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke ( NativeMethodAccessorImpl . java : 39 ) [ ERROR ] at sun . reflect . DelegatingMethodAccessorImpl . invoke ( DelegatingMethodAccessorImpl . java : 25 ) [ ERROR ] at java . lang . reflect . Method . invoke ( Method . java : 597 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . ClassBuilder . invokeMethod ( ClassBuilder . java : 101 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . AbstractBuilder . build ( AbstractBuilder . java : 90 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . ClassBuilder . buildClassDoc ( ClassBuilder . java : 124 ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke0 ( Native Method ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke ( NativeMethodAccessorImpl . java : 39 ) [ ERROR ] at sun . reflect . DelegatingMethodAccessorImpl . invoke ( DelegatingMethodAccessorImpl . java : 25 ) [ ERROR ] at java . lang . reflect . Method . invoke ( Method . java : 597 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . ClassBuilder . invokeMethod ( ClassBuilder . java : 101 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . AbstractBuilder . build ( AbstractBuilder . java : 90 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . builders . ClassBuilder . build ( ClassBuilder . java : 108 ) [ ERROR ] at com . sun . tools . doclets . formats . html . HtmlDoclet . generateClassFiles ( HtmlDoclet . java : 155 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . AbstractDoclet . generateClassFiles ( AbstractDoclet . java : 164 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . AbstractDoclet . startGeneration ( AbstractDoclet . java : 106 ) [ ERROR ] at com . sun . tools . doclets . internal . toolkit . AbstractDoclet . start ( AbstractDoclet . java : 64 ) [ ERROR ] at com . sun . tools . doclets . formats . html . HtmlDoclet . start ( HtmlDoclet . java : 42 ) [ ERROR ] at com . sun . tools . doclets . standard . Standard . start ( Standard . java : 23 ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke0 ( Native Method ) [ ERROR ] at sun . reflect . NativeMethodAccessorImpl . invoke ( NativeMethodAccessorImpl . java : 39 ) [ ERROR ] at sun . reflect . DelegatingMethodAccessorImpl . invoke ( DelegatingMethodAccessorImpl . java : 25 ) [ ERROR ] at java . lang . reflect . Method . invoke ( Method . java : 597 ) [ ERROR ] at com . sun . tools . javadoc . DocletInvoker . invoke ( DocletInvoker . java : 269 ) [ ERROR ] at com . sun . tools . javadoc . DocletInvoker . start ( DocletInvoker . java : 143 ) [ ERROR ] at com . sun . tools . javadoc . Start . parseAndExecute ( Start . java : 340 ) [ ERROR ] at com . sun . tools . javadoc . Start . begin ( Start . java : 128 ) [ ERROR ] at com . sun . tools . javadoc . Main . execute ( Main . java : 41 ) [ ERROR ] at com . sun . tools . javadoc . Main . main ( Main . java : 31 )
搞了半天没研究出来,最后试了多个命令,如 :pakage 、test 等命令都不报错,只有在用install 的时候报错。 仔细看日志,最后怀疑是 在生成 javadoc 的时候报错,又试了install -D maven.javadoc.skip=true 命令跳过 生成javadoc 部分,果然就不报错了。
仔细研究了下,原来是maven javadoc插件 版本的问题,导致生成这个的时候报错。
在pom 中增加
<build> <finalName> biz-statistics </finalName> <resources> <resource> <directory> ${project.basedir}/src/main/resources </directory> <filtering> true </filtering> </resource> </resources> <plugins> <plugin> <artifactId> maven-javadoc-plugin </artifactId> <version> 2.9.1 </version> <executions> <execution> <id> attach-javadocs </id> <phase> install </phase> <goals> <goal> jar </goal> </goals> <configuration> <encoding> UTF-8 </encoding> </configuration> </execution> </executions> <configuration> <encoding> UTF-8 </encoding> </configuration> </plugin> </plugins> </build>
设置版本号即可。以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
原文链接:https://blog.csdn.net/my_interface/article/details/80996167
查看更多关于使用maven打包生成doc文档和打包源码的详细内容...