Java阶段五Day15
文章目录
- Java阶段五Day15
- 分层其他依赖
- dao-api
- dao-impl
- infrustructure
- domain
- adapter
- main
- 测试整合项目main
- 前台师傅功能
- luban-front配置
- 师傅相关表格ER图
- ER练习案例
- 鲁班表格ER关系(非常重要)
- 前台师傅接口——师傅入驻
- adapter
- domain
- infrustructure
- dao-impl映射文件
- main模块启动
分层其他依赖
保证最后 main 启动的时候,可以支持SSM框架内容
简单的启动测试案例,能否从 main 启动时,获取controller service repository dao
接口代理
dao-api
定义持久层接口,定义使用的数据库表格对应po
<dependency><groupId>org.example</groupId><artifactId>worker-po</artifactId><version>1.0-SNAPSHOT</version>
</dependency>
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId>
</dependency>
dao-impl
定义持久层实现,看到实现的依赖jpa hibernate mybatis
<dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>2.1.0</version>
</dependency>
infrustructure
domain
添加一个公用common
<dependency><groupId>org.example</groupId><artifactId>worker-common</artifactId><version>1.0-SNAPSHOT</version>
</dependency>
adapter
需要spring mvc
等支持
<!--私服提供的 adapter支持依赖-->
<dependency><groupId>com.tedu.inn</groupId><artifactId>inn-spring-adapter-support</artifactId><version>1.0.0-SNAPSHOT</version>
</dependency>
main
负责整合,跑通应用
<!--持久层整合-->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.1.4</version></dependency>
</dependency>
<!--TODO dubbo配置-->
<!--TODO nacos-->
测试整合项目main
main 提供了所需的启动 web 应用依赖内容
配置持久层
-
- 依赖
-
- 编写持久层实现(xml映射文件)
namespace
对应接口全路径
select
标签的id值对应接口的方法名称
-
- 编写持久层接口
-
- main扫描接口包
@SpringBootApplication @MapperScan("cn.tedu.luban.test.dao") public class WorkerServerApplication {//检测以下是否能够创建myabtis的实现对象DaoTestpublic static void main(String[] args) {//从启动方法获取返回值,spring上下文对象ConfigurableApplicationContextcontext = SpringApplication.run(WorkerServerApplication.class, args);DaoTest proxy = context.getBean(DaoTest.class);System.out.println(proxy.getClass().getName());int select = proxy.select();System.out.println(select);} }
-
yaml
数据源mybatis
各种属性
server:port: 9001
spring:application:name: luban-worker-serverdatasource:url: jdbc:mysql://localhost:3306/tarena_tp_luban_worker?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai&allowMultiQueries=trueusername: rootpassword: rootdriver-class-name: com.mysql.cj.jdbc.Driver
# mybatis
mybatis:configuration:cache-enabled: false # 不启用mybatis缓存map-underscore-to-camel-case: true # 映射支持驼峰命名法log-impl: org.apache.ibatis.logging.stdout.StdOutImpl # 将运行的sql输出到控制台mapper-locations: classpath*:mapper/*.xml
前台师傅功能
luban-front配置
项目中 vue.config.js 的文件,配置了前端请求的代理,代理会根据配置向外发出请求
一共配置了4个代理
- 访问功能的网关
- 图片上传服务
只考虑上传,访问演示系统环境中图片上传是没问题的,考虑的是读取图片,rpc调用,必须使用本地attach
base
基本服务
在系统中查询服务区域,查询服务类型,都可以访问演示系统提供的base服务
- 登录注册
师傅相关表格ER图
目标:
- 掌握ER图分析创建过程
ER图——实体关系图(entity Relationship
)
在设计项目之初,做数据库设计的一个阶段性分析过程,产出ER图(数据库的概念设计)
ER练习案例
设计步骤:需求分析,实体确定,实体关系
需求:请给一个论坛,设计功能,包含用户可以登录,用户可以申请成为版主,论坛有板块,用户可以在板块里发帖,可以回帖,版主可以删除所有回帖和发帖,用户只能删除自己的回帖和发帖
确定实体: 用户 版主 板块 帖子 回帖
实体关系: 需要根据实体提供的功能,完成实体与其他实体的关系确定,最后需要优化,删除间接关系,保留最清晰联系。最终由创建数据库DBA决定到底如何关联实体对应表格
(数据库设计六个阶段 需求分析,概念设计,逻辑设计,物理设计,数据库创建,数据库运维)
如果设计到表格落地:
user: table_user
role: table_role
user_role: table_user_role
reply: table_reply(uerId)
,外键需要加到哪里
如果是1对1的表格,任何一方理论上做外键,但是应该区分主从表
主表: 核心数据
从表: 数据依赖主表数据存在
鲁班表格ER关系(非常重要)
鲁班平台需求描述: 支持运营商 供应商 厂家入住提供维修需求订单的平台,可以允许用户登录注册,线下培训考核,成为师傅进行抢单,并且对订单结果负责的一个服务平台系统
- 运营商 / 厂家 / 供应商 入住
- 用户的登录注册
- 用户成为师傅需要师傅入住
- 师傅入住后,绑定给一个平台账号
- 厂家提供需求单,平台定义结算分润
- 师傅入住时选择服务区域
- 师傅入住时选择服务分类
- 师傅入住时上传身份信息图片
- 师傅查询需求单,抢单,生成订单
- 师傅签到,上传施工图片,完成订单
- 平台进行订单结算
实体确定:
前台师傅接口——师傅入驻
- 从上向下开发业务功能
adapter
接收请求controller
domain
处理业务service
repository
定义domain
接口**Repository
infrustructure
定义repositoryImpl
dao-api
接口定义持久层功能dao-impl xml
映射文件 sql 语句
adapter
WorkerServerController
package com.tarena.luban.worker.server.controller;import com.tarena.tp.luban.worker.server.dto.param.WorkerCreateParam;
import com.tedu.inn.protocol.exception.BusinessException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/**前台师傅接口1. 入住 写操作2. 查询详情,查询的是已经审核通过的当前登录的师傅信息*/
@RestController
@RequestMapping("/worker")
public class WorkerServerController {@Autowiredprivate WorkerServerService workerServerService;/*** 返回 通用数据result*/@PostMapping("/create")public Long createWorker(@RequestBody WorkerCreateParam workerCreateParam) throws BusinessException {//调用 worker service 新增return workerServerService.create(workerCreateParam);}
}
domain
相关代码,处理的问题,后端代码如何获取userId
WorkerServerService
package com.tarena.luban.worker.server.manange;
import com.tarena.luban.worker.server.repository.WorkerAreaRepository;
import com.tarena.luban.worker.server.repository.WorkerCategoryRepsoitory;
import com.tarena.luban.worker.server.repository.WorkerRepository;
import com.tarena.passport.protocol.LoginUser;
import com.tarena.passport.sdk.context.SecurityContext;
import com.tarena.tp.luban.worker.server.common.enums.ResultEnum;
import com.tarena.tp.luban.worker.server.dto.param.WorkerAreaParam;
import com.tarena.tp.luban.worker.server.dto.param.WorkerCategoryParam;
import com.tarena.tp.luban.worker.server.dto.param.WorkerCreateParam;
import com.tedu.inn.commons.utils.Asserts;
import com.tedu.inn.protocol.exception.BusinessException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.CollectionUtils;import java.util.List;/*** @author liner* @version 1.0*/
@Service
@Slf4j
public class WorkerServerService {@Autowiredprivate WorkerRepository workerRepository;@Autowiredprivate WorkerAreaRepository workerAreaRepository;@Autowiredprivate WorkerCategoryRepsoitory workerCategoryRepsoitory;/*** 1. 补充userId* 2. 检查 手机号* 3. 检查 身份证 和真实名称是否匹配 TODO* 4. 存储 worker workerCategory workerArea* 使用定义好的repository接口* @param workerCreateParam* @return*/@Transactional(rollbackFor = Exception.class)public Long create(WorkerCreateParam workerCreateParam) throws BusinessException {//获取userIdLong userId=getUserIdByToken();//检查 手机号 身份证 TODOcheckPhoneAndIdCard(workerCreateParam);//挨个存储对应数据到持久层workerCreateParam.setUserId(userId);Long id=saveWorker(workerCreateParam);saveWorkerArea(workerCreateParam);saveWorkerCategory(workerCreateParam);return id;}/*** 先删除,后新增* @param workerCreateParam*/private void saveWorkerCategory(WorkerCreateParam workerCreateParam) {workerCategoryRepsoitory.deleteByUserId(workerCreateParam.getUserId());List<WorkerCategoryParam> workerCategoryParams = workerCreateParam.getWorkerCategoryParams();if (!CollectionUtils.isEmpty(workerCreateParam.getWorkerCategoryParams())){//循环workerCategoryParams.forEach(param -> {param.setUserId(workerCreateParam.getUserId());workerCategoryRepsoitory.save(param);});}}/*** 先删除,后新增* @param workerCreateParam*/private void saveWorkerArea(WorkerCreateParam workerCreateParam) {workerAreaRepository.deleteByUserId(workerCreateParam.getUserId());//循环存储 <foreach>//TODO 批量存List<WorkerAreaParam> workerAreaParams= workerCreateParam.getWorkerAreaParams();for (WorkerAreaParam workerAreaParam : workerAreaParams) {//提交的参数 workerCategoryParam中和workerParam类似的,也没有userId;workerAreaParam.setUserId(workerCreateParam.getUserId());//insert into worker_areaworkerAreaRepository.save(workerAreaParam);}}/*** 1. 当前用户有可能已经是师傅了.* 1.1 先查讯数据库是否有当前用户.师傅信息 有就报错 没有 就新增* 1.2 不管有没有 如果有就删除.重新新增* @param workerCreateParam* @return*/private Long saveWorker(WorkerCreateParam workerCreateParam) {//如果当前用户在数据库中有师傅信息,就删除 重新入住师傅信息workerRepository.delete(workerCreateParam.getUserId());Long id=workerRepository.save(workerCreateParam);//TODO rpc 调用 将身份信息,worker-id,和当前图片传递给attach系统,做更新return id;}private void checkPhoneAndIdCard(WorkerCreateParam workerCreateParam) {//TODOlog.info("check phone and idCard,now passed");}private Long getUserIdByToken() throws BusinessException {LoginUser loginToken = SecurityContext.getLoginToken();//判断 user登录还是没登录 如果loginUser是空的,说明没登录Asserts.isTrue(loginToken==null,new BusinessException(ResultEnum.USER_TOKEN_VERIFY_FAILED));return loginToken.getUserId();}}
infrustructure
- 实现
domain
定义的repository
接口 - 根据代码需求创建
dao-api
的dao
接口
dao-impl映射文件
worker insert delete
workerArea insert delete
workerCategory insert delete
实现xml
映射文件,从源代码中粘贴修改
namespace
对应当前接口类- 不需要方法的删除
- 根据当前接口中方法名,确定标签的 id 是否对应
- 根据接口中方法参数,确定 sql 中 #{参数名} 是否正确
insert
标签
<insert id="insert" parameterType="com.tarena.tp.luban.worker.po.Worker" useGeneratedKeys="true" keyColumn="id"keyProperty="id">
mybatis可以通过 useGeneratedKeys
属性 决定是否要补充参数的属性值
keyColumn
就是读取数据库的字段
keyProperty
补充到对象的属性
main模块启动
spring-boot-starter-web
底层web容器 默认tomcat
tomcat
容器里默认加载servlet
容器,会有servlet-api
存在
main
依赖分层的模块,依赖中存在servlet-api
,会和main starter-web
冲突