news 2026/2/24 22:47:56

接入MIC(中国制造)接口的帮助

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
接入MIC(中国制造)接口的帮助

一、接入前准备(必须完成)

1. 注册与认证(账号与资质)

  1. 访问MIC 开放平台:https://open.made-in-china.com/
  2. 用企业账号注册 / 登录(个人账号权限受限,跨境 / 商品类接口多为企业专属)
  3. 完成企业实名认证:营业执照、法人信息、对公账户核验(1–3 个工作日)
  4. 开通API 服务权限:在控制台「API 服务」→「申请开通」,选择你需要的能力包(商品搜索、商品详情、类目、榜单等)

2. 创建应用,获取核心凭证

  1. 进入「应用管理」→「创建应用」
    • 应用名称:自定义(如 “MIC 商品数据工具”)
    • 应用类型:自用型 / 第三方应用(自用即可)
    • 回调 URL:OAuth 授权用,本地调试可填http://localhost
  2. 审核通过后,在应用详情页获取三大核心凭证(务必妥善保管,严禁泄露)
    • app_key/client_id:应用唯一标识
    • app_secret/client_secret:签名密钥
    • access_token:接口调用令牌(通过 OAuth 获取,有效期通常 24 小时)

3. 申请接口权限

  1. 进入「权限管理」→「申请 API 权限」
  2. 搜索并勾选你需要的接口(以商品 / 类目 / 榜单为例):
    • 商品类目:category.get(获取类目树)
    • 商品搜索 / 榜单:product.searchproduct.topList
    • 商品详情:product.get
  3. 提交审核,公开权限一般即时通过,高阶权限可能 1–2 个工作日。

二、核心技术流程:鉴权与签名(MIC 通用规则)

MIC 接口采用OAuth2.0 + MD5 签名双重校验,所有请求必须带合法签名与令牌。

1. 获取 access_token(授权流程)

(1)获取授权码 code

plaintext

GET https://open.made-in-china.com/oauth/authorize ?client_id=你的app_key &redirect_uri=你的回调URL &response_type=code &state=随机字符串(防CSRF)

用户授权后,平台会重定向到你的redirect_uri并带回code

(2)用 code 换取 access_token

plaintext

POST https://open.made-in-china.com/oauth/token Content-Type: application/x-www-form-urlencoded grant_type=authorization_code &client_id=你的app_key &client_secret=你的app_secret &code=上一步获取的code &redirect_uri=你的回调URL

返回示例(JSON):

json

{ "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...", "expires_in": 86400, "refresh_token": "xxx...", "token_type": "bearer" }

2. 生成签名(MD5,必对)

签名规则(与 1688 类似,但参数拼接略有差异):

  1. 把所有非空请求参数(不含sign、不含文件)按参数名 ASCII 升序排列
  2. key1=value1&key2=value2&...拼接成字符串
  3. 首尾拼接app_secretapp_secret + 参数字符串 + app_secret
  4. MD5 加密,转大写,得到sign

示例(Python):

python

运行

import hashlib def generate_mic_sign(params, app_secret): # 1. 按key升序排序 sorted_items = sorted(params.items(), key=lambda x: x[0]) # 2. 拼接 key=value&key=value... param_str = "&".join([f"{k}={v}" for k, v in sorted_items if v is not None]) # 3. 首尾加secret sign_raw = app_secret + param_str + app_secret # 4. MD5大写 sign = hashlib.md5(sign_raw.encode("utf-8")).hexdigest().upper() return sign

三、接口调用实战(以 “获取商品类目 + 类目榜单” 为例)

