一、接口概述
1688开放平台提供item_search_img接口(又称"拍立淘"),支持通过上传图片搜索相似/同款商品,返回商品ID、标题、价格、销量、图片链接等核心信息,适用于电商比价、供应链选品、智能推荐等场景。
二、使用前准备
- 注册与认证
- 在1688开放平台注册企业账号,完成企业认证(需营业执照、法人身份证等)。
- 创建应用(如"供应链分析系统"),获取
App Key和App Secret,用于接口身份验证。 - 申请接口权限:在控制台申请
com.alibaba.product.search权限,说明用途(如"采购比价系统")。
- 图片要求
- 格式:JPG/PNG/WEBP,单张≤5MB(推荐300×300像素以上,清晰无变形)。
- 上传方式:支持图片URL或Base64编码数据(需先通过
1688.upload.img接口上传至图片服务器,获取imgid)。
三、接口调用步骤
-
生成签名
使用HMAC-SHA1或MD5算法,结合
App Secret对请求参数排序后生成签名。示例代码:python`import hashlib import hmac import urllib.parse def generate_sign(params, app_secret): sorted_params = sorted(params.items()) query_str = urllib.parse.urlencode(sorted_params) signature = hmac.new(app_secret.encode('utf-8'), query_str.encode('utf-8'), hashlib.sha1).hexdigest().upper() return signature` -
上传图片获取imgid
调用
1688.upload.img接口上传图片,返回pic_url作为imgid:python`import requests def upload_img(app_key, app_secret, image_path): url = "https://api.1688.com/router/rest" params = { 'app_key': app_key, 'method': '1688.upload.img', 'format': 'json', 'v': '2.0', 'timestamp': int(time.time()), 'sign_method': 'md5' } files = {'file': open(image_path, 'rb')} params['sign'] = generate_sign(params, app_secret) response = requests.post(url, files=files, params=params) if response.status_code == 200: return response.json().get('pic_url') return None` -
调用图片搜索接口
使用
imgid调用item_search_img接口,支持分页、排序和类目筛选:python`def search_items(app_key, app_secret, imgid, cat=None, page=1): url = "https://api.1688.com/router/rest" params = { 'app_key': app_key, 'method': '1688.item_search_img', 'format': 'json', 'v': '2.0', 'timestamp': int(time.time()), 'sign_method': 'md5', 'imgid': imgid, 'cat': cat or '', 'page': page } params['sign'] = generate_sign(params, app_secret) response = requests.get(url, params=params) if response.status_code == 200: return response.json() return None`
四、返回数据解析
接口返回JSON数据,包含商品列表及分页信息。示例:
json
`{
"items": {
"item": [
{
"num_iid": "634209995336",
"title": "精英篮球袜子男短袜加厚无骨缝头毛巾底吸汗透气户外跑步毛巾运动",
"price": "3.00",
"sales": 1600,
"pic_url": "https://cbu01.alicdn.com/img/ibank/2020/490/610/23562016094_1701667707.jpg",
"detail_url": "https://detailp4p.1688.com/buyer/offerdetail/634209995336.html"
}
],
"total_results": 80
}
}`
五、注意事项
- 调用频率限制:企业认证用户支持每秒10+次调用,延迟≤30秒,避免高频调用被限流。
- 安全与合规:禁止存储用户隐私数据(如手机号、地址),需通过电商平台链接跳转展示价格。
- 错误处理:添加异常捕获(如网络超时、数据解析错误),使用沙箱环境测试稳定性。
- 性能优化:对频繁请求采用缓存机制,异步处理图片上传和搜索任务。
六、应用场景示例
- 电商比价:通过图片搜索竞品价格,辅助定价策略。
- 供应链管理:快速匹配供应商,优化采购流程。
- 侵权检测:识别相似商品,保护知识产权。
通过以上步骤,您可高效利用1688图片搜索API实现商品信息获取。如需进一步集成,可参考1688开放API文档提供的完整代码示例和调试技巧。