Linux使用IDEA配置maven的web项目骨架archetype(模板) 自定义骨架
说明:本文说的骨架就是 archetype,也可以理解为模板,总是就是指你创建项目时的基本配置。
前言:在使用IDEA创建maven的web项目时,一般都是直接使用提供的默认web项目,如图

然而创建之后,整个项目就几乎都是默认配置,什么都没有。

那么问题来了,(前提是使用maven)我能不能创建一个ssm的web项目骨架,作为一个模板,然后以后
直接按着这个模板创建呢?这样的话就不用每次都修改web.xml、pom.xml这些东西了,也不用每次添加
各种ssm的配置文件了。答案是可以的。方法如下:
1、搭建好基本的项目骨架

上面就是我常用的骨架,主要就是一些配置文件和web.xml、pom.xml的内容
为什么没有java、test的源代码文件夹呢?因为我之前试过了,当配置的时候,这些文件夹
都没有生成,生成的只有resource文件夹,我还没系统学习maven,所以具体也不知道原因。
但是,即使是这些配置文件就已经满足我的需求了,至少不用每次想练个ssm的demo都要重新配置
2.使用maven的命令创建骨架
在1步骤搭建好骨架之后,需要创建maven的archetype(骨架),也就是生成一些相关的东西,比如jar包。
在项目的根目录下(即项目的pom.xml文件所在目录)下执行maven命令:
mvn archetype:create-from-project
然后就创建成功了,如下图

3.使用maven的命令安装骨架
在archetype的根目录下(即: 项目根目录\target\generated-sources\archetype)再执行以下maven命令:
mvn install
这样就把该archetype安装到了本地的maven 仓库中了
错误:
但是,我遇到了一点问题,错误我忘了截图,反正就是说在仓库中找不到目录,
No such file or directory
如果碰到这个问题,不要慌,那是因为仓库中没有创建文件夹。
文件夹的名字应该是groupId的值。创建之后,再次执行 maven install 就能安装成功了。
4.使用archetype
使用可以用maven命令行的方式,但在本文中是使用IDEA。
当你在你的maven仓库中看到你安装的骨架之后,就可以在IDEA中添加archetype了。
添加方式如下

在创建maven项目时,选择Create from archetype,然后点击Add Archetype
之后就在弹出窗口填上你的 groupId、artifactId、version就可以了。
然后选择你刚创建的模板就可以创建成功了。
补充:
1、使用范围
按照上面方法创建的骨架,一般都是你本地电脑使用的,也就是说如果别人想用,需要用另外的方法。
这里就不阐述了。
2、删除骨架
当你不想使用这个骨架,或者骨架有误的时候,需要删除,该怎么删除呢?主要是删除两个地方的东西。
步骤如下:
(1)删除IDEA中的骨架
主要是要删除UserArchetypes.xml文件的内容。不同操作系统的位置不一样。
Mac系统:
一般是在${...}/.IntelliJIdea2018.3/Maven/Indices/UserArchetypes.xml
Linux系统:
一般是在${...}/.IntelliJIdea2018.3/system/Maven/Indices/UserArchetypes.xml
Windows系统:
一般是在${...}/.IntelliJIdea2018.3/system/Maven/Indices/UserArchetypes.xml
${...}指的是你的安装路径,以你的为主
主要就是这个路径下有个UserArchetypes.xml文件,然后打开删除里面的<archetype>标签即可
(2)删除maven仓库中的骨架
直接在你的本地仓库中按照你创建的骨架的groupId、artifactId寻找,之后删除文件夹即可。
比如我这里是直接删掉my文件夹就行了。
3.骨架命名
你的自定义骨架的groupId千万不要跟常见的名词重复,不然就会哭到爆。
命名是以这个来的 groupId、artifactId、version
比如我的骨架是groupId是my
然后我就用这个骨架新建项目,然后我就填一般的groupId和artifactId。

也就是说 你的自定义骨架是my.yellow-archetype
你用这个骨架创建的项目是cn.test
你就会发现你创建的项目里面,所有出现mybatis的词的地方,都变成了cnbatis

