我正在VB.NET(紧凑框架)中构建移动应用程序,我想知道在设备上进行潜在离线交互的最佳方法是什么。基本上,这些设备具有蜂窝和802.11,但可能仍处于离线状态(接收效果不佳等)。司机会在他们离开卡车时扫描箱子,我想更新新位置 - 如果有网络信号则立即更新,或者如果离线并稍后处理则排队。不过,这让我想到了如何处理离线问题。
我不是在寻找一个特定的解决方案,但实际上只是关于开发人员如何利用最流畅的用户体验实现这一目标的故事,并提供了一个指向操作方法或者后续操作的链接或者类似的内容。感谢您对此的指示!
答案 0 :(得分:2)
我们无法给出明确的答案,因为没有适合所有使用场景的“正确”答案。例如,如果您在后端使用SQL Server而在本地使用SQL CE,则可以始终设置合并复制并让数据引擎为您处理所有这些。那很干净。使用脱机应用程序块可能会解决它。使用存储转发可能是一种选择。
您可以在本地存储,然后使用直接连接,在检测到网络时使用的WCF服务的Web服务来滚动您自己的同步。您可以使用MSMQ进行交付。
您必须考虑的不是“正确”的方式,而是您的实施将如何影响应用程序的可用性。如果由于缺乏连接而禁用功能,应用程序是否仍然可用?如果您有陈旧数据,那是一个问题吗?当您拥有GSM / GPRS(通常不是免费的)时,可能需要传输一些关键数据,而当您拥有802.11时,可能需要做更多的工作。也许你可以整天运行,在早上下拉查找表并只上传交易,设备跟踪它所做的更改。
基本上,它实际上取决于它的使用方式,数据的性质,现场设备之间数据事务的重要性,数据延迟的影响,以及其他我无法想到的因素。
因此,第一步是确定应用程序的使用方式,然后确定基础架构和架构,以提供所需的连接和数据访问。
答案 1 :(得分:0)
我自己没有用过它,但是你有没有考虑过CF的“存储和转发”功能?它可能适合您的需求。我相信它使用Exchange邮箱作为消息队列来向设备发送SOAP数据包。
答案 2 :(得分:0)
解决此问题的最佳方法是始终脱机工作,然后使用消息队列来处理向设备发送更改和从设备发送更改。例如,当驱动程序标记已交付的内容时,更新本地存储中提供的项目,并在传出队列中放置一条消息,告诉服务器它已交付。连接启动时,将任何排队的项目发送回服务器,并从服务器获取已排队的任何消息。