openfegin上传文件并返回数据 动态请求头和请求路径

本文介绍了一种使用Spring Cloud OpenFeign调用OCR接口的方法,通过具体的代码示例展示了如何从图片中提取文本信息,包括配置Feign客户端、定义服务接口及自测代码。

背景

    调用OCR接口传入图片并返回值识别后数据

代码实现

import gm.ocr.demo.config.FeginClientConfig;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestHeader;


@FeignClient(name = "ocr",url = "${ocr.url}",configuration = FeginClientConfig.class)
@Service
public interface FeginOcrService {
    /**
     * 功能描述: <br>
     * 〈
     * 本方法为调用OCR通用方法
     * 调用OCR接口 传入image byte[] 返回图片 信息
     * app_key 和 app_secret 请求头里需包含
     * file image文件
     * url 请求路径〉
     * @Param: [key , secret, file, url]
     * @Return: java.lang.String
     * @Date: 2020/4/8 15:23
     */
    @PostMapping(value = "{url}",headers = {"content-type=application/octet-stream","connection=Keep-Alive"})
    public String queryImageData(@RequestHeader(name = "app-key") String key, @RequestHeader(name = "app-secret") String secret, @RequestBody byte[] file, @PathVariable("url") String url);



}
FeginClientConfig  设置fegin日志级别     
yml配置
logging:
  level:
    xx.xx.xx.rpcservice: debug
@Component
public class FeginClientConfig {

    @Bean
    Logger.Level feignLevel(){
        return Logger.Level.FULL;
    }



}

自测代码

@SpringBootTest
class GmOcrDemoApplicationTests {

    @Autowired
    FeginOcrService feginOcrService;


    @Test
    void contextLoads1() throws Exception {
        String appKey = "xxx"; // your appKey
        String appSecret = "xxx";// your appSecret 
        String url = "/id";
        contextLoads2(appKey, appSecret, "E:\\test\\ocr\\1.png", url);
    }


    void contextLoads2(String appKey, String appSecret, String fileUrl, String url) throws Exception {
        String s = feginOcrService.queryImageData(appKey, appSecret, readfile(fileUrl), url);
        System.out.println(url + " = response = " + s);
    }


    public static byte[] readfile(String path) {
        String imgFile = path;
        InputStream in = null;
        byte[] data = null;
        try {
            in = new FileInputStream(imgFile);
            data = new byte[in.available()];
            in.read(data);
            in.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return data;
    }


}

 

OpenFeign动态加载可从动态代理动态路由配置两方面来理解其方法与实现。 OpenFeign使用JDK的动态代理来实现动态加载。OpenFeign的`@FeignClient`能解析SpringMVC的`@RequestMapping`注解下的接口,通过动态代理的方式产生实现类。它提供了一种声明式的远程调用接口,大幅简化远程调用的编程体验。在接口远程方法调用时运用动态代理,以此实现动态加载功能[^1]。 在动态路由配置方面,OpenFeign动态加载还可通过配置动态路由来实现。`LocalService`发起的底层方法调用会被OpenFeign生成的代理对象接管,由代理对象发起远程服务调用,将结果返回给`LocalService`。在OpenFeign通过动态代理技术创建代理对象的过程中,可将对应的路由设置到对应的代理对象中,从而实现动态加载,达成本地调试等目的[^3]。 以下是一个简单示例代码说明动态路由配置思路: ```java import feign.Feign; import feign.RequestInterceptor; import feign.RequestTemplate; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import java.util.HashMap; import java.util.Map; @Configuration public class FeignConfig { // 模拟动态路由配置 private static final Map<String, String> dynamicRoutes = new HashMap<>(); static { dynamicRoutes.put("service1", "http://dynamic-url-1"); dynamicRoutes.put("service2", "http://dynamic-url-2"); } @Bean public RequestInterceptor dynamicRouteInterceptor() { return new RequestInterceptor() { @Override public void apply(RequestTemplate template) { // 根据服务名获取动态路由 String serviceName = getServiceNameFromTemplate(template); String dynamicUrl = dynamicRoutes.get(serviceName); if (dynamicUrl != null) { template.uri(dynamicUrl + template.path()); } } private String getServiceNameFromTemplate(RequestTemplate template) { // 这里需要根据实际情况从 RequestTemplate 中提取服务名 // 示例代码简单处理,实际可能需要根据具体规则解析 return "service1"; } }; } // 示例接口 interface MyFeignClient { // 定义接口方法 } // 创建 Feign 客户端 MyFeignClient myFeignClient = Feign.builder() .requestInterceptor(dynamicRouteInterceptor()) .target(MyFeignClient.class, "http://default-url"); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值