所以综上所述,把你的groupId命名为乱七八糟就行了,比如fsjdghsjkghsji
参考链接:
https://blog.csdn.net/qq_21251983/article/details/52252970?utm_source=blogxgwz6
https://stackoverflow.com/questions/4361567/where-are-added-archetypes-stored-in-intellij
Linux使用IDEA配置maven的web项目骨架archetype(模板) 自定义骨架的更多相关文章
- eclipse中配置maven的web项目
提高效率,一般都会使用IED如eclipse来帮助开发.eclipse中单独建立一个web项目或者是maven项目是可以通过插件很容易完成的,但是如果要结合2者,就需要先建立一个,然后再转换或使原型. ...
- maven构建web项目,用jetty测试的配置pom.xml
maven构建web项目,用jetty测试的配置pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmln ...
- 【maven】 在 MyEcplise上使用maven搭建Web项目
二.在My Ecplise上使用Maven搭建Web项目 1.新建一个maven项目 2.create一个简单的骨架 3.就像在ecplise中一样设置项目的以下配置 4.新创建的项目结构如下 ...
- step2-------使用myeclipse创建maven java web项目
1.文章内容概述: 在对项目需求进行分析之后,决定使用maven对我的java web项目进行管理,这篇文章记录了使用myeclipse创建maven java web项目的过程. 2.开发环境: j ...
- Maven学习总结(七)——eclipse中使用Maven创建Web项目
一.创建Web项目 1.1 选择建立Maven Project 选择File -> New ->Project,如下图所示:
- Maven发布web项目到tomcat
在java开发中经常要引入很多第三方jar包:然而无论是java web开发还是其他java项目的开发经常会由于缺少依赖包引来一些不必要的异常.常常也是因为这样的原因导致许多简单的缺包和版本问题耗费大 ...
- Maven——eclipse中使用Maven创建Web项目
原文:http://www.cnblogs.com/xdp-gacl/p/4054814.html 一.创建Web项目 1.1 选择建立Maven Project 选择File -> New - ...
- 转】Maven学习总结(七)——eclipse中使用Maven创建Web项目
原博文出自于: http://www.cnblogs.com/xdp-gacl/p/4054814.html 感谢! 一.创建Web项目 1.1 选择建立Maven Project 选择File -& ...
- 使用Maven构建Web项目的目录结构
1.Web项目的目录结构 基于Java的Web项目,标准的打包方式是WAR.与JAR比较,包含更多的内容,比如JSP文件.Servlet.Java类.web.xml配置文件.依赖JAR包.静态 ...
随机推荐
- C++基础——类封装简单示例
一.前言 在IC前端设计/验证领域,只会HDL远远不够.目前大多数项目使用已开发好的系统架构和IP Core,因此设计部分的工作量慢慢向系统集成和验证方向转移.而在集成和验证过程中,往往以各种脚本和面 ...
- LeetCode算法题-Letter Case Permutation(Java实现)
这是悦乐书的第315次更新,第336篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第184题(顺位题号是784).给定一个字符串S,将每个字母单独转换为小写或大写以创建另 ...
- pandas 对数据帧DataFrame中数据的增删、补全及转换操作
1.创建数据帧 import pandas as pd df = pd.DataFrame([[1, 'A', '3%' ], [2, 'B'], [3, 'C', '5%']], index=['r ...
- 中缀表达式得到后缀表达式(c++、python实现)
将中缀表达式转换为后缀表达式的算法思想如下: 从左往右开始扫描中缀表达式 遇到数字加入到后缀表达式 遇到运算符时: 1.若为‘(’,入栈 2.若为’)‘,把栈中的运算符依次加入后缀表达式,直到出现'( ...
- SpringBoot整合Jsp和Thymeleaf (附工程)
前言 本篇文章主要讲述SpringBoot整合Jsp以及SpringBoot整合Thymeleaf,实现一个简单的用户增删改查示例工程.事先说明,有三个项目,两个是单独整合的,一个是将它们整合在一起的 ...
- element-ui 动态换肤
1.在安装好 element-ui@2.x 以后,首先安装sass-loader npm i sass-loader node-sass -D 2.安装 element-theme npm i ele ...
- Linux最小系统移植之早期打印CONFIG_DEBUG_LL
一.几个关键宏定义 CONFIG_DEBUG_LL. CONFIG_DEBUG_LL_INCLUDE 容我慢慢道来, 首先要使能早期打印, menuconfig必须选中CONFIG_DEBUG_LL, ...
- Docker进阶之一:Docker介绍与体系结构
一. Docker是什么 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源,基于Linux内核的cgroup,namespace,Union FS 等技术, ...
- React引领未来用户界面——心莱科技内部直播分享会
视频地址(请点开链接观看视频)https://v.qq.com/x/page/l08427ukdjo.html 本周,心莱科技在公司内部就开展了一场前端技术分享会,使用了直播模式进行分享,主要分享关于 ...
- Linux 用户与组的基本操作及文件权限位的设置方法
用户的基本操作 添加用户: useradd xxx 查看所有的用户: cat /etc/passwd 用户更改组: usermod -G groups loginname 将用户从组中删除: gpas ...