如何高效爬取天猫商品数据?官方API与非官方接口全解析

简介: 本文介绍两种天猫商品数据爬取方案:官方API和非官方接口。官方API合法合规,适合企业长期使用,需申请企业资质;非官方接口适合快速验证需求,但需应对反爬机制。详细内容涵盖开发步骤、Python实现示例、反爬策略、数据解析与存储、注意事项及扩展应用场景。推荐工具链包括Playwright、aiohttp、lxml等。如需进一步帮助,请联系作者。

一、方案概述

本文提供两种爬取天猫商品数据的技术方案:

  1. 官方API方案:合法合规,需企业资质,推荐长期稳定使用
  2. 非官方接口方案:适合快速验证需求,需技术对抗反爬机制

二、官方API方案详解

1. 天猫开放平台接口

  • 适用场景:企业级数据采集需求
  • 接口优势
  • 数据完整度高(含商品详情、价格、评论等)
  • 官方维护,稳定性强
  • 支持分页和批量查询
开发步骤:
  1. 注册开发者账号:open.taobao.com
  2. 申请接口权限
  • taobao.item.get:商品详情
  • taobao.items.search:商品搜索
  1. 安装SDK
pip install alibabacloud-python-sdk-core
  1. 签名请求示例
from alibabacloud_tea_openapi import models as open_api_models
from alibabacloud_tbk_dg import models as tbk_dg_models
from alibabacloud_tbk_dg.client import Client
config = open_api_models.Config(
    app_key="your_app_key",
    app_secret="your_app_secret",
    region_id="cn-hangzhou"
)
client = Client(config)
request = tbk_dg_models.TbkItemInfoGetRequest(
    num_iid=654321  # 商品ID
)
response = client.tbk_item_info_get(request)
print(response.body)

三、非官方接口实战

1. 接口逆向分析

核心API:
GET https://h5api.m.taobao.com/h5/mtop.taobao.detail.getdetail/6.0/
参数构造:
{
  "itemNumId": "654321",
  "isForbidBuyItem": false,
  "isForbidPromotion": false,
  "sellerId": "123456"
}
关键参数说明:

参数名

作用

生成方式

sign

签名验证

JS逆向生成(需解密)

t

时间戳

当前时间戳(秒级)

User-Agent

浏览器指纹

随机生成(如iOS/Android)

2. Python实现示例

import requests
import execjs
# JS解密逻辑(需根据实际逆向代码调整)
with open('sign.js', 'r') as f:
    sign_js = f.read()
ctx = execjs.compile(sign_js)
sign = ctx.call('generate_sign', params)
headers = {
    'User-Agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 14_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.1.1 Mobile/15E148 Safari/604.1',
    'Cookie': 't=your_cookie; cna=xxx;'
}
url = f'https://h5api.m.taobao.com/h5/mtop.taobao.detail.getdetail/6.0/?sign={sign}&data={data}'
response = requests.get(url, headers=headers)
print(response.json())

四、反反爬策略

1. 动态参数对抗

  • sign参数:定期更新解密逻辑
  • t参数:每次请求生成新时间戳
  • User-Agent:使用fake_useragent轮换

2. 代理池方案

from requests_rotating_proxy import RotatingProxyManager
proxy_manager = RotatingProxyManager([
    'http://user:[email protected]:8080',
    'http://user:[email protected]:8080'
])
response = requests.get(url, proxies=proxy_manager.get_proxy())

3. 行为模拟

import time
import random
# 随机延迟(0.5-2秒)
time.sleep(random.uniform(0.5, 2.0))
# 模拟真实用户行为
# 可结合selenium/playwright添加鼠标移动、点击等操作

五、数据解析与存储

1. 核心字段提取

data = response.json()
item_info = {
    '商品ID': data['itemNumId'],
    '标题': data['title'],
    '价格': data['price']['viewPrice'],
    '销量': data['soldQuantity'],
    '评论数': data['reviewCount']
}

2. 存储方案

  • 结构化存储:MySQL/PostgreSQL
  • 分布式存储:HBase/Elasticsearch
  • 临时缓存:Redis(存储已爬取商品ID)

六、注意事项

  1. 法律合规
  • 遵守《电子商务法》第24条用户信息保护规定
  • 避免爬取用户隐私数据(如收货地址)
  1. 反爬对抗
  • 定期更新JS解密逻辑
  • 使用分布式高匿代理(推荐Bright Data)
  1. 性能优化
  • 异步请求(aiohttp+asyncio)
  • 结果缓存(Redis LRU策略)

