C#的DDE工控应用的B/S开发

本文介绍了如何在B/S系统中使用C#实现DDE(动态数据交换)客户端,与DDE服务器、中间件交互,以实现积水点监测系统的数据动态更新和报警功能。DDE客户端通过Advise动态获取并转换数据,再由中间件提供给B/S系统。在数据处理中,涉及了液位数据转换、警告判断和存储过程调用等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1:项目前提:上海市排水公司积水点监测系统升级,现有DDE服务,那只能通过DDECLIENT去访问了。客户又是要求B/S系统,这次又是放弃C/S系统进行开发.现在:整个项目使用 "设备" - DDESERVER - DDEClient - 中间件 - WEB 这样一个架构.(该项目已通过城投公司领导的汇报确认)

2:特点,主要完成DdeClient,与中间件服务业务功能.而中间件的服务主要是将数据提供给B/S

DDE思路:通过Advise动态交换DDE服务上的数据,通过POKE向DDE服务写数据,用于反控与参数设置!
注意:DDE API需要用户调用API自己封装,点NET并不提供DDE的开发模块!

3:内部运行的图,可参考“OPC的开发”,http://blog.youkuaiyun.com/zerodj/archive/2006/01/25/588289.aspx
4:DDE得到数据后,使用特定的公式转换出实际需要显示的数据!

5:DDE上Advise的事件
private static void MyClient_Advise(object sender, DdeClient.AdviseEventArgs args)
  {
   string sPrmValue = System.Text.Encoding.ASCII.GetString(args.Data).Replace(System.Environment.NewLine, "");
   string sPrmName  = args.Item;
   string sWhere = "PENAME = '" + sPrmName.Replace("'","''") + "'";

   DataRow[] dRows = null;
   lock(ddeParams.PARAMSINFO) //动态内存数据表
   {
    dRows = ddeParams.PARAMSINFO.Select(sWhere);
   }
   if(dRows == null)return;
   
   lock(dRows)
   {
    foreach(DataRow dRow in dRows)
    { 

     #region 如果是积水点的液位数据,需要转换陪率
     //如果是积水点的液位数据,需要转换陪率
     if(Convert.ToInt32(dRow["BWaterPOS"]) == 1)
     {
      //得到积水点编号
  &

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值