这里写目录标题
1. 分模块开发与设计
首先将 web应用
中的各个模块(pojo, dao, serivce, controller)
进行划分
1.1 实体类 (pojo) 划分
- 新建模块
(ssm_pojo)
- 拷贝原始项目中对应的相关内容到
ssm_pojo
模块中- 实体类(User)
- 配置文件(无)
1.2 dao 层划分
- 新建模块:
(ssm_dao)
- 拷贝原始项目中对应的相关内容到
ssm_dao模块
中- 数据层接口(UserDao)
- 配置文件:保留与数据层相关配置文件(3个)
- 注意:分页插件在配置中与SqlSessionFactoryBean绑定,需要保留
pom.xml
:引入数据层相关坐标即可,删除springmvc相关坐标- spring
- mybatis
- spring整合mybatismysql
- druid
- pagehelper
- 直接依赖ssm_pojo (对ssm_pojo模块执行install指令,将其安装到本地仓库)
1.3 serivce 层划分
- 新建模块:
(ssm_service)
- 拷贝原始项目中对应的相关内容到
ssm_service模块
中- 业务层接口与实现类
(UserService、UserServicelmpl)
- 配置文件:保留与数据层相关配置文件(1个)
pom.xml
:引入数据层相关坐标即可,删除springmvc相关坐标- spring
- junit
- spring整合junit
- 直接依赖ssm_dao (对ssm_dao模块执行install指令,将其安装到本地仓库)
- 间接依赖ssm_pojo (由ssm_dao模块负责依赖关系的建立)
- 修改service模块spring核心配置文件名,添加模块名称,格式:
applicationContext-service.xml
- 修改dao模块spring核心配置文件名,添加模块名称,格式:
applicationContext-dao.xml
- 修改单元测试引入的配置文件名称,由单个文件修改为多个文件
(classpath:"applicationContext-service.xml,applicationContext-dao.xml")
- 业务层接口与实现类
1.4 controller 层划分
- 新建模块:
(使用webapp模板)
- 拷贝原始项目中对应的相关内容到
ssm_ _controller模块
中 - 表现层控制器类与相关设置类
(UserController、 异常相关.....)
- 配置文件:保留与表现层相关配置文件(1个)、服务器相关配置文件(1个)
pom.xml
:引入数据层相关坐标即可,删除springmvc相关坐标- spring
- springmvc
- jackson
- servlet
- tomcat服务器插件
- 直接依赖ssm_ service (对ssm_ service模块执行install指令, 将其安装到本地仓库)
- 间接依赖ssm_ dao、 ssm_ _pojo
- 修改
web.xml配置文件
中加载spring环境的配置文件名称,使用*通配符
,加载所有applicationContext-
开始的配置文件
1.5 小结
分模块开发
- 模块中仅包含当前模块对应的功能类与配置文件
- spring核心配置根据模块功能不同进行独立制作
- 当前模块所依赖的模块通过导入坐标的形式加入当前模块后才可以使用
- web.xml需要加载所有的spring核心配置文件
2. 聚合、继承、属性
2.1 聚合
- 以下配置均在
ssm模块
中的pom.xml
中发生
多模块维护
聚合操作
注意:
ssm_controller模块要打war包
不写,默认jar包
2.2 继承
- 通过继承可以实现模块之间依赖关系的维护。避免jar包冲突。
- 作用:通过继承可以实现在子工程中沿用父工程中的配置
- maven中的继承与java中的继承相似,在子工程中配置继承
- 关系制作方式:
- 在子工程中声明其父工程坐标与对应的位置。
继承与聚合
作用
- 聚合用于
快速构建项目
- 继承用于
快速配置
- 聚合用于
相同点
:- 聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中
- 聚合与继承均属于设计型模块,并无实际的模块内容
不同点
:- 聚合是在
当前模块
中配置关系,聚合可以感知到参与聚合的模块
有哪些 - 继承是在
子模块
中配置关系,父模块
无法感知哪些子模块继承了自己
- 聚合是在
2.3 属性
作用
:方便统一版本
1. 自定义属性
2. 内置属性
3. Setting属性
4. Java系统属性
5. 环境变量属性
3. 版本管理、 资源配置
3.1 版本管理
工程版本
-
SNAPSHOT(快照版本)
- 项目开发过程中,为方便团队成员合作,解决模块间相互依赖和时时更新的问题,开发者对每个模块进行构建的时候,输出的临时性版本叫快照版本(测试阶段版本)
快照版本会随着开发的进展不断更新
-
RELEASE(发布版本)
- 目开发到进入阶段里程碑后,向团队外部发布较为稳定的版本,这种版本所对应的构件文件是稳定的,即便进行功能的后续开发,也不会改变当前发布版本内容,这种版本称为发布版本
工程版本号约定
-
约定规范:
- <主版本>.<次版本>.<增量版本>.<里程碑版本>
- 主版本:表示项目重大架构的变更,如: spring5相较于spring4的迭代
- 次版本:表示有较大的功能增加和变化,或者全面系统地修复漏洞
- 增量版本: 表示有重大漏洞的修复
- 里程碑版本:表明一个版本的里程碑(版本内部)。这样的版本同下一个正式版本相比,相对来说不是很稳定,有待更多的测试
-
范例:
- 5.1.9.RELEASE
3.1 资源配置
上节介绍了通过属性
统一管理jar包
,那么资源应该怎么使属性进行配置呢?例如:jdbc链接
资源配置多文件维护
资源配置
- 作用
- 在任意配置文件中加载pom文件中定义的属性
- 调用格式
${jdbc.url}
- 开启配置文件加载pom属性
<!--配置资源文件对应的信息-->
<resources>
<resource>
<!一设定配置文件对应的位置目录,支持使用属性动态设定路径,也可以和下面使用相对路径获取-->
<directory>$ {project.basedir }/src/main/resources</directory>
<!―-开启对配置文件的资源加载过滤-->
<filtering>true</filtering>
</resource>
</resources>
3.2案例
- 在
ssm 模块的 pom.xml
中配置属性
- 因为jdbc是在ssm_dao模块中使用的,找到相关资源,把
url
的获取方式该为${jdbc.url}
- 配置资源文件对应的信息
4. 多环境开发
4.1 多环境配置
加载指定环境
- 作用
- 加载指定环境配置
- 调用格式
mvn 指令 -P 环境定义 id
- 范例
mvn install -P pro_env
4.2 跳过测试
使用命令跳过测试
- 命令
mvn 指令 -D skipTests
- 注意事项
- 执行的指令生命周期必须包含测试环节
使用界面操作跳过测试
在 ssm模块的pom.xml
使用插件配置跳过测试
5. 私服
Nexus
- Nexus是Sonatype公司的一款maven私服产品
- 下载地址: https://help.sonatype.com/repomanager3/download
多模块开发图例:
5.1 Nexus安装、启动与配置
启动服务器(命令行启动)
nexus.exe /run nexus
访问服务器(默认端口:8081)
http://localhost:8081
修改基础配置信息
- 安装路径下etc目录中nexus-default.properties文件保存有nexus基础配置信息,例如:
默认访问端口
修改服务器运行配置信息
- 安装路径下bin目录中nexus.vmoptions文件保存有nexus服务器启动对应的配置信息,例如:
默认占用内存空间
5.2 私服的获取
仓库分类
1. 宿主仓库hosted
- 保存无法从中央仓库获取的资源
- 自主研发
- 第三方非开源项目
2. 代理仓库proxy
- 代理远程仓库,通过nexus访问其他公共仓库,例如
中央仓库
3. 仓库组group
- 将
若干个仓库
组成一个群组,简化配置 - 仓库组不能保存资源,属于设计型仓库
资源上传
上传资源时提供对应的信息
- 保存的位置(宿主仓库)
- 资源文件
- 对应坐标
5.3 idea 环境中资源上传与下载
访问私服配置(本地仓库访问私服)
访问私服配置(项目工程访问私服)
5.4 小结
资源发布
- 设置私服访问权限
- 设置资源上传路径:
(私服宿主仓库地址)
- 设置资源下载路径:
(私服仓库组地址)
发布命令