news 2026/5/23 16:52:00

Java爬虫1688详情api接口实战解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java爬虫1688详情api接口实战解析

下面给出一份可直接落地的「Java 版 1688 商品详情 API 爬虫」完整示例,覆盖签名算法、HTTP 调用、JSON 解析、异常重试、频率控制等关键要点,复制即可运行。
(注:1688 接口需企业认证并申请 AppKey / AppSecret,以下代码以官方 REST 网关item_get为例,也可平替为第三方代理网关,只需换域名即可 。)


一、Maven 依赖

<dependencies> <!-- HTTP --> <dependency> <groupId>org.apache.httpcomponents.client5</groupId> <artifactId>httpclient5</artifactId> <version>5.3.1</version> </dependency> <!-- JSON --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.17.0</version> </dependency> </dependencies>

二、签名工具(1688 官方 MD5 签名规则)

public class SignUtil { public static String sign(TreeMap<String, String> params, String appSecret) { StringBuilder sb = new StringBuilder(appSecret); for (Map.Entry<String, String> e : params.entrySet()) { sb.append(e.getKey()).append(e.getValue()); } sb.append(appSecret); return md5(sb.toString()).toUpperCase(); } private static String md5(String raw) { try { byte[] bs = MessageDigest.getInstance("MD5").digest(raw.getBytes(StandardCharsets.UTF_8)); StringBuilder hex = new StringBuilder(); for (byte b : bs) hex.append(String.format("%02X", b & 0xFF)); return hex.toString(); } catch (Exception e) { throw new RuntimeException(e); } } }

三、统一入口 ——ItemGetService

public class ItemGetService { private static final String GATEWAY = "https://api.1688.com/router/rest"; private final String appKey; private final String appSecret; private final CloseableHttpClient http; public ItemGetService(String appKey, String appSecret) { this.appKey = appKey; this.appSecret = appSecret; this.http = HttpClients.custom() .setConnectionManager(PoolingHttpClientConnectionManagerBuilder.create() .setMaxConnTotal(50).setMaxConnPerRoute(10).build()) .build(); } /** 获取商品详情(自动重试 3 次) */ public ItemDO getItem(long numIid) throws IOException { TreeMap<String, String> params = new TreeMap<>(); params.put("method", "item_get"); params.put("app_key", appKey); params.put("timestamp", String.valueOf(System.currentTimeMillis())); params.put("num_iid", String.valueOf(numIid)); params.put("v", "2.0"); params.put("sign_method", "md5"); params.put("format", "json"); params.put("sign", SignUtil.sign(params, appSecret)); String url = GATEWAY + "?" + URLEncodedUtils.format( params.entrySet().stream() .map(e -> new BasicNameValuePair(e.getKey(), e.getValue())) .collect(Collectors.toList()), StandardCharsets.UTF_8); for (int i = 0; i < 3; i++) { try (CloseableHttpResponse resp = http.execute(new HttpGet(url))) { if (resp.getCode() == 200) { JsonNode root = new ObjectMapper().readTree(EntityUtils.toString(resp.getEntity())); if ("0".equals(root.get("code").asText())) { return new ObjectMapper().convertValue(root.get("item"), ItemDO.class); } throw new IllegalStateException("API 业务错误: " + root.get("msg").asText()); } } catch (Exception e) { if (i == 2) throw e; try { Thread.sleep(1000); } catch (InterruptedException ignore) {} } } throw new RuntimeException("重试 3 次仍失败"); } @Data // lombok public static class ItemDO { private String title; private BigDecimal price; private Integer num; // 库存 private String picUrl; private List<Sku> skus; } public void shutdown() throws IOException { http.close(); } }

四、频率控制 + 批量调用示例

public class CrawlerBoot { public static void main(String[] args) throws Exception { ItemGetService api = new ItemGetService("你的AppKey", "你的AppSecret"); List<Long> numIids = List.of(610947572360L, 623456789012L); // 商品ID池 for (Long id : numIids) { ItemGetService.ItemDO item = api.getItem(id); System.out.printf("标题=%s 价格=%s 库存=%d%n", item.getTitle(), item.getPrice(), item.getNum()); Thread.sleep(350); // 约 3 次/秒,低于官方 5 次/秒限制 } api.shutdown(); } }

五、常见坑 & 优化建议

  1. 签名顺序必须TreeMap升序,否则 4005 授权失败。

  2. 免费账号每日调用上限 1 万次,超出需购买套餐;峰值时段做好限流与重试。

  3. 如需 SKU 图、阶梯价、近 30 天销量,需在参数额外指定fields=skus,priceRange,saleInfo

  4. 若走第三方代理网关(如api-gw.onebound.cn),签名规则不变,仅换域名即可。

  5. 数据落库时建议用ON DUPLICATE KEY UPDATE做幂等,避免重复写入。


六、一句话总结
以上代码即为“Java 爬虫 1688 详情 API 接口”的最小可运行骨架,已帮你屏蔽掉签名、编码、重试、频率等所有细节,直接填上自己的 AppKey / Secret 即可把 1688 商品库变成本地数据表

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 3:51:50

云主机经常被恶意入侵,请问如何有效应对?

云主机因部署灵活、成本可控、扩展性强&#xff0c;已成为企业和个人建站、应用部署的主流选择。但与此同时&#xff0c;云主机长期暴露在公网环境中&#xff0c;也更容易成为黑客扫描、攻击和入侵的目标。许多用户发现&#xff0c;即使只是部署了一个普通网站&#xff0c;服务…

作者头像 李华
网站建设 2026/5/22 1:01:31

Nano banana Pro版在细节上的改进

在人工智能的演进史中&#xff0c;每一个细微的量变往往都预示着一场质变的到来。如果说早期的图像模型是在进行“模糊的像素模拟”&#xff0c;那么Nano Banana Pro的问世&#xff0c;则标志着 AI 正式接管了现实世界的“物理细枝末节”。 这款被誉为视觉生成领域“顶级艺术总…

作者头像 李华
网站建设 2026/5/22 15:13:12

物理信息神经网络(PINNs)完整教程

物理信息神经网络&#xff08;PINNs&#xff09;完整教程 【免费下载链接】PINNs Physics Informed Deep Learning: Data-driven Solutions and Discovery of Nonlinear Partial Differential Equations 项目地址: https://gitcode.com/gh_mirrors/pi/PINNs 物理信息神经…

作者头像 李华
网站建设 2026/5/23 4:16:10

安卓虚拟相机终极指南:3分钟学会手机摄像头魔法

安卓虚拟相机终极指南&#xff1a;3分钟学会手机摄像头魔法 【免费下载链接】com.example.vcam 虚拟摄像头 virtual camera 项目地址: https://gitcode.com/gh_mirrors/co/com.example.vcam 还在为视频会议必须露脸而困扰吗&#xff1f;或者想在直播中使用预先准备好的精…

作者头像 李华
网站建设 2026/5/20 4:51:08

Codeforces竞赛效率工具:cf-tool完整使用指南

在算法竞赛的世界里&#xff0c;每一秒都至关重要。你是否曾在Codeforces比赛中因为频繁切换浏览器和编辑器而错失良机&#xff1f;是否因为手动测试样例、提交代码而浪费宝贵时间&#xff1f;今天&#xff0c;我们将为你介绍一款专为Codeforces设计的命令行工具——cf-tool&am…

作者头像 李华