Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
取酒独倾
unidocs-zh
提交
965e2158
U
unidocs-zh
项目概览
取酒独倾
/
unidocs-zh
与 Fork 源项目一致
Fork自
DCloud / unidocs-zh
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
965e2158
编写于
9月 21, 2022
作者:
hbcui1984
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add 开放平台
上级
08d2ed76
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
370 addition
and
0 deletion
+370
-0
docs/plugin/open.md
docs/plugin/open.md
+370
-0
未找到文件。
docs/plugin/open.md
0 → 100644
浏览文件 @
965e2158
# DCloud开放平台DSP对接规范
名词解释:
-
DSP:developer service provider,为开发者提供服务的三方厂商
## 开发者服务商(DSP)入驻DCloud开放平台
-
DSP在DCloud开放平台
[
https://open.dcloud.net.cn/
](
https://open.dcloud.net.cn/
)
注册账号,需企业实名认证。
-
注册成功后,由DCloud分配账号级
`dspId`
,
`dspSecret`
。
## DSP配置开户所需信息
DSP入驻DCloud开放平台后,需配置希望获取开发者哪些信息,以及是否支持个人用户开户:
-
可选信息:
`email`
,
`phone`
,
`realname`
,
`nickname`
,
`identity`
(个人为身份证号、企业为营业执照),
`bankInfo`
(开户行,开户名称,银行账号)
-
是否支持个人用户
-
账号接口地址,用于接受DCloud开放平台同步过来的用户信息(邮箱、手机号、实名信息等);API接口定义见下文。
## DSP注册SDK
-
DSP按照uniapp插件规范开发相关插件,并发布到
[
插件市场
](
https://ext.dcloud.net.cn
)
;
-
注册SDK产品,补充完善以下信息:
-
SDK支持的平台,如app-android, app-ios, mp-weixin等;
-
各平台开通服务时,需要的应用信息字段(区分必填、选填;如应用名称、包名、证书摘要等);
-
插件市场的插件ID(必填);
-
是否支持测试包名、测试证书;
-
各平台的备注信息(在DCloud开放平台向用户展示,可以添加SDK文档链接等)
-
录入DSP API接口地址。API接口定义见下文。
-
创建应用、修改应用接口返回参数的字段名称、描述信息、在原生平台需要标识保存在
`AndroidManifest`
、
`plist`
的位置
```
json
{
"app-android"
:
{
//
平台
"appid"
:
{
//
该平台创建应用时,返回的字段名称
"title"
:
"appid"
,
//
字段在页面上的展示名称
"desc"
:
"应用标识"
,
//
字段描述
"androidManifest"
:
{
//
可选,如果需要在打包时将此字段配置到AndroidManifest,需要提供AndroidManifest中字段名称
"metaDataName"
:
"dcloud_appid"
}
},
"appKey"
:
{
"title"
:
""
,
"desc"
:
""
,
"androidManifest"
:
{
"metaDataName"
:
"dcloud_appkey"
}
},
"appSecret"
:
{
"title"
:
""
,
"desc"
:
""
}
},
"app-ios"
:
{
"appKey"
:
{
"title"
:
""
,
"desc"
:
""
,
"plist"
:
{
//
可选,如果需要在打包时将此字段配置到plist,需要提供plist的参数配置路径
"keyPath"
:
"sms:config:appKey"
}
},
},
"server"
:
{
"masterSecret"
:
{
"title"
:
""
,
"desc"
:
""
,
"uniConfigCenter"
:
{
//
可选。此字段需要配置到uni-config-center
"pluginId"
:
""
,
//
此字段是uni-config-center的pluginId。不是插件市场的插件ID。
"keyPath"
:
"sms:config:masterSecret"
//
参数配置路径
}
}
}
}
```
## 开发者向DSP一键开户
开发者可在DCloud系统中,向DSP平台发起账号注册、修改、注销等流程。
具体流程为:
1.
开发者登录DCloud系统
2.
选择需要开户的DSP平台
3.
开发者授权可向DSP同步的个人信息(手机号、邮箱、实名信息等)
4.
DCloud系统通过接口方式请求DSP平台,将用户信息发送过去
5.
DSP平台返回操作结果(如:注册成功、失败以及失败原因等)
### 注册
-
接口示例
/auth/register
-
请求参数
```
json
{
"dcloudOpenUid"
:
""
,
//
DCloud开放平台用户标识
"email"
:
"mail@dcloud.io"
,
//
账号绑定的邮箱
"phone"
:
"13012345678"
,
//
账号绑定的手机号
"userType"
:
1
,
//
用户类型:
1
为个人,
2
为企业
"name"
:
"张三"
,
//
用户名称。个人用户为姓名。企业用户为企业名称
"identity"
:
"110110199001011234"
,
//
个人用户为身份证号,企业用户为营业执照
"bankInfo"
:
{
"bank"
:
"招商银行北京支行"
,
//
开户银行
"name"
:
"张三"
,
//
开户名
"account"
:
"12345678"
//
银行账号
}
"timestamp"
:
1633665031
,
}
```
-
返回参数
```
json
{
"errCode"
:
0
,
"errMsg"
:
"success"
}
```
### 同步用户信息
接口同注册接口。
### 注销账号
开发者通过一键登录,在DSP平台中注销。
## 开发者一键登录DSP平台
开发者登录DCloud系统后,可一键登录DSP平台,避免二次登录,优化体验。
一键登录分为两个步骤:
1.
DCloud平台通过接口请求DSP平台,获取authToken
2.
DCloud平台通过authToken,跳转DSP平台系统
### 获取authToken
-
接口示例
/auth/token
-
请求参数
```
json
{
"dcloudOpenUid"
:
""
,
"timestamp"
:
1633665031
,
}
```
-
返回参数
```
json
{
"errCode"
:
0
,
"errMsg"
:
"success"
,
"data"
:
{
"authToken"
:
""
,
//
登录凭证,应用相关接口都通过authToken鉴权
"expire"
:
3600
//
authToken过期时间,单位为秒
}
}
```
### 一键登录
-
说明:通过authToken可免登录打开DSP平台。DSP解析dspId,authToken,实现DSP平台自登录。
-
跳转DSP平台地址示例,如:
`https://dspdomain.com?dspId=xxx&authToken=xxx`
## 开发者向DSP注册应用
开发者可在DCloud系统中,向DSP平台发起应用注册、修改、删除流程。
### 创建应用
-
接口示例
/app/create
-
请求参数
```
json
{
"pluginId"
:
""
,
"authToken"
:
""
,
"appName"
:
""
,
"appDesc"
:
""
,
"platforms"
:
{
//
此字段对应SDK注册时,DSP选择的平台。同时开发者在开通时可选择开通一个或多个平台
"app-android"
:
{
"releasePackageName"
:
""
,
"debugPackageName"
:
""
,
"releaseCertSha1"
:
""
,
"debugCertSha1"
:
""
,
},
"app-ios"
:
{
"releaseBundleId"
:
""
,
"debugBundleId"
:
""
,
},
"mp-wexin"
:
{
"wxAppid"
:
""
,
},
"web"
:
{
"domains"
:
[
"dcloud.io"
,
"dcloud.net.cn"
]
},
"webService"
:
{
"ips"
:
[
"1.2.3.4"
,
"1.2.3.*"
],
"domains"
:
[
"dcloud.io"
,
"dcloud.net.cn"
]
}
},
"timestamp"
:
1633665031
,
}
```
-
返回参数
```
json
{
"errCode"
:
0
,
"errMsg"
:
"success"
,
"data"
:
{
"dspAppid"
:
""
,
"platforms"
:
{
//
此处返回的字段与SDK注册时配置的字段一致
"server"
:
{
//
客户端配套的server配置
"secret"
:
""
,
},
"app-android"
:
{
"appid"
:
""
,
"appKey"
:
""
,
"appSecret"
:
""
,
},
"app-ios"
:
{
"appid"
:
""
,
"appKey"
:
""
,
"appSecret"
:
""
,
},
"mp-weixin"
:
{
},
"web"
:
{
"appKey"
:
""
,
"jscode"
:
""
},
"webService"
:
{
}
}
}
}
```
### 修改应用信息
**注意:**
修改应用信息时,传递的是全量数据。如果某个平台以前开通过,在修改时没有传递,表明开发者需要删除该平台的配置。
-
接口示例
/app/modify
-
请求参数
```
json
{
"pluginId"
:
""
,
"authToken"
:
""
,
"dspAppid"
:
""
,
"appName"
:
""
,
"appDesc"
:
""
,
"platforms"
:
{
//
如果没有某个平台的参数,表示删除该平台配置
"app-android"
:
{
"releasePackageName"
:
""
,
"debugPackageName"
:
""
,
"releaseCertSha1"
:
""
,
"debugCertSha1"
:
""
,
}
},
"timestamp"
:
1633665031
,
}
```
-
返回参数
```
json
{
"errCode"
:
0
,
"errMsg"
:
"success"
,
"data"
:
{
"dspAppid"
:
""
,
"platforms"
:
{
//
此处返回的字段与SDK注册时配置的字段一致
"server"
:
{
//
客户端配套的server配置
"secret"
:
""
,
},
"app-android"
:
{
"appid"
:
""
,
"appKey"
:
""
,
"appSecret"
:
""
,
}
}
}
}
```
### 删除应用
-
接口示例
/app/delete
-
请求参数
```
json
{
"pluginId"
:
""
,
"authToken"
:
""
,
"dspAppid"
:
""
,
"timestamp"
:
1633665031
,
}
```
-
返回参数
```
json
{
"errCode"
:
0
,
"errMsg"
:
"success"
,
}
```
## DSP使用DCloud账号登录(OAuth协议)
完整文档参考:
[
https://ask.dcloud.net.cn/article/38005
](
https://ask.dcloud.net.cn/article/38005
)
### HBuilderX插件
![](
https://img-cdn-tc.dcloud.net.cn/uploads/article/20201110/2514e1ec371bdebbb9a4111052939720.png
)
### Web平台
![](
https://img-cdn-tc.dcloud.net.cn/uploads/article/20220914/3bc9cb477832756cc727f3c550b4fcd0.jpg
)
## 附录
### 接口数据传输规范
#### 编码方式
-
本API文档所涉及接口均遵循HTTP协议;
-
所有请求的ContentType在不明确指定的情况下均为application/x-www-form-urlencoded;
-
所有返回的ContentType在不明确指定的情况下均为application/json;
-
若无特殊说明或响应头中的Content-Type未指定编码,请求和响应中的字符编码均使用 UTF-8(无 BOM 头)。
#### HTTP请求方式
如无特殊说明,API请求的HTTP Method均为POST
#### URL定义
URL请求域名由DSP提供,协议:必须使用HTTPS。本文接口详述中使用的请求URL均为示例,实际上线时的URL以DSP提供的为准。
#### 请求参数
接口中描述的请求参数全部加密传输。请求参数只包含以下字段:
|名称 |类型 |必填 |描述 |
|-- |-- |-- |-- |
|dspId |int |是 |DSP在DCloud开放平台注册账号后,DCloud返回的dspId |
|data |string |是 |各接口中定义的json string加密后的数据,加密数据见下文描述 |
#### 接口响应
-
HTTP状态码
支持HTTP标准状态码,具体如下:
|状态码 |名称 |描述 |
|-- |-- |-- |
|200 |成功 |当 API 请求被正确处理,且能按设计获取结果时,返回该状态码;|
|4xx |接口调用方端错误 |由接口调用方端原因造成的错误 |
|5xx |DSP服务器端错误 |DSP API或其下层服务发生内部错误 |
-
HTTP Header
接口DSP API响应的Content-Type应为application/json。
-
HTTP Body
响应的JSON数据中包含三部分内容,分别为状态码、返回信息和数据,如下表所示:
|名称 |类型 |必填 |描述 |
|-- |-- |-- |-- |
|errCode|int |是 |状态码: 0表示成功;其它表示错误 |
|errMsg |string |是 |返回信息:若有错误,此字段为详细的错误信息 |
|data |json object|否 |响应数据。此字段加密传输,加密前为json string。接口无需返回数据时,此字段为空。 |
#### 数据加密算法
所有要求加密的字段均采用AES256加密算法进行加密。在DSP注册账号后,由DCloud开放平台提供加密的密钥
`dspSecret`
。
加密算法:AES256
加密模式:CBC
填充方式:Pkcs7 | Pkcs5
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录