七、扩展应用场景

  1. 商品比价监控:定时获取价格波动数据
  2. 竞品分析:监控同类商品销量、评价
  3. 库存预警:监听stockQuantity字段变化
  4. 评论情感分析:结合NLP处理用户评价

八、推荐工具链

工具类型

推荐工具

浏览器自动化

Playwright(首选)、Selenium

请求库

aiohttp(异步)、httpx(HTTP/2)

数据解析

lxml(XPath)、BeautifulSoup

JS逆向

Charles + Jadx + PyExecJS

代理池

Bright Data、Oxylabs

如遇任何疑问或有进一步的需求,请随时与我私信或者评论联系

相关文章
|
2月前
|
JSON 安全 API
亚马逊商品列表API秘籍!轻松获取商品列表数据
亚马逊商品列表API(SP-API)提供标准化接口,支持通过关键词、分类、价格等条件搜索商品,获取ASIN、价格、销量等信息。采用OAuth 2.0认证与AWS签名,保障安全。数据以JSON格式传输,便于开发者批量获取与分析。
|
2月前
|
JSON 缓存 算法
如何通过API获取1688商品类目数据:技术实现指南
1688开放平台提供alibaba.category.get接口,支持获取全量商品类目树。RESTful架构,返回JSON数据,含类目ID、名称、层级等信息。需注册账号、创建应用并授权。请求需签名认证,QPS限10次,建议缓存更新周期≥24小时。
310 2
|
2月前
|
缓存 监控 前端开发
顺企网 API 开发实战:搜索 / 详情接口从 0 到 1 落地(附 Elasticsearch 优化 + 错误速查)
企业API开发常陷参数、缓存、错误处理三大坑?本指南拆解顺企网双接口全流程,涵盖搜索优化、签名验证、限流应对,附可复用代码与错误速查表,助你2小时高效搞定开发,提升响应速度与稳定性。
|
2月前
|
JSON 监控 API
小红书笔记评论API:一键获取分层评论与用户互动数据
小红书笔记评论API可获取指定笔记的评论详情,包括内容、点赞数、评论者信息等,支持分页与身份认证,返回JSON格式数据,适用于舆情监控、用户行为分析等场景。
|
2月前
|
数据采集 JSON API
微店API使用指南:高效获取商品列表数据
本文介绍如何使用Python爬虫调用微店item_search接口,根据关键词搜索商品并获取商品列表数据,涵盖请求方式、JSON数据解析、分页参数设置及筛选排序功能,适用于电商数据分析与竞品研究。
|
2月前
|
JSON API 数据格式
淘宝拍立淘按图搜索API系列,json数据返回
淘宝拍立淘按图搜索API系列通过图像识别技术实现商品搜索功能,调用后返回的JSON数据包含商品标题、图片链接、价格、销量、相似度评分等核心字段,支持分页和详细商品信息展示。以下是该API接口返回的JSON数据示例及详细解析:
|
2月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
2月前
|
自然语言处理 算法 数据可视化
看球总刷比分?好奇数据哪来的?你该认识一下「体育API」了
体育API是赛事数据的“幕后搬运工”,实时同步比分、赛程、球员统计等信息,支撑各类应用提供精准推送、深度分析与互动体验,让观赛更智能高效。
414 150
|
2月前
|
XML JSON API
苏宁商品详情API秘籍!轻松获取商品详情数据
苏宁商品详情API基于RESTful架构,支持JSON/XML格式,通过AppKey、AppSecret与签名三重认证,结合OAuth 2.0实现安全调用。开发者可获取商品名称、价格、销量、库存、促销等实时数据,适用于电商分析与商业智能。接口强制使用HTTPS协议,支持POST/GET请求,统一采用UTF-8编码,确保数据传输安全可靠。
|
2月前
|
自然语言处理 监控 API
速卖通商品详情API秘籍!轻松获取SKU属性数据
速卖通商品详情API(aliexpress.item.get)支持通过编程获取商品标题、价格、SKU、库存、销量、物流模板、评价及店铺信息,适用于价格监控、选品分析等场景。接口支持多语言返回,采用AppKey+AppSecret+Token认证,需签名验证,确保安全调用。

推荐镜像

更多
  • DNS