游乐游手机版
首页/AI教程/文章详情

京东商品详情API接口开发指南(Java/Python实现)

时间:2026-06-11 16:25
京东商品详情API可通过SKUID获取商品标题、价格、促销等信息,支持批量查询(最多20个SKU)、JSON返回格式、签名验证与HTTPS加密。提供Java和Python实现示例,开发时需先申请权限,注意每秒100次调用限制及签名算法准确性。

京东商品详情API接口详解:功能、特点与开发实现指南

京东商品详情API接口开发指南(含Ja va/Python实现)

京东开放平台为开发者提供了实用的商品详情查询API接口。简单来说,只要传入SKUID,就能快速获取商品标题、价格、高清图片、促销活动等完整信息。在电商数据抓取需求旺盛、响应速度要求高的当下,这个京东商品详情接口能大幅提升开发效率。但需要特别留意的是,使用前必须先申请接口权限并获取认证密钥,这是绕不开的前提条件。

京东商品详情API接口核心特点

先来看看这个接口的几个关键优势。

批量查询是一大亮点:单次请求最多可查询20个SKU,数据处理效率瞬间拉满。根据市场反馈数据显示,使用批量查询功能后,数据采集时间可缩短约70%,特别适合需要进行大规模商品对比分析的业务场景。

数据格式方面,接口返回标准的JSON结构,主流编程语言几乎都能直接解析调用,开发门槛自然也就降低了。

安全性方面也考虑得相当周全:采用签名验证机制确保数据在传输过程中不被篡改或攻击,开发者和平台都能放心使用。再加上全面支持HTTPS加密协议,在当前网络安全环境下,相当于为数据传输加了一把安全锁。

Ja va语言实现京东商品详情API调用示例

先来看Ja va版本的实现方式。代码逻辑非常清晰,核心步骤包括构造请求参数、生成接口签名、发送HTTP请求。需要注意的是签名算法采用MD5加密,拼接参数时必须严格按照排序规则来,顺序不能出错。

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import org.apache.commons.codec.digest.DigestUtils;
import ja va.io.BufferedReader;
import ja va.io.InputStreamReader;
import ja va.net.HttpURLConnection;
import ja va.net.URL;
import ja va.util.HashMap;
import ja va.util.Map;
import ja va.util.TreeMap;

public class JdProductApi {
    private static final String API_URL = "https://api.jd.com/routerjson";
    private static final String VERSION = "1.0";

