Feign调用的两种方式

一、

先看一下项目结构
Feign调用的两种方式_第1张图片
ply模块是主要的业务模块,upms是用户管理模块
他们都分为apibiz
其中api就是一些实体类,工具类,biz就是业务逻辑代码。

首先在upms-api中建立feign的文件夹,然后新建一个接口CustomApi
Feign调用的两种方式_第2张图片
CustomApi
Feign调用的两种方式_第3张图片
然后在biz中写个controller去实现它
Feign调用的两种方式_第4张图片

@RestController
@AllArgsConstructor
public class CustomController implements CustomApi {

    

    @PostMapping({"/getUsersByIds"})
    @Override
    public List<SysUser> getUsersByIds(@RequestBody List<Integer> ids) {
    	//内容省略
        return sysUsers;
    }

然后在plybiz中创建一个类
Feign调用的两种方式_第5张图片

@ApiIgnore
@FeignClient(value = ServiceNameConstants.UPMS_SERVICE)
public interface CustomUserClient extends CustomApi {
}

这样就OK了,我们在ply模块中想用upms里面的方法就直接注入调用就可以了,比如:

 @Autowired
 private CustomUserClient customUserClient;

//直接调用
List<SysUser> usersByIds = customUserClient.getUsersByIds(users);

二、

首先在upms-api中建立feign的文件夹,然后新建一个接口RemoteDictService
Feign调用的两种方式_第6张图片

@FeignClient(contextId = "remoteDictService", value = ServiceNameConstants.UPMS_SERVICE)
public interface RemoteDictService {
//这种就是其他模块需要当前模块的什么方法,就在这里写当前模块的方法
//比如这个/dict/item/findAll就是在upms模块的
	/**
	 * 根据条件查询全部字典项
	 * @return
	 */
	@PostMapping("/dict/item/findAll")
	R<List<SysDictItem>> list(@RequestBody SysDictItem sysDictItem,@RequestHeader(SecurityConstants.FROM) String from);
//SecurityConstants.FROM 的值为:
	/**
     * 标志
     */
    //String FROM = "from";
}
//@RequestHeader(SecurityConstants.FROM) String from不是必要的,这个应该是此框架需要

ServiceNameConstants

package com.cloud.common.core.constant;

/**
 * 服务名称
 */
public interface ServiceNameConstants {
    /**
     * 认证中心
     */
    String AUTH_SERVICE = "auth";

    /**
     * upms模块
     */
    String UPMS_SERVICE = "upms-biz";

}

然后在ply模块中想用upms里面的方法就直接注入调用就可以了,比如:

 @Resource
 private RemoteDictService remoteDictService;

List<SysDictItem> dictItems = remoteDictService.list(sysDictItem, SecurityConstants.FROM_IN).getData();

你可能感兴趣的:(java,java)