跳到主要内容

保存非生产退料单

非生产退料单存盘接口

基本信息

信息备注
接口名称非生产退料单保存根据单据 ID 来新增单据(包括修改)
请求状态POSTRESTful 方式
接口路径http://localhost:23798/api/Bill/SaveBill向服务器地址发送 POST 请求
远程模式http://www.linkerplus.com/api/ext_erp/Bill/SaveBill远程模式向服务器地址发送 POST 请求,需要 ERP 注册号注册远程模式,并在 Headers 添加 sn 参数
支持日期2020-12-21自该日期起支持

请求参数

Headers

参数名称是否必须参数值备注
Content-Typeapplication/json用于指定数据的传输类型
LoginIde835943e-55c2-4bf0-832d-6f4166592941用户登录的 LoginId,取用户登录或账套验证接口返回的 LoginId
snMGR_REST_1001远程模式需添加 sn 参数,MGR_REST_ERP注册号

Body

参数名称类型是否必须参数值备注其它信息
HeadDataobject表头数据
EntryOrderIdstringWMS00001调用方业务编码调用方唯一编码,关联 ERP 单据,且避免重复提交,当提交的 EntryOrderId 重复时返回提示。为空则没有该项检测
CallIdstringM8调用的单据识别号"M8":表示非生产退料单
CallNostringM80C240001调用的单据号码传入该值代表修改原单据信息,新增数据时无需添加
DepNostringCGB部门代号
FixCststring1成本别1.固定成本,2.变动成本;为空时默认2
Remstring这是表头备注备注
UsrNostringADMIN制单人账套验证的 LoginId 需添加 UsrNo,用户登录的 LoginId 则无需添加 UsrNo
ExtendPropsobject"CUS_OS_NO":"OS0C220001",
"ZDY": "自定义"
表头扩展功能包括表头的其它字段以及用户自定义字段,字段名需与数据库表名一致
NotUseAuditFlowstringT/F跳过审核流程,自动审核。默认不跳过当传"T"时,该单据通过接口生成时,不考虑审核流程,直接自动终审
BodyDataobject []表身数据item 类型: object
CallItmnumber1原单项次HeadData 中 CallNo 存在并有值时才生效,传入该值代表修改原单据表身对应 PRE_ITM 列的信息,新增数据时无需添加
PrdNostringYL1货品代号修改时非必须
WhNostring003仓库代号为空时默认取0000
BatNostringPH01批号
PrdMarkstringTZ01特征
PrdLocstringCW01储位
Unitstring1单位
Qtynumber3主数量修改时非必须
Qty1number6副数量
Upnumber2单位成本成本别为2.变动成本时不需要输入该值
Up1number1单位成本[副]成本别为2.变动成本时不需要输入该值
Cstnumber6成本成本别为2.变动成本时不需要输入该值
Remstring这是表身摘要摘要
IsDeletestringF删除行CallItm 存在并有值时才生效,传入该值为 T 代表删除原单据表身对应 PRE_ITM 列,不删除行时无需添加
ExtendPropsobject"Valid_DD":"2020-12-23",
"ZDY": "自定义",
"SEQ_ITM":1
表身扩展功能包括表身的其它字段以及用户自定义字段,字段名需与数据库表名一致

返回数据

参数名称类型参数值备注
EntryOrderIdstringWMS00001调用方业务编码
CallIDstringM8调用的单据识别号
CallNOstringM80C240001生成的单据号码
CallOKstringT执行是否成功, 是:"T" 否:"F"
Datastring"TF_TABNAME": "TF_FL",
"BIL_ITM": "0",
"MF_TABNAME": "MF_FL",
"BIL_NO": "M80C240001",
"BIL_ID": "M8"
单据信息,JSON 字符串格式
ErrorStrstring错误信息

调用范例

Request

无需赋值的字段不需要添加,转入来源单或修改原单据时传入的字段代表修改原值

无来源示范

{
"HeadData": { // 必须,表头数据
"EntryOrderId": "WMS00001", // 非必须,调用方业务编码
"CallId": "M8" // 必须,调用的单据识别号,"M8":表示非生产退料单
},
"BodyData": [ // 必须,表身数据
{
"PrdNo": "YL1", // 必须,货品代号
"Qty": 3 // 必须,主数量
},
{
"PrdNo": "YL2", // 必须,货品代号
"Qty": 4 // 必须,主数量
}
]
}

完整字段

