溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法

發(fā)布時間:2022-04-25 11:56:09 來源:億速云 閱讀:338 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法”,在日常操作中,相信很多人在分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

    需求:制作一個醫(yī)院列表的顯示功能。列表中包含醫(yī)院編號、醫(yī)院等級、醫(yī)院地址、狀態(tài)等。
    分析:首先確定是典型的條件查詢帶分頁。由于醫(yī)院的等級需要查詢數(shù)據(jù)字典部分,這個調(diào)用是在不同的微服務(wù)模塊中,這就需要進行遠程調(diào)用。

    步驟1:向Nacos服務(wù)中心注冊微服務(wù)

    (1)引入Nacos依賴

      <!--服務(wù)注冊-->
      <dependency>
          <groupId>com.alibaba.cloud</groupId>
          <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
      </dependency>

    (2)配置微服務(wù)到Nacos 1.配置service-hosp

    # 服務(wù)端口
    server.port=8201
    # 服務(wù)名
    spring.application.name=service-hosp
    # Nacos服務(wù)地址
    spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

    2.配置service-cmn

    # 服務(wù)端口
    server.port=8202
    # 服務(wù)名
    spring.application.name=service-cmn
    # Nacos服務(wù)地址
    spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

    3.將各微服務(wù)模塊添加到注冊中心

    在各微服務(wù)模塊的啟動類添加@EnableDiscoveryClient,表示將微服務(wù)注冊到Nacos。

    步驟2:使用Feign進行遠程調(diào)用

    下面在service-hosp創(chuàng)建醫(yī)院列表接口(條件查詢帶分頁),在service-cmn中創(chuàng)建根據(jù)編號查詢數(shù)據(jù)字典名稱的醫(yī)院等級接口。然后通過Feign完成遠程調(diào)用。

    (1)service-hosp醫(yī)院列表接口

    訪問路徑

    /admin/hosp/hospital/list/{page}/{limit}

    Controller:

    @RestController
    @RequestMapping("/admin/hosp/hospital")
    @CrossOrigin
    public class HospitalController {
        @Autowired
        private HospitalService hospitalService;
        /**
         * 醫(yī)院列表(條件查詢帶分頁)
         * @param page
         * @param limit
         * @param hospitalQueryVo
         * @return
         */
        @GetMapping("list/{page}/{limit}")
        public Result listHosp(@PathVariable Integer page,
                               @PathVariable Integer limit,
                               HospitalQueryVo hospitalQueryVo){
            Page<Hospital> pageModel = hospitalService.selectHospPage(page,limit,hospitalQueryVo);
            return Result.ok(pageModel);
        }
    }

    Service接口:

        // 醫(yī)院列表(條件查詢帶分頁)
        Page<Hospital> selectHospPage(Integer page, Integer limit, HospitalQueryVo hospitalQueryVo);

    Service實現(xiàn)類:

    // 醫(yī)院列表(條件查詢帶分頁)
        @Override
        public Page<Hospital> selectHospPage(Integer page, Integer limit, HospitalQueryVo hospitalQueryVo) {
            // 1.創(chuàng)建pageable對象
            Pageable pageable = PageRequest.of(page - 1, limit);
            // 2.創(chuàng)建條件匹配器
            ExampleMatcher matcher = ExampleMatcher.matching()
                    .withStringMatcher(ExampleMatcher.StringMatcher.CONTAINING)
                    .withIgnoreCase(true);
            // 3.hospitalQueryVo轉(zhuǎn)換為Hospital對象
            Hospital hospital = new Hospital();
            BeanUtils.copyProperties(hospitalQueryVo, hospital);
            // 4.創(chuàng)建對象
            Example<Hospital> example = Example.of(hospital, matcher);
            // 5.調(diào)用方法實現(xiàn)查詢
            Page<Hospital> pages = hospitalRepository.findAll(example, pageable);
            // 6.得到所有醫(yī)院信息的集合
            pages.getContent().stream().forEach(item -> {
            	// 此方法執(zhí)行了遠程調(diào)用
                this.setHospitalHosType(item);
            });
            return pages;
        }

    Repository:

    @Repository
    public interface HospitalRepository extends MongoRepository<Hospital,String> {
        /**
         * 根據(jù)HosCode獲得記錄
         * @param hoscode
         * @return
         */
        Hospital getHospitalByHoscode(String hoscode);
    }

    (2)service-cmn醫(yī)院等級/地址接口

    由于醫(yī)院等級、省市區(qū)地址都是取得數(shù)據(jù)字典value值,所以在列表顯示醫(yī)院等級、醫(yī)院地址時要根據(jù)數(shù)據(jù)字典value值獲取數(shù)據(jù)字典名稱。我們在這里需要寫兩個接口。

    查詢醫(yī)院等級,訪問路徑為

    /admin/cmn/dict/getName/{dictCode}/{value}

    查詢醫(yī)院地址,訪問路徑為

    /admin/cmn/dict/getName/{value}

    Controller:

        /**
         * 根據(jù)dictCode和value查詢 數(shù)據(jù)字典
         * @param dictCode
         * @param value
         * @return
         */
        @GetMapping("getName/{dictCode}/{value}")
        public String getName(@PathVariable String dictCode,
                              @PathVariable String value) {
            String dictName = dictService.getDictName(dictCode, value);
            return dictName;
        }
         /**
         * 根據(jù)value查詢 數(shù)據(jù)字典
         * @param value
         * @return
         */
        @GetMapping("getName/{value}")
        public String getName(@PathVariable String value) {
            String dictName = dictService.getDictName("",value);
            return dictName;
        }

    Service接口:

        /**
         * 根據(jù)dictCode和value查詢 數(shù)據(jù)字典
         * @param dictCode
         * @param value
         * @return
         */
        String getDictName(String dictCode, String value);

    Service實現(xiàn)類:

     /**
         * 根據(jù)dictCode和value查詢 數(shù)據(jù)字典
         * @param dictCode
         * @param value
         * @return
         */
        @Override
        public String getDictName(String dictCode, String value) {
            // 如果dictCode為空,直接根據(jù)value查詢;否則根據(jù)dictCode和value查詢
            if (StringUtils.isEmpty(dictCode)) {
                QueryWrapper<Dict> wrapper = new QueryWrapper<>();
                wrapper.eq("value", value);
                Dict dict = baseMapper.selectOne(wrapper);
                return dict.getName();
            } else {
                // 根據(jù)dictcode查詢dict對象,得到dict的id值
                Dict codeDict = this.getDictByDictCode(dictCode);
                Long parent_id = codeDict.getId();
                // 根據(jù)parent_id和value進行查詢
                Dict finalDict = baseMapper.selectOne(new QueryWrapper<Dict>()
                        .eq("parent_id", parent_id)
                        .eq("value", value));
                return finalDict.getName();
            }
        }

    數(shù)據(jù)訪問層由Mybatis-plus完成。

    (3)引入Feign依賴

            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-openfeign</artifactId>
                <scope>provided</scope>
            </dependency>

    單獨創(chuàng)建service-cmn-clientMave工程進行遠程調(diào)用。

    (4)調(diào)用端通過包掃描Feign

    在調(diào)用端的啟動類上,添加 @EnableFeignClients(basePackages = "com.gql") 注解。

    (5)遠程調(diào)用

    接口中的方法為要調(diào)用模塊的方法簽名,注意訪問路徑為完整路徑,且形參中注解后要加上參數(shù)名稱。

    1.遠程調(diào)用接口

    // 要調(diào)用的微服務(wù)名稱
    @FeignClient("service-cmn")
    @Repository
    public interface DictFeignClient {
        /**
         * 根據(jù)dictCode和value查詢 數(shù)據(jù)字典
         * @param dictCode
         * @param value
         * @return
         */
        @GetMapping("/admin/cmn/dict/getName/{dictCode}/{value}")
        public String getName(@PathVariable("dictCode") String dictCode,
                              @PathVariable("value") String value);
        /**
         * 根據(jù)value查詢 數(shù)據(jù)字典
         * @param value
         * @return
         */
        @GetMapping("/admin/cmn/dict/getName/{value}")
        public String getName(@PathVariable("value") String value);
    }

    2.執(zhí)行遠程調(diào)用

        @Autowired
        private DictFeignClient dictFeignClient;
        // 獲取查詢list集合,遍歷進行醫(yī)院等級封裝
        private Hospital setHospitalHosType(Hospital hospital) {
            // 封裝醫(yī)院等級
            String hostypeString = dictFeignClient.getName("Hostype", hospital.getHostype());
            hospital.getParam().put("hostypeString", hostypeString);
            // 封裝醫(yī)院省市區(qū)
            String provinceString = dictFeignClient.getName(hospital.getProvinceCode());
            String cityString = dictFeignClient.getName(hospital.getCityCode());
            String districtString = dictFeignClient.getName(hospital.getDistrictCode());
            hospital.getParam().put("fullAddress", provinceString + cityString + districtString);
            return hospital;
        }

    步驟3:使用swagger測試

    在swagger頁面中添加請求參數(shù)后,點擊執(zhí)行按鈕。

    分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法

    成功通過遠程調(diào)用獲取到醫(yī)院等級、地址:

    分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法

    到此,關(guān)于“分布式醫(yī)療掛號系統(tǒng)Nacos微服務(wù)Feign遠程調(diào)用數(shù)據(jù)字典的方法”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

    向AI問一下細節(jié)

    免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI