C#连接SAP并下载工单资料【生产系统与ERP对接】
时间:2019-11-29
本文章向大家介绍C#连接SAP并下载工单资料【生产系统与ERP对接】,主要包括C#连接SAP并下载工单资料【生产系统与ERP对接】使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
企业如果上了ERP系统,比如SAP、用友、金蝶或者E10等等,只需要ERP里面提供相应的接口,则可以直接将PMC创建的工单信息抛转至 MTS 系统,当该工单生产完成之后,MTS 将完成数据回传至 ERP,方便货仓进行入仓与扣数,这篇文章介绍 MTS 与 SAP 之间如何对接。
1.SAP里面必须有一个Function,类似 MSSQL里面的存储过程一样,根据用户传入的参数,返回所需要的数据,这一部分程序通过 ABAP 完成,不在本文的讲述范围之类,这里略过。
2.MTS连接到 SAP,Call对应的 Function,拿到数据后进行处理,这里需要准备以下几个参数。
- SAP服务器的IP地址
- 访问SAP的用户名
- 访问SAP的密码
- SAP系统的实例编号
- SAP系统的客户端编号
为了方便多个地方调用,这里将Call SAP 的代码写成一个方法,避免重复代码,代码如下:
using SAP.Middleware.Connector;
public class SapHelper { public IRfcTable GetSapData(string FunctionName, string TableName, List<string> Key, List<string> Value) { string Server = ConfigurationManager.AppSettings["SapServer"]; string Client = ConfigurationManager.AppSettings["SapClient"]; string User = ConfigurationManager.AppSettings["SapUser"]; string Password = ConfigurationManager.AppSettings["SapPwd"]; string SystemNumber = ConfigurationManager.AppSettings["SapSystemNumber"]; RfcConfigParameters rfcPar = new RfcConfigParameters(); rfcPar.Add(RfcConfigParameters.Name, "CON"); rfcPar.Add(RfcConfigParameters.AppServerHost, Server); rfcPar.Add(RfcConfigParameters.Client, Client); rfcPar.Add(RfcConfigParameters.User, User); rfcPar.Add(RfcConfigParameters.Password, Password); rfcPar.Add(RfcConfigParameters.SystemNumber, SystemNumber); rfcPar.Add(RfcConfigParameters.Language, "EN"); RfcDestination dest = RfcDestinationManager.GetDestination(rfcPar); RfcRepository rfcrep = dest.Repository; IRfcFunction myfun = null; myfun = rfcrep.CreateFunction(FunctionName); IRfcTable IrfTable = myfun.GetTable(TableName); if (Key.Count != Value.Count) { return null; } for (int i = 0; i < Key.Count; i++) { myfun.SetValue(Key[i].ToString(), Value[i].ToString()); } myfun.Invoke(dest); return IrfTable; } }
当用户输入需要下载的工单号码之后,系统连接到 SAP 开始调用函数:
string Order = Request["LotName"]; if (string.IsNullOrEmpty(Order)) { return; }
//这里强烈建议将参数以key value的形式传进去,方便很多。
List<string> Key1 = new List<string>(); List<string> Value1 = new List<string>(); Key1.Insert(0, "ORDER_NUMBER"); Value1.Insert(0, Order); IRfcTable IrfTable_Order = new SapHelper().GetSapData("function", "table", Key1, Value1); DataTable dt_Order = new DataTable(); dt_Order.Columns.Add("LotName"); dt_Order.Columns.Add("ProductName"); dt_Order.Columns.Add("LotQuantity"); dt_Order.Columns.Add("Customer"); dt_Order.Columns.Add("Plant"); for (int i = 0; i < IrfTable_Order.Count; i++) { IrfTable_Order.CurrentIndex = i; DataRow dr = dt_Order.NewRow(); dr["LotName"] = IrfTable_Order.GetString("AUFNR"); dr["ProductName"] = IrfTable_Order.GetString("STLBEZ"); dr["LotQuantity"] = Math.Round(Convert.ToDouble(IrfTable_Order.GetString("GAMNG")), 0).ToString(); dr["Customer"] = IrfTable_Order.GetString("PSPEL"); dr["Plant"] = IrfTable_Order.GetString("WERKS"); dt_Order.Rows.Add(dr); } var json = Newtonsoft.Json.JsonConvert.SerializeObject(dt_Order); var totalRecordCount = dt_Order.Rows.Count.ToString(); json = "{\"total\":" + totalRecordCount + ",\"rows\":" + json + "}"; Response.Write(json); Response.End();
注意,从SAP里面得到的数据是一张 rfc table,并不是我们常用的 DataTable,所以这里需要进行转换后才能使用,最后将数据转换为 JSON 输出即可:
下一篇将介绍如何将 MTS 里面的工单完工数回传至 SAP 里面,方便货仓入仓与扣数...
原文地址:https://www.cnblogs.com/allen0118/p/11957699.html
- 【防护】如何阻止SELECT * 语句
- COGS 862. 二进制数01串【dp+经典二分+字符串】
- 【AlphaGo Zero 核心技术-深度强化学习教程代码实战03】编写通用的格子世界环境类
- 冒泡排序简单操作模版及实例分析
- COGS 1299. bplusa【听说比a+b还要水的大水题???】
- python学习笔记之运算符
- 锐捷网络NBR部分路由器cookie欺骗权限绕过
- 手写快排模版
- COGS 68. [NOIP2005] 采药【01背包复习】
- UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
- 我的第一个网页制作:Hello World!
- UESTC 1584 Washi与Sonochi的约定【树状数组裸题+排序】
- Hyperledger - 超级账本项目:简介,安装,案例
- 我的第三个网页制作:b、i、s、u、sub、sup标签的使用
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- CSS盒模型、边框和背景、表格和列表、颜色和透明度、阴影和轮廓及长度单位rem
- C++核心准则CP.110:不要自已为初始化编写双重检查锁定代码
- BOSS直聘招聘信息获取之爬虫程序数据处理
- BOSS直聘招聘信息获取之爬虫程序分析
- 历时4个多月,学习了这 66 个CSS 特效
- ArrayList、LinkedList哪家强,据说90%人都不知道
- Windows创建克隆隐藏账号
- 学员分享-aspera踩坑记录
- BOSS直聘招聘信息获取之爬虫工具分析
- 把你的shiny网页工具部署在云服务器
- 面试中的路由问题
- BOSS直聘招聘信息获取之使用webdriver进行爬取
- es6中class的一些基础知识和es5语法的对比
- Windows 系统常用命令行命令(一):前言
- Vue项目使用mt-picker实现省市区三级联动踩坑记录