文档中心 > API类目 > 工具类API

alipay.system.oauth.token (换取授权访问令牌)

换取授权访问令牌

公共参数

请求地址:
环境 HTTPS请求地址
正式环境 https://openapi.alipay.com/gateway.do
公共请求参数:
参数 类型 是否必填 最大长度 描述 示例值
app_id String 32 支付宝分配给开发者的应用ID 2014072300007148
method String 128 接口名称 alipay.system.oauth.token
format String 40 仅支持JSON JSON
charset String 10 请求使用的编码格式,如utf-8,gbk,gb2312等 utf-8
sign_type String 10 商户生成签名字符串所使用的签名算法类型,目前支持RSA2和RSA,推荐使用RSA2 RSA2
sign String 256 商户请求参数的签名串,详见签名 详见示例
timestamp String 19 发送请求的时间,格式"yyyy-MM-dd HH:mm:ss" 2014-07-24 03:07:50
version String 3 调用的接口版本,固定为:1.0 1.0
app_auth_token String 40 详见应用授权概述

请求参数

参数 类型 是否必填 最大长度 描述 示例值
grant_type String 必须 20 值为authorization_code时,代表用code换取;值为refresh_token时,代表用refresh_token换取 authorization_code
code String 可选 40 授权码,用户对应用授权后得到。 4b203fe6c11548bcabd8da5bb087a83b
refresh_token String 可选 40 刷新令牌,上次换取访问令牌时得到。见出参的refresh_token字段 201208134b203fe6c11548bcabd8da5bb087a83b

公共响应参数

参数 类型 是否必填 最大长度 描述 示例值
code String - 网关返回码,详见文档 40004
msg String - 网关返回码描述,详见文档 Business Failed
sub_code String - 业务返回码,详见文档 ACQ.TRADE_HAS_SUCCESS
sub_msg String - 业务返回码描述,详见文档 交易已被支付
sign String - 签名,详见文档 DZXh8eeTuAHoYE3w1J+POiPhfDxOYBfUNn1lkeT/V7P4zJdyojWEa6IZs6Hz0yDW5Cp/viufUb5I0/V5WENS3OYR8zRedqo6D+fUTdLHdc+EFyCkiQhBxIzgngPdPdfp1PIS7BdhhzrsZHbRqb7o4k3Dxc+AAnFauu4V6Zdwczo=

响应参数

参数 类型 是否必填 最大长度 描述 示例值
user_id String 必填 16 支付宝用户的唯一userId 2088102150477652
access_token String 必填 40 访问令牌。通过该令牌调用需要授权类接口 20120823ac6ffaa4d2d84e7384bf983531473993
expires_in String 必填 16 访问令牌的有效时间,单位是秒。 3600
refresh_token String 必填 40 刷新令牌。通过该令牌可以刷新access_token 20120823ac6ffdsdf2d84e7384bf983531473993
re_expires_in String 必填 16 刷新令牌的有效时间,单位是秒。 3600

请求示例

  • JAVA
  • .NET
  • PHP
  • HTTP请求源码
AlipayClient alipayClient = new DefaultAlipayClient("https://openapi.alipay.com/gateway.do","app_id","your private_key","json","GBK","alipay_public_key","RSA2");
AlipaySystemOauthTokenRequest request = new AlipaySystemOauthTokenRequest();
request.setGrantType("authorization_code");
request.setCode("4b203fe6c11548bcabd8da5bb087a83b");
request.setRefreshToken("201208134b203fe6c11548bcabd8da5bb087a83b");
AlipaySystemOauthTokenResponse response = alipayClient.execute(request);
if(response.isSuccess()){
System.out.println("调用成功");
} else {
System.out.println("调用失败");
}

响应示例

  • JSON示例
{
	"alipay_system_oauth_token_response":{
		"access_token":"20120823ac6ffaa4d2d84e7384bf983531473993",
		"refresh_token":"20120823ac6ffdsdf2d84e7384bf983531473993",
		"user_id":"2088102150477652",
		"re_expires_in":"3600",
		"expires_in":"3600"
	}
}

异常示例

  • JSON示例
{
	"alipay_system_oauth_token_response":{
		"msg":"Service Currently Unavailable",
		"code":"20000",
		"sub_msg":"系统繁忙",
		"sub_code":"isp.unknow-error"
	},
	"sign":"ERITJKEIJKJHKKKKKKKHJEREEEEEEEEEEE"
}

业务错误码

错误码 错误描述 解决方案
isv.grant-type-invalid grant_type参数不正确 grant_type必须是authorization_code、refresh_token二者之一 若传入authorization_code为code换取令牌,若传入refresh_token为刷新令牌
isv.code-invalid 授权码(auth_code)
错误、状态不对或过期
使用有效的auth_code重新执行令牌换取,或引导用户重新授权
isv.refresh-token-invalid 刷新令牌(refresh_token)错误或状态不对 使用有效的refresh_token重新执行令牌刷新,或引导用户重新授权
isv.refresh-token-time-out 刷新令牌(refresh_token)过期 使用有效的refresh_token重新执行令牌刷新,或引导用户重新授权
isv.refreshed-token-invalid 刷新出来的令牌无效 使用返回的刷新令牌再次刷新
isv.invalid-app-id 调用接口的应用标识(app_id)与令牌授权的应用不相符 传入正确的app_id和令牌,若开发者支付宝账号名下有多个app_id,或者开发者管理多个归属于不同支付宝账号的app_id,请注意不要混用不同app_id的code
isp.unknow-error 未知错误 重试,或联系支付宝客服

公共错误码

返回
顶部