1. 通用请求规范

  • 请求地址:https://api.made-in-china.com/rest/{version}/{interface}
  • 版本:v1v2(以文档为准,目前主流v2
  • 请求方式:GET(查询类)/POST(提交类)
  • 必传公共参数(所有接口都要):
参数名类型必填说明
app_keystring应用 ID
timestamplong13 位毫秒时间戳
noncestring随机字符串(防重放,如 UUID)
signstringMD5 签名(大写)
access_tokenstring授权令牌
formatstring默认 json

2. 接口 1:获取商品类目树(category.get)

请求示例(Python)

python

运行

import requests import time import uuid # 配置 APP_KEY = "你的app_key" APP_SECRET = "你的app_secret" ACCESS_TOKEN = "你的access_token" API_URL = "https://api.made-in-china.com/rest/v2/category.get" def get_mic_category_tree(parent_id=0): # 业务参数 params = { "app_key": APP_KEY, "timestamp": int(time.time() * 1000), "nonce": str(uuid.uuid4()), "access_token": ACCESS_TOKEN, "parent_id": parent_id, # 0=顶级类目 "format": "json" } # 生成签名 params["sign"] = generate_mic_sign(params, APP_SECRET) # 发送请求 resp = requests.get(API_URL, params=params, timeout=10) return resp.json() # 调用:获取顶级类目 if __name__ == "__main__": result = get_mic_category_tree(parent_id=0) print(result)
响应结构(关键字段)

json

{ "code": 200, "message": "success", "data": { "categories": [ { "category_id": "1001", "name": "Apparel", "level": 1, "is_leaf": false, "children": [...] } ] } }

3. 接口 2:按类目获取商品榜单(product.topList)

业务参数(核心)
  • category_id:类目 ID(从上一步获取)
  • sort_type:排序类型(sales = 销量,price = 价格,newest = 新品)
  • page_no/page_size:分页
  • country:目标市场(可选,如 US、DE)
调用示例(关键代码)

python

运行

API_TOP_URL = "https://api.made-in-china.com/rest/v2/product.topList" def get_category_top_products(category_id, sort_type="sales", page_no=1, page_size=20): params = { "app_key": APP_KEY, "timestamp": int(time.time() * 1000), "nonce": str(uuid.uuid4()), "access_token": ACCESS_TOKEN, "category_id": category_id, "sort_type": sort_type, "page_no": page_no, "page_size": page_size, "format": "json" } params["sign"] = generate_mic_sign(params, APP_SECRET) resp = requests.get(API_TOP_URL, params=params, timeout=10) return resp.json()

四、限流、异常与最佳实践

1. 限流规则(必须遵守)

  • 国内 IP:QPS ≤ 10
  • 海外 IP:QPS ≤ 5
  • 单日调用限额:基础权限一般 5000–10000 次,企业版可提升
  • 触发限流返回429 Too Many Requests,需做退避重试(1s→3s→5s,最多 3 次)

2. 常见错误码与处理

错误码含义处理方案
400参数错误 / 签名错误核对参数顺序、签名逻辑、时间戳
401token 过期 / 无效刷新 access_token 或重新授权
403权限不足检查接口权限是否开通
404类目 / 商品不存在核对 ID 有效性
429限流本地限流 + 退避重试
500服务异常缓存兜底,重试 1 次,失败告警

3. 生产优化建议

  1. 缓存类目数据:类目更新慢,本地缓存 24 小时,减少调用
  2. 令牌池 / 自动刷新:提前刷新access_token,避免过期中断
  3. 字段过滤:用fields参数只返回需要的字段,提升性能
  4. 日志与监控:记录请求耗时、成功率、错误码,便于排查

五、与 1688 接口的关键差异(避坑)

  1. 授权体系:MIC 强依赖access_token,1688 部分公开接口可仅用签名
  2. 参数拼接:MIC 用key=value&分隔,1688 是直接keyvalue无分隔符
  3. 限流粒度:MIC 按 IP 地域区分 QPS,1688 按应用维度
  4. 类目结构:MIC 类目 ID 为字符串,层级用level显式标注,更适合跨境场景

六、下一步行动

  1. 先在 MIC 开放平台完成企业认证 + 应用创建 + 权限申请
  2. 用 Postman 先调试category.get,拿到类目 ID
  3. 再调用product.topList,验证类目榜单数据
  4. 最后集成到你的系统,加上缓存、限流、异常兜底
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/23 14:42:37

基于STM32H750的LCR测量仪设计

基于STM32H750的LCR测量仪设计 第一章 绪论 LCR测量仪是电子检测领域的核心仪器,用于精准测量电感(L)、电容(C)、电阻(R)等无源元件参数,广泛应用于电子研发、生产质检、设备维修等场…

作者头像 李华
网站建设 2026/2/24 21:25:58

食品包装机械远程运维管理系统方案

在食品安全日益受到重视的今天,食品包装机械作为保障食品品质和安全的重要环节,其稳定性和可靠性至关重要。然而,食品包装机械种类繁多,分布广泛,给设备制造商的售后运维工作带来了巨大挑战。该平台通过集成PLC数据采集…

作者头像 李华
网站建设 2026/2/23 14:42:36

必须了解的2026年二维码链接到视频推荐榜单

随着2026年的到来,二维码链接到视频的使用场景越来越丰富,成为信息传播的重要工具。借助二维码,用户可以轻松获取所需视频内容,不论是在产品推广、健康教育还是课堂学习中,二维码都能发挥关键作用。它不仅提升了互动体…

作者头像 李华
网站建设 2026/2/23 19:32:20

小米王扉:光谷有很好AI产业基础,我们会扎根武汉,推进技术研发

雷递网 乐天 1月31日小米集团技术委员会副主席、武汉总部总经理王扉日前在2026光谷AI产业发展峰会上表示,小米在AI方面、特别是辅助驾驶方面的投入,已经超过1800人、其中博士生超过100人,北京上海武汉三地研发。小米武汉是2017年正式成立&…

作者头像 李华
网站建设 2026/2/23 7:00:48

基于python的奖学金评定评优系统-pycharm DJANGO FLASK

文章目录 基于Python的奖学金评定系统技术选型核心功能模块设计技术实现要点系统架构建议部署与扩展方案 大数据系统开发流程主要运用技术介绍源码文档获取定制开发/同行可拿货,招校园代理 :文章底部获取博主联系方式! 基于Python的奖学金评定系统技术选…

作者头像 李华