本系列文章介紹從0開始搭建一個基于分布式的醫療掛號系統。本次四篇文章完成了
醫院設置微服務模塊
的后端接口,為了方便開發,對接口的返回結果
、全局異常
、全局日志
進行了統一處理。 同時,為了方便進行訪問測試,還整合了Swagger2工具
,這些通用的模塊中,除了全局日志
被放在醫院設置微服務模塊的配置資源中,其余都統一被抽取在common模塊中。具體實現可參考下面文章:
- 醫院設置微服務 | 模塊搭建
- 醫院設置微服務 | 接口開發
- 通用模塊 | 整合Swagger2
- 通用模塊 | 統一返回結果、統一異常處理、統一日志處理
作者:Hudie
微信公眾號/CSDN博客:編程一只蝶
項目已開源至gitee:https://gitee.com/guo-qianliang/yygh_parent
項目已開源至github:https://github.com/Guoqianliang/yygh_parent
一、框架調用流程
從Controller層到Service層
Controller層需要調用Service層的方法,我們在其中使用依賴注入(@Autowired注解)將Service的接口裝進Spring容器。-
從Service層到Mapper層
Service層需要調用Mapper層,MyBatis-Plus框架已經將Mapper依賴注入進了Service層,我們只需要分別繼承IService<T>接口和ServiceImpl實現類即可。
使用MyBatis-Plus后的三層調用關系
二、醫院設置表接口開發
1.增
(1)增加記錄
具體代碼說明:
- 參數中使用@RequestBody注解表示使用JSON格式傳遞參數,默認是required=true,表示不能為空。
- 代碼中首先將記錄的狀態設置為1表示該記錄可用,然后使用MD5加密算法設置簽名密鑰,關于MD5加密算法會在接下來的文章中詳細介紹。
/**
* 1 增加記錄
*/
@PostMapping("saveHospitalSet")
public Result saveHospitalSet(@RequestBody HospitalSet hospitalSet) {
// 設置狀態字段 (1:可以使用,0:不能使用)
hospitalSet.setStatus(1);
// 設置簽名密鑰字段(使用MD5加密)
hospitalSet.setSignKey(MD5.encrypt(System.currentTimeMillis() + "" + new Random().nextInt(1000)));
// 調用方法執行添加
boolean flag = hospitalSetService.save(hospitalSet);
return Result.isOKorFail(flag);
}
2.刪
(1)邏輯刪除記錄
/**
* 2.1 邏輯刪除記錄
*/
@ApiOperation(value = "removeHospSer", notes = "邏輯刪除醫院設置")
@DeleteMapping(value = "{id}")
public Result removeHospSer(@PathVariable Long id) {
boolean flag = hospitalSetService.removeById(id);
return Result.isOKorFail(flag);
}
(2)批量刪除記錄
/**
* 2.2 批量刪除記錄
*/
@DeleteMapping("batchRemove")
public Result batchRemoveHospitalSet(@RequestBody List<Long> idList) {
hospitalSetService.removeByIds(idList);
return Result.ok();
}
3.改
(1)修改記錄
/**
* 3 修改記錄
*/
@PostMapping("updateHospitalSet")
public Result updateHospitalSet(@RequestBody HospitalSet updateHospitalSet) {
boolean flag = hospitalSetService.updateById(updateHospitalSet);
return Result.isOKorFail(flag);
}
4.查
(1)查詢所有記錄
/**
* 4.1 查詢所有記錄
* @return list
*/
@ApiOperation(value = "findAllHospitalSet", notes = "獲取所有醫院設置信息")
@GetMapping("findAll")
public Result findAllHospitalSet() {
List<HospitalSet> list = hospitalSetService.list();
return Result.ok(list);
}
(2)條件查詢帶分頁
查詢時需要傳遞參數作為查詢條件,可以使用
vo對象
將查詢條件進行封裝。然后在Controller中獲取條件對象,由于帶有條件查詢帶有分頁,還需獲取分頁數據(當前頁current、每頁記錄數limit)
醫院設置表的分頁查詢vo對象:
具體代碼說明:
- findPageHospSet方法傳入
三個參數
,①當前頁current ②每頁大小limit ③條件查詢的vo對象分頁步驟
是:①創建page對象、②創建QueryWrapper對象、③調用方法執行分頁查詢條件
是醫院名稱或醫院編號,對醫院名稱進行模糊查詢,對醫院編號進行等值查詢,需要注意對這兩個值進行判空處理。@RequestBody(required = false)
注解表示使用JSON格式傳遞參數,然后把JSON數據的值放到對象中去,required = false表示這個值可以為空。使用此參數要將提交方式改為POST,因為GET方式得不到值。
/**
* 4.2 條件查詢帶分頁
* 根據醫院名稱或編號查詢
*/
@PostMapping("findPage/{current}/{limit}")
public Result findPageHospSet(@PathVariable long current,
@PathVariable long limit,
@RequestBody(required = false) HospitalSetQueryVo hospitalSetQueryVo) {
// 1. 創建page對象。傳遞當前頁、每頁記錄數
Page<HospitalSet> page = new Page(current, limit);
// 2. 創建QueryWrapper對象.
QueryWrapper<HospitalSet> queryWrapper = new QueryWrapper<>();
// 2.1 對醫院名稱和醫院編號進行判空
String hosname = hospitalSetQueryVo.getHosname();
String hoscode = hospitalSetQueryVo.getHoscode();
if (!StringUtils.isEmpty(hosname)) {
queryWrapper.like("hosname", hospitalSetQueryVo.getHosname());
}
if (!StringUtils.isEmpty(hoscode)) {
queryWrapper.eq("hoscode", hospitalSetQueryVo.getHoscode());
}
// 3. 調用方法執行分頁。(參數是上面兩個對象)
Page<HospitalSet> pageHospitalSet = hospitalSetService.page(page, queryWrapper);
// 返回結果
return Result.ok(pageHospitalSet);
}
(3)根據id獲取記錄
/**
* 4.3根據id獲取記錄
*/
@GetMapping("getHospSet/{id}")
public Result getHospSet(@PathVariable Long id) {
HospitalSet hospitalSet = hospitalSetService.getById(id);
return Result.ok(hospitalSet);
}
5.鎖定和解鎖表
針對表中的status字段:
- status=1時表示解鎖
- status=0時表示鎖定
只有醫院設置表的狀態為解鎖狀態時,才能進行和醫院系統的對接,從而進行數據的操作。
/**
* 醫院設置表鎖定和解鎖
*/
@ApiOperation(value = "lockHospitalSet 醫院設置表鎖定和解鎖")
@PutMapping("lockHospitalSet/{id}/{status}")
public Result lockHospitalSet(@PathVariable Long id,
@PathVariable Integer status) {
// 根據id查詢醫院設置信息
HospitalSet hospitalSet = hospitalSetService.getById(id);
// 設置狀態
hospitalSet.setStatus(status);
// 調用更新方法
hospitalSetService.updateById(hospitalSet);
return Result.ok();
}
6.發送簽名密鑰
發送簽名密鑰,即短信接口,由于調用短信接口較為復雜,后面會有專門的文章進行介紹,這里暫時只寫好框架。具體開發流程可參考后續文章。
/**
* 發送簽名密鑰
*/
@ApiOperation(value = "sendKeyHospitalSet 發送簽名密匙")
@PutMapping("sendKey/{id}")
public Result sendKeyHospitalSet(@PathVariable Long id) {
HospitalSet hospitalSet = hospitalSetService.getById(id);
// 簽名密鑰
String signKey = hospitalSet.getSignKey();
// 醫院編號
String hoscode = hospitalSet.getHoscode();
// TODO 發送短信
return Result.ok();
}
至此,醫院設置微服務后端接口開發已經完成了,通過swagger可以查看到我們開發的所有方法: