feign調(diào)用返回object類型轉(zhuǎn)換方式
feign調(diào)用返回object類型轉(zhuǎn)換
引入依賴
<dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.9.8</version> </dependency>
/** * @Description: 將數(shù)據(jù)轉(zhuǎn)換到相應(yīng)的容器 * @param bean * @param clazz * @return * @throws * @author dlh * @date 2019/3/19 10:28 */ public static <T> T convertValue(Object bean, Class<T> clazz){ try{ ObjectMapper mapper = new ObjectMapper(); return mapper.convertValue(bean, clazz); }catch(Exception e){ logger.error("錯(cuò)誤的轉(zhuǎn)換:BeanUtil.convertValue() --->" + e.getMessage()); return null; } }
SpringCloud feign接口轉(zhuǎn)換服務(wù)
Feign是通過(guò)提供面向接口操作的方式來(lái)替代RestTemplate API的Rest操作。
使用Feign
Feign這種技術(shù)應(yīng)用在服務(wù)消費(fèi)端
修改pom.xml配置文件,加入Feign的依賴包
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-feign</artifactId> </dependency>
由于Fegin是將Rest的操作轉(zhuǎn)換成接口的形式,所以我們需要新建一個(gè)接口,并在接口上聲明@FeignClient注解
@FeignClient(value = "DEPT-PROVIDER",configuration = FeignClientConfig.class) public interface DeptClientService { @RequestMapping(method= RequestMethod.GET,value="/dept/get/{id}") public Dept get(@PathVariable("id") long id) ; @RequestMapping(method=RequestMethod.GET,value="/dept/list") public List<Dept> list() ; @RequestMapping(method=RequestMethod.POST,value="/dept/add") public boolean add(Dept dept) ; } @Configuration public class FeignClientConfig { @Bean public Logger.Level getFeignLoggerLevel() { return feign.Logger.Level.FULL ; } @Bean public BasicAuthRequestInterceptor getBasicAuthRequestInterceptor() { return new BasicAuthRequestInterceptor("admin", "admin"); } }
其中configuration = FeignClientConfig.class不是必須的,將configuration屬性去除仍然能work。
將之前的Rest操作的API,替換成面向DeptClientService接口的形式
@RestController @RequestMapping("/consumer/dept") public class ConsumerDeptController { @Autowired private DeptClientService deptClientService; @RequestMapping(value = "/get") public Dept get(long id) { return this.deptClientService.get(id); } @RequestMapping("/list") public List<Dept> list(){ return this.deptClientService.list(); } @RequestMapping("/add") public boolean add(Dept dept){ return this.add(dept); } /* public static final String DEPT_GET_URL = "http://DEPT-PROVIDER/dept/get/"; public static final String DEPT_LIST_URL = "http://DEPT-PROVIDER/dept/list/"; public static final String DEPT_ADD_URL = "http://DEPT-PROVIDER/dept/add"; @Autowired private RestTemplate restTemplate; @Autowired private HttpHeaders httpHeaders; @Autowired private LoadBalancerClient loadBalancerClient; @RequestMapping(value = "/get") public Dept get(long id) { ServiceInstance serviceInstance = this.loadBalancerClient.choose("DEPT-PROVIDER") ; System.out.println( "【*** ServiceInstance ***】host = " + serviceInstance.getHost() + "、port = " + serviceInstance.getPort() + "、serviceId = " + serviceInstance.getServiceId()); //Dept dept = restTemplate.getForObject(DEPT_GET_URL + id, Dept.class); Dept dept = restTemplate.exchange(DEPT_GET_URL+id, HttpMethod.GET,new HttpEntity<Object>(this.httpHeaders),Dept.class).getBody(); return dept; } @RequestMapping("/list") public List<Dept> list(){ //List<Dept> deptList = restTemplate.getForObject(DEPT_LIST_URL, List.class); List<Dept> deptList = this.restTemplate.exchange(DEPT_LIST_URL,HttpMethod.GET,new HttpEntity<Object>(this.httpHeaders),List.class).getBody(); return deptList; } @RequestMapping("/add") public boolean add(Dept dept){ //Boolean flag = restTemplate.postForObject(DEPT_ADD_URL, dept, Boolean.class); Boolean flag = this.restTemplate.exchange(DEPT_ADD_URL,HttpMethod.POST,new HttpEntity<Object>(this.httpHeaders),Boolean.class).getBody(); return flag; }*/ }
在啟動(dòng)類中加入@EnableFeignClients注解
@SpringBootApplication @EnableEurekaClient @EnableFeignClients(basePackages = {"cn.zgc.service"}) public class FeignConsumer_80_StartSpringCloudApplication { public static void main(String[] args) { SpringApplication.run(FeignConsumer_80_StartSpringCloudApplication.class,args); } }
Feign自帶了負(fù)責(zé)均衡特性,所以使用Feign之后可以不用使用Ribbon。
Feign的配置
Feign 最重要的功能就是將 Rest 服務(wù)的信息轉(zhuǎn)換為接口,但是在實(shí)際的使用之中也需要考慮到一些配置情況,例如:數(shù)據(jù)壓縮, Rest 的核心本質(zhì)在于: JSON 數(shù)據(jù)傳輸( XML、文本),于是就必須思考一種情況,萬(wàn)一用戶發(fā)送的數(shù)據(jù)很大呢? 所以這個(gè)時(shí)候可以考慮修改application.yml 配置文件對(duì)傳輸數(shù)據(jù)進(jìn)行壓縮;
feign: compression: request: mime-types: # 可以被壓縮的類型 - text/xml - application/xml - application/json min-request-size: 2048 # 超過(guò)2048的字節(jié)進(jìn)行壓縮
開啟Feign的日志(默認(rèn)是不開啟的)
logging: level: cn.zgc.service: DEBUG
feign調(diào)用的時(shí)候返回參數(shù)不是期望的數(shù)據(jù)類型
今天碰到個(gè)坑,feign調(diào)用其他應(yīng)用的時(shí)候反參并不是期望的類型;不知道這個(gè)在其他請(qǐng)求方式有沒(méi)有這個(gè)bug
解決的方法
是在feign調(diào)用的那里指定Response<?>的泛型類,我這邊是碰到期望是返回Long類型,但是返回的是Integer類型,不知道是不是隱式轉(zhuǎn)換了,這里記錄一下這個(gè)Bug
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java中PO、VO、BO、POJO、DAO、DTO、TO、QO、Bean、conn的理解
這篇文章主要介紹了java中PO、VO、BO、POJO、DAO、DTO、TO、QO、Bean、conn的理解,需要的朋友可以參考下2020-02-02grade構(gòu)建閱讀spring源碼環(huán)境 Idea2020.3的過(guò)程
這篇文章主要介紹了grade構(gòu)建閱讀spring源碼環(huán)境 Idea2020.3,本文分步驟通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10Java StackTraceElement實(shí)例代碼
這篇文章主要介紹了Java StackTraceElement實(shí)例代碼,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-02-02JVM性能調(diào)優(yōu)實(shí)現(xiàn)原理及配置
這篇文章主要介紹了JVM性能調(diào)優(yōu)實(shí)現(xiàn)原理及配置,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12springboot關(guān)于容器啟動(dòng)事件總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于springboot容器啟動(dòng)事件相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)下。2019-10-10Java中區(qū)別.toString() ,(String),valueOf()方法
這篇文章主要介紹了Java中區(qū)別.toString() ,(String),valueOf()方法,需要的朋友可以參考下2017-01-01詳解rabbitmq使用springboot實(shí)現(xiàn)fanout模式
這篇文章主要介紹了rabbitmq使用springboot實(shí)現(xiàn)fanout模式,Fanout特點(diǎn)是發(fā)布與訂閱模式,是一種廣播機(jī)制,它是沒(méi)有路由key的模式,需要的朋友可以參考下2023-07-07