Research
Security News
Malicious PyPI Package ‘pycord-self’ Targets Discord Developers with Token Theft and Backdoor Exploit
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
alipay-serverless-sdk
Advanced tools
支付宝小程序端Serverless配套SDK,让您享受极简编程体验的同时,快速集成支付宝、阿里云等阿里经济体开放的各项核心能力。
npm install alipay-serverless-sdk --save
npm install @alicloud/mpserverless-sdk --save
alipay-serverless-sdk
依赖@alicloud/mpserverless-sdk
,使用时需要传入 mpserverless-sdk 实例进行初始化
// 1. 引入必要的 sdk
import MPServerless from '@alicloud/mpserverless-sdk';
import cloud from 'alipay-serverless-sdk';
// 2. 在 app.js 中对 sdk 进行初始化
// 2.1 初始化 MPServerless
my.serverless = my.serverless || new MPServerless({
uploadFile: my.uploadFile,
request: my.request,
getAuthCode: my.getAuthCode,
}, {
// 2.2 参数能在小程序云服务空间详情中获取
appId: '',
spaceId: '',
clientSecret: '',
endpoint: ''
});
// 2.3 初始化 alipay-serverless-sdk
cloud.init(my.serverless);
// 3. 在想要使用的页面导入 alipay-serverless-sdk 即可使用
// 比如在 page.js
import cloud from 'alipay-serverless-sdk';
cloud.base.qrcode.create(urlParam, queryParam, describe);
将API Doc中API的上两级标题中的英文(转首字符小写驼峰格式),用点号拼接在一起作为前缀,就是这个API的完整引用路径。Alipay Serverless SDK致力于保持良好的API命名,以符合开发者的编程直觉。
下面是几个典型的例子。
import cloud from 'alipay-serverless-sdk';
//调用基础能力-用户授权-获取授权访问令牌API
cloud.base.oauth.getToken
//调用营销能力-小程序模板消息-发送模板消息API
cloud.marketing.templateMessage.send
//调用会员能力-支付宝身份认证-生成认证链接API
cloud.member.identification.certify
//调用支付能力-花呗分期-创建花呗分期交易API
cloud.payment.huabei.create
// 调用资金能力-无密转账到支付宝账户-单笔转账API
cloud.fund.transferAccount.transfer
// 调用资金能力-B2C现金红包-发放现金红包
cloud.fund.b2cRedPacket.send
//调用安全能力-文本风险识别-检测内容风险API
cloud.security.textRisk.detect
//调用阿里云能力-短信-发送API
cloud.aliyun.shortMessage.send
getToken(code: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
code | string | 是 | 授权码,用户对应用授权后得到 |
可前往alipay.system.oauth.token查看更加详细的参数说明。
refreshToken(refreshToken: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
refreshToken | string | 是 | 刷新令牌,上次换取访问令牌时得到,见出参的refresh_token字段 |
可前往alipay.system.oauth.token查看更加详细的参数说明。
create(urlParam: string, queryParam: string, describe: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
urlParam | string | 是 | 小程序中能访问到的页面路径,例如:page/component/component-pages/view/view |
queryParam | string | 是 | 小程序的启动参数,打开小程序的query ,在小程序 onLaunch的方法中获取 |
describe | string | 是 | 二维码描述 |
可前往alipay.open.app.qrcode.create查看更加详细的参数说明。
send(toUserId: string, formId: string, userTemplateId: string, page: string, data: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
toUserId | string | 是 | 发送消息的支付宝账号 |
formId | string | 是 | 用户发生的交易行为的交易号,或者用户在小程序产生表单提交的表单号,用于信息发送的校验 |
userTemplateId | string | 是 | 用户申请的模板id号,固定的模板id会发送固定的消息 |
page | string | 是 | 小程序的跳转页面,用于消息中心用户点击之后详细跳转的小程序页面,例如:page/component/index |
data | string | 是 | 开发者需要发送模板消息中的自定义部分来替换模板的占位符,例如:{"keyword1": {"value" : "12:00"},"keyword2": {"value" : "20180808"},"keyword3": {"value" : "支付宝"}} |
可前往alipay.open.app.mini.templatemessage.send查看更加详细的参数说明。
create(outBizNo: string, brandName: string, voucherName: string, quantity: number, publishStartTime: string, publishEndTime: string, validPeriod: string, availableTime: string, description: string, extensionInfo: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outBizNo | string | 是 | 外部业务单号。用作幂等控制。同一个pid下相同的外部业务单号作唯一键。 |
brandName | string | 是 | 品牌名。用于在卡包中展示,长度不能超过12个字符。 |
voucherName | string | 是 | 券名称。用于在卡包中展示,长度不能超过20个字符。展示的实际名称为:券名称+兑换券。如,voucher_name为咖啡。则,卡包展示名称为:咖啡兑换券。 |
quantity | number | 是 | 拟发行券的数量。单位为张。该数值必须是大于0的整数。 |
publishStartTime | string | 是 | 发放开始时间,早于该时间不能发券。发放开始时间不能大于当前时间15天。格式为:yyyy-MM-dd HH:mm:ss |
publishEndTime | string | 是 | 发放结束时间,晚于该时间不能发券。券的发放结束时间和发放开始时间跨度不能大于90天。发放结束时间必须晚于发放开始时间。格式为:yyyy-MM-dd HH:mm:ss |
validPeriod | string | 是 | 券有效期。具体取值规则可前往alipay.marketing.exchangevoucher.template.create查看更加详细的参数说明。 |
availableTime | string | 是 | 券可用时段。具体取值规则可前往alipay.marketing.exchangevoucher.template.create查看更加详细的参数说明。 |
description | string | 是 | 券使用说明。JSON数组字符串,最多可以有10条,每条最多50字。不采用时输入"[]" |
extensionInfo | string | 是 | 扩展字段,JSON字符串。具体取值规则可前往alipay.marketing.exchangevoucher.template.create查看更加详细的参数说明。 |
可前往alipay.marketing.exchangevoucher.template.create查看更加详细的参数说明。
send(templateId: string, userId: string, outBizNo: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
templateId | string | 是 | 券模板ID。 |
userId | string | 是 | 支付宝用户ID 。 |
outBizNo | string | 是 | 外部业务订单号,用于幂等控制,相同template_id和out_biz_no认为是同一次业务。 |
可前往alipay.marketing.voucher.send查看更加详细的参数说明。
use(voucherId: string, userId: string, outBizNo: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
voucherId | string | 是 | 待使用的券id ,来自发券接口alipay.marketing.voucher.send |
userId | string | 是 | 支付宝用户ID ,必须保证待使用的券ID归属于该支付宝用户ID。 |
outBizNo | string | 是 | 外部业务号,用户幂等控制。相同voucher_id和out_biz_no被认为是同一次核销。 |
可前往alipay.marketing.exchangevoucher.use查看更加详细的参数说明。
query(voucherId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
voucherId | string | 是 | 券ID(券唯一标识, 发券接口返回参数) 。 |
可前往alipay.marketing.voucher.query查看更加详细的参数说明。
init(outerOrderNo: string, bizCode: string, identityParam: IdentityParam, merchantConfig: MerchantConfig)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outerOrderNo | string | 是 | 商户请求的唯一标识,商户要保证其唯一性,值为32位长度的字母数字组合,建议前面几位字符是商户自定义的简称,中间可以使用一段时间,后段可以使用一个随机或递增序列 |
bizCode | string | 是 | 认证场景码,入参支持的认证场景码和商户签约的认证场景相关,可选值有如下,FACE:多因子人脸认证;CERT_PHOTO:多因子证照认证;CERT_PHOTO_FACE:多因子证照和人脸认证;SMART_FACE:多因子快捷认证 |
identityParam | IdentityParam | 是 | 需要验证的身份信息参数 |
merchantConfig | MerchantConfig | 是 | 商户个性化配置 |
IdentityParam对象说明
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
identityType | string | 是 | 身份信息参数类型,必须传入CERT_INFO |
certType | string | 是 | 证件类型,当前支持身份证,必须传入IDENTITY_CARD |
certName | string | 是 | 真实姓名 |
certNo | string | 是 | 证件号码 |
MerchantConfig对象说明
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
returnUrl | string | 是 | 需要回跳的目标URL地址,一般指定为商户业务页面 |
可前往alipay.user.certify.open.initialize查看更加详细的参数说明。
certify(certifyId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
certifyId | string | 是 | 本次申请操作的唯一标识,由身份认证初始化接口调用后生成,后续的操作都需要用到 |
可前往alipay.user.certify.open.certify查看更加详细的参数说明。
query(certifyId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
certifyId | string | 是 | 身份认证操作的唯一标识,由身份认证初始化接口调用后生成 |
可前往alipay.user.certify.open.query查看更加详细的参数说明。
create(subject: string, outTradeNo: string, totalAmount: string, buyerId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
subject | string | 是 | 订单标题 |
outTradeNo | string | 是 | 商户订单号,64个字符以内,可包含字母、数字、下划线,需保证在商户端不重复 |
totalAmount | string | 是 | 订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000] |
buyerId | string | 是 | 买家的支付宝用户ID,如果为空,会从传入的码值信息中获取买家ID |
可前往alipay.trade.create查看更加详细的参数说明。
query(outTradeNo: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outTradeNo | string | 是 | 交易创建时传入的商户订单号 |
可前往alipay.trade.query查看更加详细的参数说明。
refund(outTradeNo: string, refundAmount: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outTradeNo | string | 是 | 交易创建时传入的商户订单号 |
refundAmount | string | 是 | 需要退款的金额,该金额不能大于订单金额,单位为元,支持两位小数 |
可前往alipay.trade.refund查看更加详细的参数说明。
close(outTradeNo: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outTradeNo | string | 是 | 交易创建时传入的商户订单号 |
可前往alipay.trade.close查看更加详细的参数说明。
cancel(outTradeNo: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outTradeNo | string | 是 | 交易创建时传入的商户订单号 |
可前往alipay.trade.cancel查看更加详细的参数说明。
create(subject: string, outTradeNo: string, totalAmount: string, buyerId: string, extendParams: HuabeiConfig)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
subject | string | 是 | 订单标题 |
outTradeNo | string | 是 | 商户订单号,64个字符以内,可包含字母、数字、下划线,需保证在商户端不重复 |
totalAmount | string | 是 | 订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000] |
buyerId | string | 是 | 买家的支付宝用户ID,如果为空,会从传入的码值信息中获取买家ID |
extendParams | HuabeiConfig | 是 | 花呗交易扩展参数 |
HuabeiConfig对象说明
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
hbFqNum | string | 是 | 花呗分期数,仅支持传入3、6、12 |
hbFqSellerPercent | string | 是 | 代表卖家承担收费比例,商家承担手续费传入100,用户承担手续费传入0,仅支持传入100、0两种 |
可前往alipay.trade.create查看更加详细的参数说明。
pay(subject: string, outTradeNo: string, totalAmount: string, authCode: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
subject | string | 是 | 订单标题 |
outTradeNo | string | 是 | 交易创建时传入的商户订单号 |
totalAmount | string | 是 | 订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000] |
authCode | string | 是 | 支付授权码,25 |
可前往alipay.trade.pay查看更加详细的参数说明。
transfer(outBizNo: string, transAmount: string, payee: object, orderTitle: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outBizNo | string | 是 | 商户端的唯一订单号,对于同一笔转账请求,商户需保证该订单号唯一。 |
transAmount | string | 是 | 订单总金额,单位为元,精确到小数点后两位,取值范围[0.1,100000000]。 |
+ payee | object | 是 | 收款方信息。 |
└ identity | string | 是 | 参与方的唯一标识。 |
└ identity_type | string | 是 | 参与方的标识类型,目前支持如下类型:1、ALIPAY_USER_ID 支付宝的会员ID 2、ALIPAY_LOGON_ID:支付宝登录号,支持邮箱和手机号格式。 |
└ name | string | 否 | 参与方真实姓名,如果非空,将校验收款支付宝账号姓名一致性。当identity_type=ALIPAY_LOGON_ID时,本字段必填。 |
orderTitle | string | 是 | 转账业务的标题,用于在支付宝用户的账单里显示。 |
可前往alipay.fund.trans.uni.transfer查看更加详细的参数说明。
query(payFundOrderId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
payFundOrderId | string | 是 | 支付宝支付资金流水号。 |
可前往alipay.fund.trans.common.query查看更加详细的参数说明。
transfer(outBizNo: string, transAmount: string, payee: object, orderTitle: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outBizNo | string | 是 | 商户端的唯一订单号,对于同一笔转账请求,商户需保证该订单号唯一。 |
transAmount | string | 是 | 订单总金额,单位为元,精确到小数点后两位,取值范围[0.1,100000000]。 |
+ payee | object | 是 | 收款方信息。 |
└ identity | string | 是 | 参与方的唯一标识。 |
└ identity_type | string | 是 | 参与方的标识类型,目前支持如下类型:1、ALIPAY_USER_ID 支付宝的会员ID 2、ALIPAY_LOGON_ID:支付宝登录号,支持邮箱和手机号格式。 |
└ name | string | 否 | 参与方真实姓名,如果非空,将校验收款支付宝账号姓名一致性。当identity_type=ALIPAY_LOGON_ID时,本字段必填。 |
orderTitle | string | 是 | 转账业务的标题,用于在支付宝用户的账单里显示。 |
可前往alipay.fund.trans.uni.transfer查看更加详细的参数说明。
query(payFundOrderId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
payFundOrderId | string | 是 | 支付宝支付资金流水号。 |
可前往alipay.fund.trans.common.query查看更加详细的参数说明。
send(outBizNo: string, transAmount: string, payee: object, orderTitle: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
outBizNo | string | 是 | 商户端的唯一订单号,对于同一笔转账请求,商户需保证该订单号唯一。 |
transAmount | string | 是 | 订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000]。 |
+ payee | object | 是 | 收款方信息。 |
└ identity | string | 是 | 参与方的唯一标识。 |
└ identity_type | string | 是 | 参与方的标识类型,目前支持如下类型:1、ALIPAY_USER_ID 支付宝的会员ID 2、ALIPAY_LOGON_ID:支付宝登录号,支持邮箱和手机号格式。 |
└ name | string | 否 | 参与方真实姓名,如果非空,将校验收款支付宝账号姓名一致性。当identity_type=ALIPAY_LOGON_ID时,本字段必填。 |
orderTitle | string | 是 | 转账业务的标题,用于在支付宝用户的账单里显示。 |
可前往alipay.fund.trans.uni.transfer查看更加详细的参数说明。
query(payFundOrderId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
payFundOrderId | string | 是 | 支付宝支付资金流水号。 |
可前往alipay.fund.trans.common.query查看更加详细的参数说明。
detect(content: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
content | string | 是 | 待检测的文本内容 |
可前往alipay.security.risk.content.detect查看更加详细的参数说明。
send(phoneNumbers: string, signName: string, templateCode: string, templateParam: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
phoneNumbers | string | 是 | 短信接收号码,支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式;发送国际/港澳台消息时,接收号码格式为:国际区号+号码,如“85200000000” |
signName | string | 是 | 短信签名 |
templateCode | string | 是 | 短信模板ID,发送国际/港澳台消息时,请使用国际/港澳台短信模版 |
templateParam | string | 否 | 短信模板变量替换JSON串,例如:{"code":"1234","product":"ytx"} |
可前往SendSms查看更加详细的参数说明。
batchSend(phoneNumberJson: object, signNameJson: object, templateCode: string, templateParamJson: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
phoneNumberJson | string | 是 | 短信接收号码,JSON格式,批量上限为100个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式 |
signNameJson | string | 是 | JOSN格式短信签名,例如:[“云通信”,”云通信”] |
templateCode | string | 是 | 短信模板ID,发送国际/港澳台消息时,请使用国际/港澳台短信模版 |
templateParamJson | string | 是 | 短信模板变量替换JSON串,例如:[{"code":"1234","product":"ytx1"},{"code":"5678","product":"ytx2"}] |
可前往SendBatchSms查看更加详细的参数说明。
query(phoneNumber: string, sendDate: string, pageSize: number, currentPage: number)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
phoneNumber | string | 是 | 短信接收号码,如果需要查询国际短信,号码前需要带上对应国家的区号,区号的获取详见国际短信支持国家信息查询API接口 |
sendDate | string | 是 | 短信发送日期格式yyyyMMdd,支持最近30天记录查询,例如:20170525 |
pageSize | number | 是 | 页大小,最大不超过50 |
currentPage | number | 是 | 当前页码 |
可前往QuerySendDetails查看更加详细的参数说明。
preciseQuery(phoneNumber: string, sendDate: string, pageSize: number, currentPage: number, bizId: string)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
phoneNumber | string | 是 | 短信接收号码,如果需要查询国际短信,号码前需要带上对应国家的区号,区号的获取详见国际短信支持国家信息查询API接口 |
sendDate | string | 是 | 短信发送日期格式yyyyMMdd,支持最近30天记录查询,例如:20170525 |
pageSize | number | 是 | 页大小,最大不超过50 |
currentPage | number | 是 | 当前页码 |
bizId | string | 是 | 发送流水号,从调用发送接口返回值中获取 |
可前往QuerySendDetails查看更加详细的参数说明。
execute(method: string, params: object)
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
method | string | 是 | API接口名称,例如:alipay.trade.create |
params | object | 是 | 被包装在biz_content下的请求参数集合,例如:{ url_param: 'pages/cloud/cloud', query_param: 'key=value', describe: '我是二维码描述'} |
字段名 | 类型 | 必填 | 说明 |
---|---|---|---|
code | string | 是 | 网关返回码 |
msg | string | 是 | 网关返回码描述 |
subCode | string | 否 | 业务返回码,参见具体的API接口文档 |
subMsg | string | 否 | 业务返回码描述,参见具体的API接口文档 |
FAQs
Alipay Serverless SDK for mini-program development.
The npm package alipay-serverless-sdk receives a total of 3 weekly downloads. As such, alipay-serverless-sdk popularity was classified as not popular.
We found that alipay-serverless-sdk demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.