Finance API文档
0. 公共部分
请求url
- {apiRoot}/{method}?ver={version}&appkey={appkey}&sign={sign}
| 参数名 | 说明 | 示例 |
|---|---|---|
| apiRoot | 根地址 | http://localhost:9000 |
| method | 方法名 | /voucher/save |
| version | 版本号 | 1.0 |
| appkey | AppKey | FinanceClient |
| sign | 签名 | 5D3AA349E953AF0C15E38C147B15EE35 |
参数
| 参数名 | 必选 | 类型 | 说明 |
|---|---|---|---|
| Content | 是 | Content | 内容 |
| Token | 是 | string | 鉴权令牌,登录后获取 |
返回
| 参数名 | 必选 | 类型 | 说明 |
|---|---|---|---|
| Result | 是 | int | 结果码 |
| ErrMsg | 否 | string | 错误描述 |
| Solution | 否 | string | 解决建议 |
结果码
| 结果码 | 描述 | 说明 |
|---|---|---|
| 0 | SUCCESS | 成功 |
| 1000 | NULL_DTL | 没有导入的实现 |
| 1001 | FILE_NOT_EXISST | 文件不存在 |
| 1002 | RECORD_NOT_EXIST | 记录不存在 |
| 1003 | RECORD_EXIST | 记录已存在 |
| 1004 | IMPERFECT_DATA | 不完美的数据 |
| 1005 | SERVICE_TIMEOUT | 超时 |
| 1006 | NULL | 空的请求 |
| 1007 | INCORRECT_STATE | 当前状态不符合预期 |
| 1008 | AMMOUNT_IMBALANCE | 借贷不平衡 |
| 1009 | LINKED_DATA | 有关联的业务 |
| 3000 | NOT_SUPPORT | 不支持 |
| 3001 | SYSTEM_ERROR | 未知的系统错误 |
| 3002 | AUTHENTICATION_ERROR | 无效的签名 |
签名算法
string SignRequest(string body)
{
StringBuilder query = new StringBuilder(Secret);
query.Append(body);
query.Append(Secret);
MD5 md5 = MD5.Create();
byte[] bytes = md5.ComputeHash(Encoding.UTF8.GetBytes(query.ToString()));
StringBuilder result = new StringBuilder();
for (int i = 0; i < bytes.Length; i++)
{
result.Append(bytes[i].ToString("X2"));
}
return result.ToString();
}
1. 保存凭证
方法
- /voucher/save
请求方式
- POST
参数
- Content
| 参数名 | 必选 | 类型 | 说明 |
|---|---|---|---|
| header | 是 | VoucherHeader | 表头 |
| entries | 是 | List | 分录 |
| udefenties | 否 | Map<string,<string,object>> | 自定义扩展字段 |
- VoucherHeader
| 参数名 | 必选 | 类型 | 说明 |
|---|---|---|---|
| id | 是 | int | ID(为0即为新增,否则为修改的内码) |
| word | 是 | string | 凭证字:“记” |
| note | 否 | string | 备注 |
| reference | 否 | string | 参考信息 |
| year | 是 | int | 年度 |
| period | 是 | int | 期间 |
| businessDate | 是 | dateTime | 业务日期(2019-03-05T00:00:00) |
| date | 是 | dateTime | 日期(2019-03-05T00:00:00) |
| creatTime | 否 | dateTime | 创建时间(2019-03-05T00:00:00) |
| creater | 是 | int | 创建人 |
| cashier | 否 | string | 出纳 |
| agent | 否 | string | 经办人 |
- VoucherEntry
| 参数名 | 必选 | 类型 | 说明 |
|---|---|---|---|
| index | 是 | int | 分录号 |
| accountSubjectNo | 是 | string | 科目代号 |
| explanation | 否 | string | 摘要 |
| amount | 是 | decimal | 金额 |
| direction | 是 | int | 方向:1(借方),-1(贷方 ) |
| uniqueKey | 是 | string | 唯一码(uuid),作为自定义内容的键值 |
返回
| 参数名 | 必选 | 类型 | 说明 |
|---|---|---|---|
| Id | 条件 | int | 如果成功,返回凭证内码 |
示例
- url : http://localhost:9000/voucher/save?ver=1.0&appkey=FinanceClient&sign=5D3AA349E953AF0C15E38C147B15EE35
- body:
{
"Content" : {
"header" : {
"id" : 0,
"word" : "记",
"note" : null,
"reference" : "参考信息",
"year" : 2019,
"period" : 3,
"businessDate" : "2019-03-05T00:00:00",
"date" : "2019-03-05T00:00:00",
"creatTime" : "2019-03-05T23:46:01",
"creater" : 13594,
"cashier" : "出纳",
"agent" : "经办"
},
"entries" : [{
"index" : 1,
"accountSubjectNo" : "1001",
"explanation" : "摘要",
"amount" : 200.0,
"direction" : 1,
"uniqueKey": "afffc876a94049afaa7275c7c7d8d76f"
}, {
"index" : 2,
"accountSubjectNo" : "1002",
"explanation" : "摘要",
"amount" : 200.0,
"direction" : -1,
"uniqueKey": "7761b2300fdb48bd991e570c0f8fc39f"
}
],
"udefenties": {
"afffc876a94049afaa7275c7c7d8d76f": {
"cust": "",
"price": 4.0,
"qty": 78.0
},
"7761b2300fdb48bd991e570c0f8fc39f": {
"cust": null,
"price": 0.0,
"qty": 0.0
}
}
},
"Token" : "3AIavxSAoaJhuBB1o4hc6fw4hNlpC4KoXgfT1mpu1hyQiA_lqKNKOkNDtC_mKdHiWEAHooTE1vZAtsYhz4g_jNoNR5JBkp9UHXZSYFbSuj0j38muKaMbFhTRMEZ_xqd4znSY_Fcp8V96hto4VpLWqh0__yHKFoRZQ0DGS5HcrpQ="
}
返回
{
"id" : 233,
"Result" : 0,
"ErrMsg" : null,
"Solution" : null
}
Finance API文档的更多相关文章
- Java在DOS命令下的运行及其API文档制作过程
该文档主要描述java程序在DOS命令下的运行,以及一些常用的命令 常用DOS命令: d: 回车 盘符切换 dir(directory):列出当前目录下的文件以及文件夹 md (make direct ...
- 在ASP.NET Core Web API上使用Swagger提供API文档
我在开发自己的博客系统(http://daxnet.me)时,给自己的RESTful服务增加了基于Swagger的API文档功能.当设置IISExpress的默认启动路由到Swagger的API文档页 ...
- 利用sphinx为python项目生成API文档
sphinx可以根据python的注释生成可以查找的api文档,简单记录了下步骤 1:安装 pip install -U Sphinx 2:在需要生成文档的.py文件目录下执行sphinx-apido ...
- 如何使 WebAPI 自动生成漂亮又实用在线API文档
1.前言 1.1 SwaggerUI SwaggerUI 是一个简单的Restful API 测试和文档工具.简单.漂亮.易用(官方demo).通过读取JSON 配置显示API. 项目本身仅仅也只依赖 ...
- Android多媒体--MediaCodec 中文API文档
*由于工作需要,需要利用MediaCodec实现Playback及Transcode等功能,故在学习过程中翻译了Google官方的MediaCodec API文档,由于作者水平限制,文中难免有错误和不 ...
- 新手如何查看API文档?
Java API文档为例: 1:知道包名,可以在Overview里直接找到这个包,然后去查这个包下面的类和方法.2:知道类名和方法名,可以在Index.html里直接去找这个类或方法,然后查看.3:如 ...
- Bullet的学习资源(用Doxygen生成API文档)
Bullet 全称 Bullet Physics Library,是著名的开源物理引擎(可用于碰撞检测.刚体模拟.可变形体模拟),这里将bullet的学习资源整理一下,希望能帮助入门者少走弯路. 看下 ...
- [API]使用Blueprint来高雅的编写接口文档 前后端api文档,移动端api文档
网址:http://apiary.io/ 介绍:一款非常强大的前后端交互api设计编辑工具(编辑器采用Markdown类似的描述标记,非常高效),高颜值的api文档,还能生成多种语言的测试代码. 中文 ...
- jQuery MiniUI开发系列之:使用API文档
jQuery MiniUI在组件设计上,是简约.独立的,没有复杂的继承体系. 比如使用DataGrid,可以在api文档的datagrid部分,查找到datagrid的所有属性.方法.事件,而无需关注 ...
随机推荐
- 简介C#读取XML的方式(转)
在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询. XML作用 ...
- 手机APP测试之monkey
Monkey测试是一种为了测试软件稳定性.健壮性的快速有效的方法,Monkey程序由Android系统自带,使用Java语言写成.本此由于公司APP产品所需,用monkey进行稳定性测试,下面将本次使 ...
- python类的动态属性设置
需求:根据入参,动态添加设置类的属性 实现: self.__setattr__ self.__getattribute__
- cxgrid主从表的从表数据小于主表总数的问题
当从表的数据移动需要和数据源记录同步时,会发生一现象:从表中设定的keyfield记录不连续,显示就会中断. 这样要设置从表的排序,按照主表的关联键在内存表里进行排序 indexFieldNames设 ...
- Python 学习笔记01篇
编程基础很零碎 看了路飞学城的讲解视频,整体课程列表排列很清晰,每个视频都在十几分钟到二十几分钟之间,适合零碎化的的学习 第一章和第二章的前半部分可以较轻松地入门
- Spring 获取bean 几种方式
转载自: http://www.cnblogs.com/luoluoshidafu/p/5659574.html 1.读取xml文件的方式,这种在初学入门的时候比较适用 . ApplicationCo ...
- git--创建空的分支
背景:项目进行中,需要创建一个空分支.在Git中创建分支,是必须有一个父节点的,也就是说必须在已有的分支上来创建新的分支,如果你的工程已经进行了一段时间,这个时候是无法创建空分支的. 解决方法: 使用 ...
- SpringCloud-day05-服务调用Ribbon
6.服务调用Ribbon 6.1Ribbon简介 前面讲了eureka服务注册与发现,但是结合eureka集群的服务调用并没有谈到.这里就要用到Ribbon,结合eureka,来实现服务的调用: Ri ...
- Redis主从集群及哨兵模式
本次实验环境准备用一台服务器模拟3台redis服务器,1主2从 主从集群搭建 第一步:安装Redis 安装Redis,参考前面安装Redis文章,保证单机使用没有问题. 第二步:配置服务器文件 定位到 ...
- pandas列操作集锦
列操作 pandas的列操作 数据准备: 增 将两张表合并到一起 pd.concat([page_001,page_002]).reset_index(drop=True) 默认从上到下合,如果想从左 ...