最近遇到一个新项目,需要与硬件结合,进行读取信息并保存在数据库中。业务要求也在昨天发布一个问题,当然感谢许多园内的朋友出谋划策,截图有真相!

关于这个问题,我做了如下假设。目前处于测试状态,代码比较简单,具体功能已经实现。

1、首先一张比较丑的图片表名业务逻辑关系。


用户customer 他可以去A  B  C  D 四个办事处去登记信息。这样假设每个办事处有一个登记人员,假设customer 选择了 A ,(可能是离A比较近,他不想跑了)

登记人员说出示的卡。登记人员就把的卡往Arecorder 一放,点击鼠标,用户的信息就可以显示到web界面上了。看到这里是不是感觉很简单,不就是Arecorder 把customer的信息发送给web页面了吗?

你说的没有错,就是这么简单。那简单咱就技术实现吧。

技术实现:需要考虑哪些问题。

      1》  A recorder 只是一台具有连接网络或者局域网的计算机。 web 服务管理也不是部署在 A recorder 计算机上的,当然大家知道是部署在服务器上的。那么问题来了。要实现web服务器与Arecorder之间的通信怎么实现呢?

这也难不倒你,网络传输tcp socket编程。。。不难。这里对于这个问题,我们不做深入探究。我使用的是WCF技术。

2》  好了,web服务与A recorder 通信的问题解决了,那就写程序白。。。。。,半个小时过去了,你的编码速度很牛啊,service端和client的代码都搞定了,现在就测试可不可以呢。说道这里,service端的代码发布到与web服务IIS上面去,client代码当然去监控A recorder了,这里本来没有任何问题,我们知道service 的程序时一直运行的,它们之间的关系可以简单一张图表示,当然只是简单的 request-response模式。

看到这里,你可能发现问题。我应该何时请求呢,我贴卡的时候去Request,这是个好主意,Request 发送到哪里呢,肯定是service呀,不然还能发送到哪了,哈,那么问题来了? web服务管理不是给你一个人使用的,也就是说有好多人都在使用这套管理系统,可能赵四 王五 都在 登记用户信息,好你拿着custmoer的卡一刷,Request 就发送出去了,那么它会发送到你打开的web 页上吗???,或者发送到 赵四、或者王五的打开的页面上呢,那么这样这么多不确定性,确实不好办呢。怎么办???赶紧想呀,经理崔项目呢。。。

3》 时间一点一点过去,你想呀,突然脑袋灵光一现,为什么我非要等到customer刷卡的时,去Request呢,我为什么不能使登记人员去把握Request呢。而 A recorder 成为service呢。这样之间的关系不就清楚了吗。是呀到这里,恭喜你。那还等什么赶紧code呀。。。。,测试下,果然不错。哈哈哈。

4》经理说,我们不是需要一个A recorder,而是有 B C D 。。。,你一个都搞定了,多加几个也是没有问题的吧。瞬间整个人都不好了。。。,经理说了那也上呀,多个录卡器,多个工作登记人员,要想实现信息登录的正确性,怎么办,web服务又是大家共享的,顺着思路想下去,。。。。,多个Recorder,那就要区分每个Recorder,那好办,每个都绑定一个固定的IP不就可以了吗? 然后让web request ,好呀,干嘛,code呀。。。。,不对,我web request 了,那我应该需要的是哪个recorder的信息呢,怎么办? 这可能会造成我把别的customer的信息请求过来的。要是事先能知道Request哪一个就好了,怎么办,那就让登记人员,在请求的时候把选中那个recorder。不就可以了吗。是呀,如图:

5》到这里,通过分析已经找到了,解决方案,那么接下来要看编程技术了,这里只是简单的分享下。

coding: Recorder 端的代码。wcf基本结构四层结构;

Contract:

