当前位置: 首页 > article >正文

Java后端如何优雅地封装第三方API调用逻辑以对接美团外卖霸王餐接口

Java后端如何优雅地封装第三方API调用逻辑以对接美团外卖霸王餐接口在Java后端开发中对接第三方API如美团外卖霸王餐接口是常见的需求。直接在业务代码中拼接URL、处理JSON、写HTTP请求不仅导致代码臃肿还难以维护和测试。本文将介绍一种基于Spring Boot的优雅封装方案采用“客户端-请求-响应”分离的设计模式结合OkHttp作为底层HTTP客户端实现高内聚、低耦合的API调用逻辑。1. 引入依赖首先在pom.xml中引入必要的依赖包括Spring Web、OkHttp以及JSON处理库如Jackson或Fastjson。dependenciesdependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependencydependencygroupIdcom.squareup.okhttp3/groupIdartifactIdokhttp/artifactIdversion4.9.3/version/dependencydependencygroupIdcom.alibaba/groupIdartifactIdfastjson/artifactIdversion1.2.83/version/dependency/dependencies2. 定义通用的数据传输对象为了统一处理API响应我们定义通用的请求和响应基类。API响应封装packagecom.baodanbao.cn.model;publicclassMeituanResponseT{privateintcode;privateStringmessage;privateTdata;// 构造函数publicMeituanResponse(){}publicMeituanResponse(intcode,Stringmessage,Tdata){this.codecode;this.messagemessage;this.datadata;}// Getter和SetterpublicintgetCode(){returncode;}publicvoidsetCode(intcode){this.codecode;}publicStringgetMessage(){returnmessage;}publicvoidsetMessage(Stringmessage){this.messagemessage;}publicTgetData(){returndata;}publicvoidsetData(Tdata){this.datadata;}publicbooleanisSuccess(){returnthis.code0;// 假设0为成功}}霸王餐活动请求对象packagecom.baodanbao.cn.model.request;publicclassBawangcanActivityRequest{privateStringappId;privatelongtimestamp;privateStringsign;privateActivityBodybody;// Getter和SetterpublicstaticclassActivityBody{privateStringshopId;privateintlimitCount;privateStringstartDate;privateStringendDate;// Getter和Setter}}3. 封装HTTP客户端创建一个专门的OkHttpClient Bean并配置超时、拦截器等。packagecom.baodanbao.cn.config;importokhttp3.OkHttpClient;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importjava.util.concurrent.TimeUnit;ConfigurationpublicclassHttpClientConfig{BeanpublicOkHttpClientmeituanOkHttpClient(){returnnewOkHttpClient.Builder().connectTimeout(10,TimeUnit.SECONDS).readTimeout(30,TimeUnit.SECONDS).writeTimeout(30,TimeUnit.SECONDS).build();}}4. 核心API客户端封装这是最核心的部分。我们创建一个MeituanBawangcanClient类专门负责与美团接口通信。packagecom.baodanbao.cn.client;importcom.alibaba.fastjson.JSON;importcom.baodanbao.cn.model.MeituanResponse;importcom.baodanbao.cn.model.request.BawangcanActivityRequest;importcom.baodanbao.cn.util.SignUtil;importokhttp3.*;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.stereotype.Component;importjava.io.IOException;ComponentpublicclassMeituanBawangcanClient{privatefinalOkHttpClienthttpClient;privatefinalStringappKey;privatefinalStringappSecret;privatefinalStringapiUrl;AutowiredpublicMeituanBawangcanClient(OkHttpClienthttpClient,Value(${meituan.app-key})StringappKey,Value(${meituan.app-secret})StringappSecret,Value(${meituan.api-url})StringapiUrl){this.httpClienthttpClient;this.appKeyappKey;this.appSecretappSecret;this.apiUrlapiUrl;}/** * 创建霸王餐活动 */publicMeituanResponseStringcreateActivity(BawangcanActivityRequest.ActivityBodybody)throwsIOException{// 1. 构建请求体BawangcanActivityRequestrequestnewBawangcanActivityRequest();request.setAppId(appKey);request.setTimestamp(System.currentTimeMillis()/1000);request.setBody(body);// 2. 生成签名重要StringjsonBodyJSON.toJSONString(request);StringsignSignUtil.generateSign(jsonBody,appSecret);request.setSign(sign);// 3. 序列化最终请求StringfinalJsonJSON.toJSONString(request);// 4. 构建HTTP请求RequesthttpRequestnewRequest.Builder().url(apiUrl/bawangcan/activity/create).post(RequestBody.create(finalJson,MediaType.get(application/json; charsetutf-8))).build();// 5. 执行调用try(ResponseresponsehttpClient.newCall(httpRequest).execute()){if(!response.isSuccessful())thrownewIOException(Unexpected code response);ResponseBodyresponseBodyresponse.body();if(responseBodynull)thrownewIOException(Empty response body);StringresultresponseBody.string();// 6. 解析响应returnJSON.parseObject(result,newTypeReferenceMeituanResponseString(){}.getType());}}}5. 签名工具类第三方API通常需要签名验证我们将签名逻辑独立出来。packagecom.baodanbao.cn.util;importjavax.crypto.Mac;importjavax.crypto.spec.SecretKeySpec;importjava.nio.charset.StandardCharsets;importjava.security.InvalidKeyException;importjava.security.NoSuchAlgorithmException;publicclassSignUtil{privatestaticfinalStringHMAC_SHA256HmacSHA256;publicstaticStringgenerateSign(Stringcontent,Stringsecret)throwsException{try{MacmacMac.getInstance(HMAC_SHA256);SecretKeySpecsecretKeySpecnewSecretKeySpec(secret.getBytes(StandardCharsets.UTF_8),HMAC_SHA256);mac.init(secretKeySpec);byte[]signDatamac.doFinal(content.getBytes(StandardCharsets.UTF_8));// 这里简化实际需要转为Hex字符串returnbytesToHex(signData);}catch(NoSuchAlgorithmException|InvalidKeyExceptione){thrownewException(签名生成失败,e);}}privatestaticStringbytesToHex(byte[]bytes){StringBuilderresultnewStringBuilder();for(byteb:bytes){result.append(String.format(%02x,b));}returnresult.toString();}}6. 在业务Service中使用封装完成后业务层代码变得非常简洁清晰。packagecom.baodanbao.cn.service;importcom.baodanbao.cn.client.MeituanBawangcanClient;importcom.baodanbao.cn.model.MeituanResponse;importcom.baodanbao.cn.model.request.BawangcanActivityRequest;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.stereotype.Service;ServicepublicclassMarketingService{AutowiredprivateMeituanBawangcanClientmeituanClient;publicStringlaunchBawangcanCampaign(StringshopId,intlimit){try{BawangcanActivityRequest.ActivityBodybodynewBawangcanActivityRequest.ActivityBody();body.setShopId(shopId);body.setLimitCount(limit);// ... 设置其他参数MeituanResponseStringresponsemeituanClient.createActivity(body);if(response.isSuccess()){return活动创建成功ID: response.getData();}else{returnAPI调用失败: response.getMessage();}}catch(Exceptione){e.printStackTrace();return系统异常;}}}7. 配置文件示例在application.yml中配置美团相关的参数。meituan:app-key:your_app_key_hereapp-secret:your_app_secret_hereapi-url:https://openapi.meituan.com本文著作权归 俱美开放平台 转载请注明出处

相关文章:

Java后端如何优雅地封装第三方API调用逻辑以对接美团外卖霸王餐接口

Java后端如何优雅地封装第三方API调用逻辑以对接美团外卖霸王餐接口 在Java后端开发中,对接第三方API(如美团外卖霸王餐接口)是常见的需求。直接在业务代码中拼接URL、处理JSON、写HTTP请求不仅导致代码臃肿,还难以维护和测试。 本…...

Youtu-VL-4B-Instruct-GGUF模型安全考量:在网络安全领域的潜在应用与风险

Youtu-VL-4B-Instruct-GGUF模型安全考量:在网络安全领域的潜在应用与风险 最近和几个做安全的朋友聊天,他们都在头疼一个问题:现在的网络攻击越来越“花里胡哨”了。以前可能就是一段恶意代码,现在呢?一张精心设计的钓…...

从长城杯赛题到实战:基于ZeroShell防火墙的威胁流量深度狩猎

1. 从CTF赛题到真实威胁狩猎的思维转换 第一次接触长城杯那道ZeroShell防火墙的赛题时,我还在纳闷:这种刻意设计的漏洞场景,在真实企业里真的存在吗?直到上个月帮某制造业客户做安全巡检,亲眼看到他们的ZeroShell 3.9.…...

从取证到防御:实战解析BadUSB攻击与USB流量异常检测(Wireshark实战)

从取证到防御:实战解析BadUSB攻击与USB流量异常检测(Wireshark实战) 在企业内网安全防护中,USB设备带来的威胁往往被低估。去年某金融机构遭遇的供应链攻击事件中,攻击者通过伪装成键盘的BadUSB设备,在3分钟…...

Alpamayo-R1-10B实战案例:自动驾驶算法工程师日常调试VLA模型工作流

Alpamayo-R1-10B实战案例:自动驾驶算法工程师日常调试VLA模型工作流 1. 项目概述 Alpamayo-R1-10B是专为自动驾驶研发设计的开源视觉-语言-动作(VLA)模型,基于100亿参数架构构建。这套工具链包含AlpaSim模拟器和Physical AI AV数据集,旨在通…...

单细胞测序入门(一):技术概览与数据获取实战

1. 单细胞测序技术全景解读 第一次接触单细胞测序时,我被这项技术的精妙设计深深震撼。想象一下,传统测序就像把水果榨成混合果汁检测成分,而单细胞测序则是把每个苹果、香蕉、葡萄分开榨汁分析——这就是单细胞分辨率带来的革命性视角。 核心…...

Llama-3.2V-11B-cot与Dify集成:零代码构建企业AI智能体

Llama-3.2V-11B-cot与Dify集成:零代码构建企业AI智能体 最近和几个做企业服务的朋友聊天,大家普遍有个感觉:现在AI模型能力越来越强,但真要把它们用起来,门槛还是有点高。特别是对于业务部门的人来说,看着…...

Aurix/Tricore实验解析:从链接脚本到汇编指令的Trap向量表构建

1. 理解Trap机制与向量表基础 在Aurix/Tricore架构中,Trap(陷阱)是处理器响应异常事件的硬件机制,相当于汽车的安全气囊——平时看不见,但遇到碰撞时会立即触发保护。与中断不同,Trap是同步触发的&#xff…...

PaddlePaddle GPU环境搭建:从驱动到深度学习库的完整指南

1. 为什么需要GPU加速深度学习? 如果你刚接触深度学习,可能会疑惑为什么大家都在讨论GPU。简单来说,GPU就像是个超级计算器,能同时处理大量简单计算。想象你要算100万道加减法题,用普通计算器(CPU&#xf…...

GLM-4.1V-9B-Base基础教程:Web界面支持的图片格式/大小/分辨率清单

GLM-4.1V-9B-Base基础教程:Web界面支持的图片格式/大小/分辨率清单 1. 模型简介 GLM-4.1V-9B-Base是智谱开源的视觉多模态理解模型,专门用于处理图像内容识别、场景描述、目标问答和中文视觉理解任务。这个模型已经完成了Web化封装,可以直接…...

告别手动点鼠标!用Python脚本批量跑Simulink仿真,效率提升10倍

告别手动点鼠标!用Python脚本批量跑Simulink仿真,效率提升10倍 在工程仿真领域,Simulink无疑是建模与分析的利器。但当面对参数扫描、蒙特卡洛分析或设计迭代等需要大量重复仿真的场景时,手动操作不仅效率低下,还容易…...

500+精选RSS源如何解决信息获取难题:Awesome RSS Feeds全解析

500精选RSS源如何解决信息获取难题:Awesome RSS Feeds全解析 【免费下载链接】awesome-rss-feeds Awesome RSS feeds - A curated list of RSS feeds (and OPML files) used in Recommended Feeds and local news sections of Plenary - an RSS reader, article dow…...

Phi-3-mini-4k-instruct-gguf实战教程:开箱即用的轻量中文问答部署指南

Phi-3-mini-4k-instruct-gguf实战教程:开箱即用的轻量中文问答部署指南 1. 认识Phi-3-mini-4k-instruct-gguf Phi-3-mini-4k-instruct-gguf是微软Phi-3系列中的轻量级文本生成模型GGUF版本。这个模型特别适合处理中文问答、文本改写、摘要整理以及简短创作等任务。…...

4象限解析OpenRocket:开源火箭仿真工具的技术突破与实践指南

4象限解析OpenRocket:开源火箭仿真工具的技术突破与实践指南 【免费下载链接】openrocket Model-rocketry aerodynamics and trajectory simulation software 项目地址: https://gitcode.com/GitHub_Trending/op/openrocket 在模型火箭设计领域,物…...

跨平台终端与进程控制:从原理到实践

跨平台终端与进程控制:从原理到实践 【免费下载链接】node-pty Fork pseudoterminals in Node.JS 项目地址: https://gitcode.com/gh_mirrors/no/node-pty 在现代软件开发中,终端交互和进程管理是不可或缺的核心能力。无论是构建IDE、开发自动化工…...

如何极速获取金融市场数据:5分钟实战指南

如何极速获取金融市场数据:5分钟实战指南 【免费下载链接】qstock qstock由“Python金融量化”公众号开发,试图打造成个人量化投研分析包,目前包括数据获取(data)、可视化(plot)、选股(stock)和量化回测(策…...

从手动压枪到智能辅助:探索罗技鼠标宏在PUBG中的进化之路

从手动压枪到智能辅助:探索罗技鼠标宏在PUBG中的进化之路 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 当你在绝地求生的激烈对枪中…...

Agent的决策模糊

文章目录Langchian Agent内部记忆:信息过载LLM注意力有限的解释:上下文窗口长度很大,会有这种问题么对比langGraphLangchian Agent内部记忆: 官方 ReAct 内部机制(铁律) LangChain 的 AgentExecutor 在一次 invoke () 内部&#…...

电源管理入门-5 arm-scmi和mailbox核间通信

上篇介绍了电源管理入门-4子系统reset,提到子系统reset的执行为了安全可以到SCP里面去执行,但是怎么把这个消息传递过去呢,答案就是mailbox。Mailbox是核间通信软硬件的统称。在软件上可以使用SCMI协议共享内存报文头,在硬件上可以…...

新手零基础入门CAN总线:借助快马AI生成可运行代码理解通信机制

作为一个刚接触嵌入式开发的菜鸟,最近被导师要求学习CAN总线协议。面对手册里密密麻麻的寄存器配置和报文格式说明,我一度怀疑自己是不是选错了专业方向。直到发现了InsCode(快马)平台,用它的AI生成功能快速搭建了一个可运行的CAN通信demo&am…...

第3期 工程车辆目标检测数据集

第3期 目标检测——工程车辆数据集 一、研究背景与意义 工程车辆是建筑工程机械的核心组成部分,涵盖汽车吊、随车吊、挖掘机、推土机、压路机、工程抢险车等品类,承担着工程建设中的运载、挖掘、吊运、平整、抢修等关键工作,大幅提升了建筑工程施工效率,显著降低人力投入…...

转行AIGC,杭州培训助你3个月入职大厂

转行AIGC,杭州培训助你3个月入职大厂 最近,很多小伙伴私信我,说想转行做AIGC相关工作,但苦于没有方向,不知道从哪里入手。今天就给大家分享一个真实案例,看看他是如何在短短3个月内成功转型,并…...

Power BI 网页数据抓取实战:以新浪外汇为例,教你5分钟搞定动态表格导入与清洗

Power BI 网页数据抓取实战:新浪外汇动态表格导入与清洗全流程解析 外汇市场瞬息万变,作为业务分析师,每天手动记录汇率数据既耗时又容易出错。今天我们就以新浪财经外汇数据为例,手把手教你用Power BI实现5分钟自动化抓取清洗的完…...

bilibili-api完全指南:评论数据爬取的4个突破式解决方案

bilibili-api完全指南:评论数据爬取的4个突破式解决方案 【免费下载链接】bilibili-api 哔哩哔哩常用API调用。支持视频、番剧、用户、频道、音频等功能。原仓库地址:https://github.com/MoyuScript/bilibili-api 项目地址: https://gitcode.com/gh_mi…...

AFL++实战:从零开始用WSL搭建模糊测试环境(附libxml2案例)

AFL实战指南:WSL环境下的模糊测试从入门到精通 模糊测试(Fuzz Testing)作为软件安全测试的重要手段,近年来在漏洞挖掘领域展现出惊人的效果。对于Windows平台开发者而言,Windows Subsystem for Linux(WSL&…...

Mongo(2): MongoDB权限认证实战——从零配置用户角色与访问控制

1. MongoDB权限认证的必要性 第一次接触MongoDB时,很多人都会被它"开箱即用"的特性吸引——安装完成后不需要任何配置就能直接操作数据库。这种便利性在开发测试阶段确实很友好,但一旦进入生产环境,就相当于把自家大门敞开给所有人…...

GLM-5.1 全面支持与 Gemini CLI 集成:HagiCode 的多模型进化之路

GLM-5.1 全面支持与 Gemini CLI 集成:HagiCode 的多模型进化之路 本文介绍了 HagiCode 平台近期的重要更新——智谱 AI GLM-5.1 模型的全面支持,以及 Gemini CLI 作为第十个 Agent CLI 的成功集成。这两项更新进一步强化了平台的多模型能力和多 CLI 生态…...

3大核心价值!六音音源开源工具:洛雪音乐跨版本修复解决方案

3大核心价值!六音音源开源工具:洛雪音乐跨版本修复解决方案 【免费下载链接】New_lxmusic_source 六音音源修复版 项目地址: https://gitcode.com/gh_mirrors/ne/New_lxmusic_source 在数字音乐体验日益依赖软件生态的今天,洛雪音乐1.…...

别再死记硬背公式了!用Simulink玩转单相全桥逆变,从方波驱动到IGBT参数设置全解析

用Simulink玩转单相全桥逆变:从方波驱动到IGBT参数设置的实战指南 电力电子领域的学习常常陷入公式推导的泥潭,而Simulink提供的可视化仿真环境就像一盏明灯。想象一下,当你调整一个参数就能立即看到波形变化,比纸上推导要直观十倍…...

pvr.iptvsimple技术解构:IPTV直播系统构建的底层逻辑与实践指南

pvr.iptvsimple技术解构:IPTV直播系统构建的底层逻辑与实践指南 【免费下载链接】pvr.iptvsimple IPTV Simple client for Kodi PVR 项目地址: https://gitcode.com/gh_mirrors/pv/pvr.iptvsimple 问题定位:IPTV直播系统的技术痛点与架构挑战 IP…...