发现有很多小伙伴都不会用IDEA打jar包,今天给大家详细总结了两种IDEA打jar包的方式,对正在学习IDEA使用的小伙伴很有帮助,需要的朋友可以参考下
在讲这两种方式之前,我们先来说明一下什么是java中的jar文件
jar (Java Archive File),翻译过来就是java的档案文件,它其实也类似于我们windows下的zip文件,唯一的区别就是在 JAR 文件的内容中,包含了一个 META-INF/MANIFEST.MF 文件,这个文件是在生成 JAR 文件的时候自动创建的,包含了JAR包的描述信息、主类的全类名等信息。
点击ok以后我们在返回上一步Project Structuer中发现IDEA中默认已经将我们的jar包输出目录填上了,这时我们可以更改一下上述的jar包输出目录,这样也更加方便的管理,此时我们更改号路径以后在点下右下角的Apply就可以了。
3.这时我们去刚才相应的jar包输出目录发现已经有了对应的包
可以使用如下两种方法来运行jar包
1.当你的Project中使用了Maven时,可以直接在Lifecycle中执行打包,第一步编译别忘记了,之前我jar包老是运行报错就是因为没有compile就直接package了。
2.双击package后我们即可以发现在target目录下便生成了一个对应的jar包,这里jar包和刚才方法一其实是一样的,只不过我们这次用Maven生成的。
到此这篇关于详细总结IDEA中打jar包的两种方式的文章就介绍到这了,更多相关IDEA打jar包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
这篇文章主要为大家详细介绍了java实现文件上传和下载,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要给大家介绍了关于Struts2学习基础教程之拦截器机制与自定义拦截器的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要介绍了手动模拟JDK动态代理的方法,帮助大家更好的了解和学习Java 代理的相关知识,感兴趣的朋友可以了解下
Java 异常机制可以使程序中异常处理代码和正常业务代码分离,保证程序代码更加优雅,并提高程序健壮性。本文超详细讲解了Java异常,感兴趣的小伙伴可以参考一下这篇文章
B/S结构的系统是一个特殊的C/S系统
B/S结构的系统优点和缺点是:
在前端HTML代码中,有一个标签,叫做base标签,这个标签可以设置整个网页的基础路径。
这是Java的语法,也不是JSP的语法。是HTML中的一个语法。HTML中的一个标签。通常出现在head标签中。
在当前页面中,凡是路径没有以“/”开始的,都会自动将base中的路径添加到这些路径之前。
需要注意:在JS代码中的路径,保险起见,最好不要依赖base标签。JS代码中的路径最好写上全路径。
当前的OA项目存在什么缺陷?
第一步:编写一个Java类实现一个接口:jarkata.servlet.Filter。并且实现这个接口当中所有的方法。
第二步:在web.xml文件中对Filter进行配置。这个配置和Servlet很像。
执行下一个过滤器,如果下面没有过滤器了,执行最终的Servlet。
注意:Filter的优先级,天生的就比Servlet优先级高。
目标Servlet是否执行,取决于两个条件:
依靠filter-mapping标签的配置位置,越靠上优先级越高。
过滤器的调用顺序,遵循栈数据结构。
第一步:编写一个类实现ServletContextListener接口。并且实现里面的方法。
当然,第二步也可以不使用配置文件,也可以用注解,例如:@WebListener
注意:所有监听器中的方法都是不需要javaweb程序员调用的,当某个特殊的事件发生(特殊的事件发生其实就是某个时机到了。)之后,被web服务器自动调用。
实现oa项目中当前登录在线的人数。
javafx在高版本的jdk中比较完善,但生产环境目前还是大量使用8,所以打包问题尤其重要。作为新手刚接触,走了不少弯路,这些弯路也加深了自己对javafx打包的认识,在此先记录下来,再慢慢补充。
本次说的打包目前还特指局限在jlink成功。
首先,使用java17的sdk开发,那么选用的idea版本号就可以支持17的javafx的开发,非常方便。以前的版本比如11需要配置--add-mould-path,编写module-info等,lib路径,maven工程需要建模板等工作,新版本中建完直接就开工了,所以,换idea版本是傻瓜式工作的第一步。
新版idea已经提供了基本的pom,包含了打包插件,如下:
如果使用的是样板代码,直接点plugin里的的javafx:jlink就行,简单一两步操作,打包工作就完成了。
问题来了,假如引用了第三方的jar包,尤其是非模块化的包,则jlink会报错。jlink目的就是为了用啥再要啥,也就是通过模块的组合尽可能减少无用的包。以前java8时候,虽然要胡子,但眉毛也得也得拿走,所以打包后的程序特别大,现在模块里有一个描述文件,这个包里描述了模块实际用到的东西(其他模块),打包的时候目的性就清晰多了。java8里没这个描述文件,那怎么办?其实当直接运行的时候,java是可以将依赖的第三方包变成自动模块,idea还会分析出自动模块名,提醒你写到requires里。那这不完了吗?jlink把所有自动的非自动的包进进行打包,完成了运行时环境定制,并知道可执行程序入口,一个可脱离系统java运行时环境的独立程序就制作成功了。
但是,jlink并不支持自动模块的打包,这就麻烦了。有两种方法解决这个问题,一个是不用jlink了(这不是废话)吗,使用 fat jar包(借助maven shade plugin,没有尝试过),另外一种思路就是没有就创造出来,不是模块就让他变成模块。其实很多包离模块就差了一个东西,module-info.class,把他补上不就成了吗。没错,moditect就有这样的功能,使用moditect插件可以方便的将一个包,变成一个模块。这个插件怎么使用呢?以一个例子为代表:
这个例子是将CustomStage变成模块。最主要其实就是moduleInfoSource,里面的内容基本就是的代码,有几个地方需要注意:
1)模块名字,与pom.properties保持一致,多看看包里的 meta或者pom信息。这个很关键,如果包名写错了会提示找不到模块描述符有问题。
2)requires和exports以及opens这些目前为止还不知道怎么一次性写对,更多的时候,是编译器一次次报错逐步改正和添加的。特别重要的是直接看包的的目录结构,哪些需要输出要心中有数。包的目录结构包含了访问权限等的内容,比如上面的lk.vivoxalabs.customstage.CustomStage的模块包含了好几层目录。
比如lk.vicoxalabs这是两层纯目录结构,导出这个目录后,其他模块要访问lk.vicoxalabs这个目录下的下一层目录是不可以的。按时你直接导出下一层的目录别人就可以访问了,比如exports lk.vivoxalabs.customstag后,customstag目录里二代类就可以使用了。这也是为什么有时候需要--add-exports,特别是java8转到模块化的程序后,经常会出现大量要求你将模块的某些功能,导出授权给unname的模块。
在compile阶段会生成新的打包后的jar文件,这时可以打开看看,已经多了一个module-info.class的文件,这暂时代表我们成功了。这时候为了使用它,需要将你原来得到maven包里的jar文件替换成你刚生成的jar,记得重新将项目里nodule-info.java替换,因为自动模块名和你定义的模块名不一样,只需要idea提示导进去就行了。
这时候可以再运行mvn javafx:link,可以成功了。
但真的成功了吗?找到打包的app,cmd中运行app.bat,会发现还会报很多错,尤其是moduleInfoSource里的info文件没有写对时,这时候根据提示一步步改正即可。
即使都该改正了,程序一定能运行出来吗?不一定。这是因为有module-info.java的程序与非模块化(特指无module-info.java)的程序不一样,比如说javafx.scene里的Image类,在这两种方式中会显示出不一样的用法(可以参考javafx.scene.Image的源码)。在8里面正常的,Image(“文件名”),在新的程序里会报错,显示非法url。这种除了重新编译源码外,还没有想到好的办法。
jlink的介绍到此为止,可见包虽然是好东西,但是版本的切换或新功能的切换也引起新的不便。java打包不止这几种方法,没必要一棵树上吊死。但通过jlink打包的学习,能够更加深入理解模块的特点,了解出错的原因,才是我们真正关心的。