1---》IOctorpusService.cs

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.ServiceModel;
namespace DataWorld.Octorpus.Contract
{
[ServiceContract]
[ServiceKnownType(typeof(RecordMintor))]
public interface IOctorpusService
{
[OperationContract]
[FaultContract(typeof(OctorException))]
string GetOctorpusNo();
}
}

2----》OctorException.cs

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization;
namespace DataWorld.Octorpus.Contract
{
[DataContract]
public class OctorException
{
#region 私有类
private string _operation;
private string _errorMessage;
#endregion
#region 构造函数
public OctorException(string operation, string errorMessage)
{
this._operation = operation;
this._errorMessage = errorMessage;
}
#endregion
#region 公共方法
[DataMember]
public string Operation
{
get { return _operation; }
set { _operation = value; }
}
[DataMember]
public string ErrorMessage
{
get { return _errorMessage; }
set { _errorMessage = value; }
}
#endregion }
}

3----》RecordMintor.cs

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization;
namespace DataWorld.Octorpus.Contract
{
[DataContract]
public class RecordMintor
{
#region 私有字段
private string _CarNo;
private string _OctorpusNo;
#endregion
#region 构造函数
public RecordMintor(string carno, string octorpusno)
{
this._CarNo = carno;
this._OctorpusNo = octorpusno;
}
#endregion
#region 公共属性
[DataMember]
public string CarNo
{
get { return _CarNo; }
set { _CarNo = value; }
}
[DataMember]
public string OctorpusNo
{
get { return _OctorpusNo; }
set { _OctorpusNo = value; }
}
#endregion
}
}

Service:

1--》OctorpusService.cs

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using DataWorld.Octorpus.Contract;
namespace DataWorld.Octorpus.Service
{
public class OctorpusService:IOctorpusService
{ public string GetOctorpusNo()
{
// OctorException oe = new OctorException("Server exception", "Restart server"); RecordMintor rm = new RecordMintor(Guid.NewGuid().ToString(), Guid.NewGuid().ToString());
//throw new NotImplementedException();
Console.WriteLine(rm.CarNo);
return rm.OctorpusNo;
}
}
}

hosting:

1--》 program.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using DataWorld.Octorpus.Service;
using System.ServiceModel;
namespace DataWorld.Octorpus.Hosting
{
class Program
{
static void Main(string[] args)
{
using (ServiceHost host = new ServiceHost(typeof(OctorpusService)))
{
host.Opened += delegate { Console.WriteLine("listening..."); };
host.Open();
Console.Read();
}
}
}
}

2--》App.config

 <?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.serviceModel>
<bindings>
<wsHttpBinding>
<binding name="wsHttpBinding">
<security mode="None">
</security>
</binding>
</wsHttpBinding>
</bindings>
<behaviors>
<serviceBehaviors> <behavior name="OctorpusServiceBehavior">
<serviceMetadata httpGetEnabled="true"/>
</behavior>
</serviceBehaviors>
</behaviors>
<services>
<service name="Company.Octorpus.Service.OctorpusService" behaviorConfiguration="OctorpusServiceBehavior">
<endpoint address="" binding="wsHttpBinding" contract="Company.Octorpus.Contract.IOctorpusService" bindingConfiguration="wsHttpBinding"/>
<host>
<baseAddresses>
<add baseAddress="http://192.168.19.56:9999/Service"/>
</baseAddresses>
</host>
</service>
</services>
</system.serviceModel>
</configuration>

client:我写在了web中;

AutoGetCarNO.ashx