{
"HeadData": { // 必须,表头数据
"EntryOrderId": "WMS00001", // 非必须,调用方业务编码
"CallId": "M8", // 必须,调用的单据识别号,"M8":表示非生产退料单
"CallNo": "M80C240001", // 非必须,调用的单据号码,传入该值代表修改原单据信息,新增数据时无需添加
"DepNo": "CGB", // 非必须,部门代号
"FixCst": "2", // 非必须,成本别
"Rem": "这是表头备注", // 非必须,备注
"UsrNo": "ADMIN", // 非必须,制单人,采用账套验证方式获取LoginId时必须
"ExtendProps": { // 非必须,扩展功能,包括表头的其他字段以及用户自定义字段
"CUS_OS_NO": "OS0C220001" // 字段名需与数据库表名一致
}
},
"BodyData": [ // 必须,表身数据
{
"CallItm": 1, // 非必须,原单项次,传入该值代表修改原单据表身对应PRE_ITM列的信息,新增数据时无需添加
"PrdNo": "YL1", // 必须,货品代号,修改时非必须
"WhNo": "003", // 非必须,仓库代号
"BatNo": "PH01", // 非必须,批号
"PrdMark": "TZ01", // 非必须,特征
"PrdLoc": "CW01", // 非必须,储位
"Unit": "1", // 非必须,单位
"Qty": 3, // 必须,主数量,修改时非必须
"Qty1": 6, // 非必须,副数量
"Up": 2, // 非必须,单位成本
"Up1": 1, // 非必须,单位成本[副]
"Cst": 6, // 非必须,成本
"Rem": "这是表身摘要", // 非必须,摘要
"IsDelete": "F", // 非必须,删除行,传入该值为T代表删除原单据表身对应PRE_ITM列,不删除行时无需添加
"ExtendProps": { // 非必须,扩展功能,包括表身的其他字段以及用户自定义字段
"Valid_DD": "2020-12-23" // 字段名需与数据库表名一致
}
}
]
}

添加序列号

无来源需添加SeqData、有来源直接取来源单的序列号

{
"HeadData": {
"EntryOrderId": "WMS00001",
"CallId": "M8"
},
"BodyData": [
{
"PrdNo": "XLH", // 必须,序列号货品
"Qty": 2, // 必须,需要和序列号数量总和相等
"ExtendProps": {
"SEQ_ITM": 1 // 必须,需要对应SeqData中的"SEQ_ITM"
}
}
],
"SeqData": [ // 必须,序列号数据
{
"SEQ_NO": "A01", // 必须,序列号
"SEQ_ITM": 1, // 必须,需要对应"BodyData""ExtendProps"中的"SEQ_ITM"
"QTY": 1 // 必须,数量,固定为1
},
{
"SEQ_NO": "A02", // 必须,序列号
"SEQ_ITM": 1, // 必须,需要对应"BodyData""ExtendProps"中的"SEQ_ITM"
"QTY": 1 // 必须,数量,固定为1
}
]
}

Response

{
"EntryOrderId": "WMS00001", // 调用方业务编码
"CallID": "M8", // 调用的单据识别号
"CallNO": "M80C240001", // 生成的单据号码
"CallOK": "T", // 执行是否成功,是:"T" 否:"F"
"Data": "{\r\n \"TF_TABNAME\": \"TF_FL\",\r\n \"BIL_ITM\": \"0\",\r\n \"MF_TABNAME\": \"MF_FL\",\r\n \"BIL_NO\": \"M80C240001\",\r\n \"BIL_ID\": \"M8\"\r\n}", // 单据信息, JSON字符串格式
"ErrorStr": "" // 错误信息
}

备注

  • 必须在 Headers 里面传入用户登录或账套验证的LoginId
  • 当采用的是账套验证获取的LoginId,那么 HeadData 中UsrNo就是制单人,不能为空。采用用户登录的LoginId则无需添加UsrNo,用户即制单人。
  • Body 中 JSON 字段,尽量不要添加赋空值的字段。
  • ExtendProps中为拓展字段,需要对应数据库表的字段,自定义字段同样在这里处理。
  • 统一字段与接口所需数据库表字段重复时,只取统一字段的值。
  • 接口程序不处理审核,没有审核流直接终审,有审核流就处于未审状态。
  • 可查看后台表LOG_BILLSAVE查看执行信息。
  • 当 HeadData 中 EntryOrderId 不为空时,可查看后台表LOG_OTHERSAVE查看单据关联信息。
EntryOrderId

EntryOrderId:为同一次调用动作的唯一 ID,全局唯一,建议采用随机 uuid/guid;例如调用方请求第一次时,无响应信息或者响应错误后再请求一次时,该 EntryOrderId 应相同,为同一次调用动作。相反,调用方第一次调用返回成功信息后,删除了单据(无论删除 ERP 单据还是调用方单据),再重新调用一次,此时 EntryOrderId 是不能与没删除前的 EntryOrderId 相同。简而言之,只要调用接口返回成功信息后的 EntryOrderId 就不能再重复调用。