    public static String queryProductDetail(long skuId, String appKey, String appSecret) {
        try {
            // 精心构造请求参数
            Map params = new TreeMap<>();
            params.put("method", "jd.union.open.goods.detail.query");
            params.put("app_key", appKey);
            params.put("timestamp", System.currentTimeMillis());
            params.put("v", VERSION);
            params.put("format", "json");

            // 构建商品请求参数
            JSONObject goodsReq = new JSONObject();
            goodsReq.put("skuIds", new long[]{skuId});
            params.put("goodsReq", goodsReq);

            // 严格生成签名
            String sign = generateSign(params, appSecret);
            params.put("sign", sign);

            // 准确发送请求
            URL url = new URL(API_URL);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("POST");
            conn.setDoOutput(true);
            conn.getOutputStream().write(JSON.toJSONString(params).getBytes());

            // 高效处理响应
            BufferedReader reader = new BufferedReader(
                new InputStreamReader(conn.getInputStream()));
            StringBuilder response = new StringBuilder();
            String line;
            while ((line = reader.readLine()) != null) {
                response.append(line);
            }
            return response.toString();
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    private static String generateSign(Map params, String appSecret) {
        StringBuilder sb = new StringBuilder(appSecret);
        for (Map.Entry entry : params.entrySet()) {
            sb.append(entry.getKey()).append(entry.getValue());
        }
        sb.append(appSecret);
        return DigestUtils.md5Hex(sb.toString()).toUpperCase();
    }
}

Python语言实现京东商品详情API调用示例

Python版本的实现更加简洁,借助requests库一行代码就能完成请求发送。签名生成逻辑与Ja va版本完全一致,只是语法换成了Python风格。

import hashlib
import time
import json
import requests

class JdProductApi:
    API_URL = "https://api.jd.com/routerjson"
    VERSION = "1.0"

    @staticmethod
    def query_product_detail(sku_id, app_key, app_secret):
        params = {
            "method": "jd.union.open.goods.detail.query",
            "app_key": app_key,
            "timestamp": int(time.time() * 1000),
            "v": JdProductApi.VERSION,
            "format": "json",
            "goodsReq": {"skuIds": [sku_id]}
        }

        # 严谨生成签名
        sign = JdProductApi.generate_sign(params, app_secret)
        params["sign"] = sign

        # 可靠发送请求
        response = requests.post(
            JdProductApi.API_URL,
            json=params,
            headers={"Content-Type": "application/json"}
        )
        return response.json()

    @staticmethod
    def generate_sign(params, app_secret):
        param_str = app_secret
        for key in sorted(params.keys()):
            param_str += f"{key}{params[key]}"
        param_str += app_secret
        return hashlib.md5(param_str.encode()).hexdigest().upper()

京东商品详情API接口返回数据示例

请求成功后,接口返回的数据结构如下(JSON格式展示):

{
    "code": 0,
    "message": "success",
    "data": {
        "skuId": 1234567,
        "skuName": "示例商品名称",
        "price": 299.00,
        "imageList": ["https://img1.jpg", "https://img2.jpg"],
        "brandName": "示例品牌",
        "category": "电子产品",
        "shopId": 10001,
        "shopName": "官方旗舰店",
        "promotionList": [
            {
                "promotionId": 1,
                "promotionName": "满299减30",
                "startTime": "2025-05-01 00:00:00",
                "endTime": "2025-05-31 23:59:59"
            }
        ]
    }
}

京东商品详情API开发注意事项与避坑指南

最后总结几个容易踩坑的关键点:

  • 权限申请先行:不要急着调接口,先去京东开放平台完成API权限申请,这是硬性前提。
  • 频率限制牢记:每个应用默认每秒最多调用100次,超出限制就会被限流。建议提前规划好调用节奏,避免程序运行中途中断。
  • 签名算法精准:官方文档怎么写就怎么实现,任何细微偏差都会导致签名验证失败。参数排序、拼接顺序、MD5大小写,每一个细节都要对得上。
  • 协议选择恰当:强烈建议使用HTTPS协议,虽然HTTP也能用,但数据传输没有加密,容易被中间人截获。
  • 异常处理全面:网络超时、参数错误、返回码非0等情况都要提前考虑,加上try-catch或容错逻辑,否则线上环境容易出大问题。

以上代码分别给出了Ja va和Python两种实现方案,大家可以根据自身技术栈选择合适的版本。实际集成时,记得将appKey和appSecret替换成自己的凭证,并补全完善的错误处理逻辑。这样基本就能稳定获取京东商品的详细数据了。

来源:https://developer.aliyun.com/article/1740699
上一篇RAG检索增强生成从入门到实战指南 下一篇在CentOS 7系统上安装Tomcat 7.0.27解压配置启动部署完整步骤
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
微软Copilot插件安装全流程:浏览器与扩展市场配置
AI教程 · 2026-07-01

微软Copilot插件安装全流程:浏览器与扩展市场配置

围绕MicrosoftCopilot在浏览器、编辑器和扩展市场中的安装与配置,梳理账号准备、安装步骤、权限检查、常见故障及安全使用边界,适合新手快速完成AI办公工具部署。

Microsoft Copilot Docker 一键部署指南:镜像拉取、端口映射与数据目录配置
AI教程 · 2026-07-01

Microsoft Copilot Docker 一键部署指南:镜像拉取、端口映射与数据目录配置

围绕Copilot类AI办公工具的Docker部署流程,说明镜像选择、拉取校验、端口映射、数据目录挂载、环境变量配置、更新回滚与常见故障处理。

微软Copilot API密钥注册获取与国内网络配置
AI教程 · 2026-07-01

微软Copilot API密钥注册获取与国内网络配置

围绕MicrosoftCopilot相关接口接入流程,梳理账号准备、Azure资源创建、密钥获取、环境变量配置、国内网络连通性优化、常见报错处理与安全管理要点。

微软Copilot Linux部署:环境准备到后台运行全流程
AI教程 · 2026-07-01

微软Copilot Linux部署:环境准备到后台运行全流程

MicrosoftCopilot不适合按本地模型方式安装,Linux服务器更常见的是部署企业入口或集成服务。流程需完成账号授权、运行环境、服务配置、反向代理、进程守护与日志监控,并注意数据权限、访问控制和合规边界。

Microsoft Copilot macOS安装教程:Apple Silicon与Intel配置步骤
AI教程 · 2026-07-01

Microsoft Copilot macOS安装教程:Apple Silicon与Intel配置步骤

MicrosoftCopilot在Mac上可通过网页应用、Edge侧边栏或Microsoft365组件使用,AppleSilicon与Intel机型重点在系统版本、浏览器、账号授权和隐私设置。