 using System;
using System.Collections.Generic;
using System.Web; namespace fairviewweb.Management
{
/// <summary>
/// Summary description for AutoGetCarNO
/// </summary>
public class AutoGetCarNO : IHttpHandler
{
private DateTime _endTime;
private bool _IsEndFlag = false;
private string _msg=null;
private Maticsoft.BLL.t_Recorder tbll = new Maticsoft.BLL.t_Recorder();
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string CarNodroplist = context.Request.QueryString["CarNodroplist"] == null ? string.Empty : context.Request.QueryString["CarNodroplist"].ToString();
Maticsoft.Model.t_Recorder tmodel= tbll.GetModel(CarNodroplist.Trim());
this._endTime=DateTime.Now.AddSeconds();
switch (tmodel.IPADDRESS)
{
case "ServiceReferenceA": try
{
ServiceReference1.OctorpusServiceClient _octorpusNO = new ServiceReference1.OctorpusServiceClient();
this._msg = _octorpusNO.GetOctorpusNo();
while (!_IsEndFlag)
{ if (!string.IsNullOrEmpty(this._msg))
{
_IsEndFlag = true;
}
if (this._endTime <= DateTime.Now)
{
_IsEndFlag = true;
}
}
if (string.IsNullOrEmpty(this._msg))
{
context.Response.Write("timeout");
}
else
{
context.Response.Write(this._msg);
}
}
catch (Exception ex)
{
string msg = ex.Message;
context.Response.Write("timeout");
}
break;
case "ServiceReferenceB": try
{
ServiceReference2.OctorpusServiceClient _octorpusNO = new ServiceReference2.OctorpusServiceClient();
this._msg = _octorpusNO.GetOctorpusNo();
while (!_IsEndFlag)
{ if (!string.IsNullOrEmpty(this._msg))
{
_IsEndFlag = true;
}
if (this._endTime <= DateTime.Now)
{
_IsEndFlag = true;
}
}
if (string.IsNullOrEmpty(this._msg))
{
context.Response.Write("timeout");
}
else
{
context.Response.Write(this._msg);
}
}
catch (Exception ex)
{
string msg = ex.Message;
context.Response.Write("timeout");
}
break;
case "ServiceReferenceC": try
{
ServiceReference1.OctorpusServiceClient _octorpusNO = new ServiceReference1.OctorpusServiceClient();
this._msg = _octorpusNO.GetOctorpusNo();
while (!_IsEndFlag)
{ if (!string.IsNullOrEmpty(this._msg))
{
_IsEndFlag = true;
}
if (this._endTime <= DateTime.Now)
{
_IsEndFlag = true;
}
}
if (string.IsNullOrEmpty(this._msg))
{
context.Response.Write("timeout");
}
else
{
context.Response.Write(this._msg);
}
}
catch (Exception ex)
{
//string msg = ex.Message;
context.Response.Write("timeout");
}
break;
} } public bool IsReusable
{
get
{
return false;
}
}
}
}

最后还给大家来个小贴图把:

前段的;

简单说明下,这个B代表是个Recorder ,然后去请求客户端。页面的实现是采用Ajax异步传输的,这里就不在累赘了。我只是采用这种办法,解决了,这个问题,如果你有更好的办法,可以继续交流。谢谢!

