# 逸兔进件回调 接入综述
## **1 域名**
* 测试环境:[http://api-dev-rx.pjpfljcw.com/](http://api-dev-rx.pjpfljcw.com/)
* 生产环境:指定获取
## **2 接入条件**
> **密钥对**
>
> * 生成密钥对: ssh-keygen -m PEM -t rsa -b 4096 -f id_rsa
> * 进行PKCS#8编码:openssl pkcs8 -topk8 -inform PEM -in id_rsa -outform pem -nocrypt -out private_key.pem
> * 根据私钥生成公钥:openssl rsa -in private_key.pem -pubout -out public_key.pem
* 合作机构申请APP_ID
* 合作机构上传公钥
### **2.1 请求格式**
统一采用`POST`,业务数据作为`Json Body`,content-type 固定为`application/json`
### **2.2 公共参数**
与业务无明显关系的统称为公共参数,包括并不限于签名、appId、请求时间等,通通置于Request Header中。
| 参数名 | 必传 | 备注 |
| --- | --- | --- |
| B-APP-ID | N(请求平台接口为必传) | appId(平台为各机构分配的AppId,对接时提供) |
| B-SIGNATURE | Y | 请求签名 |
| B-TIMESTAMP | Y | 时间戳,精确到毫秒 |
### **2.3签名方式**
所有请求都需要签名,签名算法为RSA加解密`(RSA/MD5withRSA)`MD5字符编码:utf-8签名方式为 Json序列化请求参数后使用私钥进行RSA签名
#### **2.3.1签名**
1 将业务参数转码成 `json` 字符串 然后进行ASCII码排序
```
{
"type":3,
"val":"20220222122218596"
}
```
2 使用自己生成的私钥 RSA加密`(RSA/MD5withRSA)` 业务参数生成签名
3 将生成的签名放置到 `Request Header` `B-SIGNATURE` 中
4 发送请求
### **2.3.2验签**
1 将业务参数转码成 `json` 字符串 然后进行ASCII码排序
```
{
"type":3,
"val":"20220222122218596"
}
```
2 获取到请求头中的签名
3 使用公钥 和签名 进行RSA转码
### 请求响应
除明确说明外请求和返回的数据均为utf8编码,返回数据使用JSON格式,如:
~~~
{
"code": 200,
"msg": "",
"data": {
}
}
~~~
其中 code标示请求状态,200为操作成功,data 为具体的返回数据。其他状态码标示操作错误,msg会返回具体的错误信息
### 其他说明
* 金额,统一单位元,保留两位小数
* 时间,统一13位时间戳,精确到毫秒
# API
## 1 审核状态
#### 请求Path
POST`/api-public/loan-half/check-status`
#### 请求参数
| 参数名 | 参数名称 | 参数类型 | 是否允许为空 | 备注 |
| --- | --- | --- | --- | --- |
| `code` | 审核状态 | int | 否 | 200: 成功 400:失败|
| `msg` | 原因描述 | string | 否 | 审核失败时务必给出 失败原因,成功时为‘审核成功’ |
| `type` | 类型 | string | 否 | 1,2 ,3 更多请看 "val字段"|
| `val` | 类型 | string | 否 | type=1 val值为手机号,type=2值为身份证号 ,type = 3值为进件时的订单号 |
| `url` | app下载地址 | string | 是 | 审核成功时给出app下载的URL 失败时可为空字符串 ‘’|
| `amount` | 授信金额 | int | 是 | 审核成功时设置放款金额,默认为0 |
#### 2.4 响应参数
| 参数名 | 参数名称 | 参数类型 | 是否允许为空 | 备注 |
| --- | --- | --- | --- | --- |
| 无 | | | | |
###### 示例
* 成功
~~~
{
"code": 200,
"msg":"success",
"data":{}
}
~~~
## 2 放款状态
#### 请求Path
POST`/api-public/loan-half/amount-status`
#### 请求参数
| 参数名 | 参数名称 | 参数类型 | 是否允许为空 | 备注 |
| --- | --- | --- | --- | --- |
| `loan_status` | 放款状态 | int32 | 否 | 200: 成功 400:失败|
| `loan_result` | 原因描述 | string | 否 | 放款失败时务必给出 失败原因,成功时为‘放款成功’ |
| `type` | 类型 | int | 否 | 1,2 ,3 更多请看 "val字段"|
| `val` | 类型 | string | 否 | type=1 val值为手机号,type=2值为身份证号 ,type = 3值为进件时的订单号 |
| `url` | app下载地址 | string | 是 | 审核成功时给出app下载的URL 失败时可为空字符串 ‘’|
| `amount` | 放款金额 | int | 是 | 审核成功时设置放款金额,默认为0 |
#### 2.4 响应参数
| 参数名 | 参数名称 | 参数类型 | 是否允许为空 | 备注 |
| --- | --- | --- | --- | --- |
| 无 | | | | |
###### 示例
* 成功
~~~
{
"code": 200,
"msg":"success",
"data":{}
}
~~~
- 文档说明
- 开始
- linux
- 常用命令
- ps -ef
- lsof
- netstat
- 解压缩
- 复制
- 权限
- 其他
- lnmp集成安装
- supervisor
- 安装
- supervisor进程管理
- nginx
- 域名映射
- 负载均衡配置
- lnmp集成环境安装
- nginx源码安装
- location匹配
- 限流配置
- 日志配置
- 重定向配置
- 压缩策略
- nginx 正/反向代理
- HTTPS配置
- mysql
- navicat创建索引
- 设置外网链接mysql
- navicat破解
- sql语句学习
- 新建mysql用户并赋予权限
- php
- opcache
- 设计模式
- 在CentOS下安装crontab服务
- composer
- 基础
- 常用的包
- guzzle
- 二维码
- 公共方法
- 敏感词过滤
- IP访问频次限制
- CURL
- 支付
- 常用递归
- 数据排序
- 图片相关操作
- 权重分配
- 毫秒时间戳
- base64<=>图片
- 身份证号分析
- 手机号相关操作
- 项目搭建 公共处理函数
- JWT
- 系统函数
- json_encode / json_decode 相关
- 数字计算
- 数组排序
- php8
- jit特性
- php8源码编译安装
- laravel框架
- 常用artisan命令
- 常用查询
- 模型关联
- 创建公共方法
- 图片上传
- 中间件
- 路由配置
- jwt
- 队列
- 定时任务
- 日志模块
- laravel+swoole基本使用
- 拓展库
- 请求接口log
- laravel_octane
- 微信开发
- token配置验证
- easywechart 获取用户信息
- 三方包
- webman
- win下热更新代码
- 使用laravel db listen 监听sql语句
- guzzle
- 使用workman的httpCLient
- 修改队列后代码不生效
- workman
- 安装与使用
- websocket
- eleticsearch
- php-es 安装配置
- hyperf
- 热更新
- 安装报错
- swoole
- 安装
- win安装swoole-cli
- google登录
- golang
- 文档地址
- 标准库
- time
- 数据类型
- 基本数据类型
- 复合数据类型
- 协程&管道
- 协程基本使用
- 读写锁 RWMutex
- 互斥锁Mutex
- 管道的基本使用
- 管道select多路复用
- 协程加管道
- beego
- gin
- 安装
- 热更新
- 路由
- 中间件
- 控制器
- 模型
- 配置文件/conf
- gorm
- 初始化
- 控制器 模型查询封装
- 添加
- 修改
- 删除
- 联表查询
- 环境搭建
- Windows
- linux
- 全局异常捕捉
- javascript
- 常用函数
- vue
- vue-cli
- 生产环境 开发环境配置
- 组件通信
- 组件之间通信
- 父传子
- 子传父
- provide->inject (非父子)
- 引用元素和组件
- vue-原始写法
- template基本用法
- vue3+ts项目搭建
- vue3引入element-plus
- axios 封装网络请求
- computed 计算属性
- watch 监听
- 使用@符 代替文件引入路径
- vue开发中常用的插件
- vue 富文本编辑
- nuxt
- 学习笔记
- 新建项目踩坑整理
- css
- flex布局
- flex PC端基本布局
- flex 移动端基本布局
- 常用css属性
- 盒子模型与定位
- 小说分屏显示
- git
- 基本命令
- fetch
- 常用命令
- 每次都需要验证
- git pull 有冲突时
- .gitignore 修改后不生效
- 原理解析
- tcp与udp详解
- TCP三次握手四次挥手
- 缓存雪崩 穿透 更新详解
- 内存泄漏-内存溢出
- php_fpm fast_cgi cig
- redis
- 相关三方文章
- API对外接口文档示范
- elaticsearch
- 全文检索
- 简介
- 安装
- kibana
- 核心概念 索引 映射 文档
- 高级查询 Query DSL
- 索引原理
- 分词器
- 过滤查询
- 聚合查询
- 整合应用
- 集群
- docker
- docker 简介
- docker 安装
- docker 常用命令
- image 镜像命令
- Contrainer 容器命令
- docker-compose
- redis 相关
- 客户端安装
- Linux 环境下安装
- uni
- http请求封装
- ios打包
- 视频纵向播放
- 日记
- 工作日记
- 情感日志
- 压测
- ab
- ui
- thorui
- 开发规范
- 前端
- 后端
- 状态码
- 开发小组未来规划