业务需求那些事,使用WCF如何实现业务需求!的更多相关文章

  1. 如何快速分析一款ios软件或需求的大流程,然后在业务层实现,不牵扯到界面?

    如何快速分析一款ios软件或需求的大流程,然后在业务层实现,不牵扯到界面?

  2. 业务SQL那些事--慎用LIMIT

    业务SQL那些事--慎用LIMIT 在业务中使用LIMIT限制SQL返回行数是很常见的事情,但如果不知道其中可能的坑或者说真正执行逻辑,就可能会使SQL执行非常慢,严重影响性能. LIMIT OFFS ...

  3. 什么是业务运维,企业如何实现互联网+业务与IT的融合

    业务运维并不是一个新概念,针对传统信息架构提出的业务服务管理就是把以业务为核心的IT系统与IT基础设施性能进行整合运维的解决方案.然而随着互联网+转型的不断推进,基础设施的智能化和广泛云化成为IT发展 ...

  4. DDD实战进阶第一波(八):开发一般业务的大健康行业直销系统(业务逻辑条件判断最佳实践)

    这篇文章其实是大健康行业直销系统的番外篇,主要给大家讲讲如何在领域逻辑中,有效的处理业务逻辑条件判断的最佳实践问题. 大家都知道,聚合根.实体和值对象这些领域对象都自身处理自己的业务逻辑.在业务处理过 ...

  5. 第二阶段:4.商业需求文档MRD:6.PRD-其他需求

  6. 业务逻辑审批流、审批流、业务、逻辑、面向对象、工作方式【c#】

    ------需求分析:--------1.先按照实际线下流程说这是什么事情,实际要干什么.2.再转换为面向对象-页面的操作流程,演示demo3.再与相关人员沟通是否可行需要什么地方修正.4.最终:线上 ...

  7. Android组件化

    附:Android组件化和插件化开发 App组件化与业务拆分那些事 Android项目架构之业务组件化 Android组件化核心之路由实现 Android组件化开发实践

  8. 深入浅出面向对象分析与设计读书笔记一&吉他搜索案例&吉他特性锚点集中&委托&重用&业务阶段&需求列表&用例

    案例:吉他搜索Guitar Inventory GuitarSpec需求变化:增加吉他弦数特性原始程序需要的变化: 1.修改GuitarSpec,构造,成员,getter 2.修改Guitar,构造, ...

  9. 我眼中BA(业务需求分析师)的技能广度和深度

    BA,或者称业务分析师,是企业数字能力和业务能力之间的沟通桥梁.随着企业数字转型的进一步深化,相信对BA这样的技能需求会越来越多,只是未必都用“BA/业务分析师”这样的Title. ThoughtWo ...

随机推荐

  1. eclipse搭建Log4J日志环境

    在hibernate使用的日志标准都为slf,slf可以看作为它的接口,因此需要找到它的实例,为我们做日志.我们选择使用log4j为实例. 1. 为防止冲突,先将slf4j-nop的jar包(它也是s ...

  2. 使用Kotlin开发Android应用(I):简单介绍

    使用Kotlin开发Android应用(I):简单介绍 @author ASCE1885的 Github 简书 微博 CSDN 原文链接 Kotlin是一门基于JVM的编程语言.它正成长为Androi ...

  3. 手机端页面自适应:rem布局

    rem布局非常简单,首页你只需在页面引入这段原生js代码就可以了 (function (doc, win) { var docEl = doc.documentElement, resizeEvt = ...

  4. CentOS 安装nload(流量统计)

    yum install gcc gcc-c++ ncurses-devel wget http://www.roland-riegel.de/nload/nload-0.7.2.tar.gz tar ...

  5. Android SDK开发常用工具的使用及其异常处理

    由于以下操作都是命令操作,所以在执行以下操作之前确保环境变量 ANDROID_HOME 指向的是正确的Android SDK的路径: 一.启动Android SDK Manager: android ...

  6. tabbedApliction

    一.手动创建UITabBarController 最常见的创建UITabBarController的地方就是在application delegate中的 applicationDidFinishLa ...

  7. (c#)WinForm遍历所有控件

    遍历WinForm中的所有控件,只执行一次以下语句是不行的 foreach (Control ctl in this.Controls) { } 这样只能遍历到第一层控件,子控件是遍历不到的,要想遍历 ...

  8. vuejs 三级联动

    最近在学习vuejs,写了一个城市三级联动效果,可以用在项目中的收获地址管理,支持新增与修改操作 HTML <script src="https://npmcdn.com/vue/di ...

  9. 算法竞赛中G++编译器的编译指令简单说明

    算法竞赛使用的在线判题平台在FAQ会给出提交的代码是通过什么指令进行编译的.比如hustoj给出的c++编译指令通常是: C++: g++ Main.cc -o Main -fno-asm -O2 - ...

  10. FileUpload控件

    FileUpload控件 属性:FileName: 获取上传的文件名 HasFile: 是否选择(存在)上传的文件 ContentLength: 获得上窜文件的大小,单位是字节(byte) 方法:Se ...