解析大型.NET ERP系统 电子邮件系统帐户集成

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 为保证ERP系统的信息流准确快速的传递,需要给系统设计一个消息盒子机制。当系统中发生业务操作后,需要提醒下一个环节的操作人员,以保证ERP信息流快速准确传递。比如生产任务单(工作单,加工单,制单)过帐完成后,需要通知仓库准备材料供车间领料生产。

为保证ERP系统的信息流准确快速的传递,需要给系统设计一个消息盒子机制。当系统中发生业务操作后,需要提醒下一个环节的操作人员,以保证ERP信息流快速准确传递。比如生产任务单(工作单,加工单,制单)过帐完成后,需要通知仓库准备材料供车间领料生产。消息盒子的界面大致如下所示:


解析大型.NET ERP系统 电子邮件系统帐户集成



消息盒子包含业务通知(Messages)工作流审批(Workflow)。业务通知比如采购人员下达采购订单PO后,需要通知仓库人员准备收货。工作流审批是以审批为基础的单据流程控制。


在实现消息盒子过程中,遇到一个客户需要将消息同时发送到电子邮件系统中,于是撰此文以分享实现过程。


客户的目的很简单,发送消息的同时,也将此消息抄送到相应的邮件帐户中:


解析大型.NET ERP系统 电子邮件系统帐户集成



实施部分


1 搭建电子邮件服务器


有以下几种选择


1 与Outlook搭配的邮件服务器Exchange Server是一个很好的邮件服务器,只是配置稍微复杂一点。


2 Magic WinMail ,WinWebMail 免费版可发布50-100个帐户,超过此限制需要购买授权。


3 hMailServer 开源,免费,无限制。提供COM接口可供二次开发。


最终选择hMailServer作为ERP系统的邮件服务器。配置过程此处略过。


安装好hMailServer后,创建域名EnterpriseSolution.com,并启用它。


解析大型.NET ERP系统 电子邮件系统帐户集成



2 同步帐户邮件


打开同步程序,如下图所示,输入管理员密码后连接到邮件服务器中。这是我调用COM接口完成的程序。


解析大型.NET ERP系统 电子邮件系统帐户集成



在这个程序中, 可以将ERP用户的邮件同步到hMailServer的帐户表中。


点击同步按钮,打开ERP帐户选择窗体,再点击确认之后,ERP中的帐户就同步到hMailServer邮件系统中。


解析大型.NET ERP系统 电子邮件系统帐户集成



查看hMailServer的帐户:


解析大型.NET ERP系统 电子邮件系统帐户集成



开发部分


下面详细讲解一下上面的同步程序是如何实现的,它是一个简单的C#调用C++ COM接口的程序。hMailServer官方给出的COM帮助文档地址在这里:https://www.hmailserver.com/documentation/v5.6/?page=com_objects


1 读取邮件系统帐户


先创建连接到hMailSever服务器


private Domain HMailServerConnection()

{

string hMailDomain = txtDomain.Text;

string HMailUsername = "Administrator";

string HMailPassword = txtPassword.Text;

var objGlobal = new ApplicationClass();

objGlobal.Authenticate(HMailUsername, HMailPassword);

return objGlobal.Domains.get_ItemByName(hMailDomain);

}


大部分时间我们都是与接口对象Domain交互。


然后读取帐户表数据绑定到界面网格控件中。


DataTable table = new DataTable("Table");

table.Columns.Add("Address", typeof (string));

table.Columns.Add("Password", typeof (string));

table.Columns.Add("PersonFirstName", typeof (string));

table.Columns.Add("PersonLastName", typeof (string));

_domain = HMailServerConnection();

Accounts accounts = _domain.Accounts;

for (int i = 0; i < accounts.Count; i++)

{

Account account = accounts[i];

DataRow dataRow = table.NewRow();

dataRow["Address"] = account.Address;

dataRow["Password"] = account.Password;

dataRow["PersonFirstName"] = account.PersonFirstName;

dataRow["PersonLastName"] = account.PersonLastName;

table.Rows.Add(dataRow);

}

gridAccount.AutoGenerateColumns = false;

gridAccount.DataSource = table;


2 添加邮件帐户


参考下面的代码调用


Domain domain = HMailServerConnection();

Accounts accounts = domain.Accounts;

Account mailbox = accounts.Add();

mailbox.Address = email;

mailbox.Password = password;

mailbox.Save();


3 清除邮件帐户


参考下面的代码


Accounts accounts = _domain.Accounts;

int count = accounts.Count;

while (count > 0)

{

_domain.Accounts.Delete(0);

count--;

}

_domain.Accounts.Refresh();


hMailSever提供的COM接口是x86架构的,所以这个项目我只能设x86编译平台。


4 多国语言


这个项目还有涉及到多语言实现,我采用的是一个公共方法翻译界面上的控件,参考下面的代码。


public static void TranslateForm(Form form)

{

string labelText = string.Empty;

DataRow dataRow = null;

string translation = string.Empty;

switch (Application.CurrentCulture.LCID)

{

case 2052:

translation = "CHS";

break;

case 1028:

case 3076:

case 5124:

translation = "CHT";

break;

}

foreach (var label in GetAllControlsRecusrvive<Label>(form))

{

labelText = label.Text.Trim().TrimEnd(':');

dataRow = Shared.TranslationTable.Rows.Find(labelText);

if (dataRow != null)

label.Text = Convert.ToString(dataRow[translation]);

}


我只需要在每个界面的窗体加载事件中调用上面的方法即可完成多语言功能。


protected override void OnLoad(EventArgs e)

{

base.OnLoad(e);

Shared.TranslateForm(this);

}


界面翻译项来自于项目嵌入的Xml资源文件。


项目源代码文件:http://files.cnblogs.com/files/JamesLi2015/Synchronization.zip


云服务器ECS地址:阿里云·云小站


相关文章
|
2月前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
218 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
24天前
|
小程序 前端开发 关系型数据库
uniapp跨平台框架,陪玩系统并发性能测试,小程序源码搭建开发解析
多功能一体游戏陪练、语音陪玩系统的开发涉及前期准备、技术选型、系统设计与开发及测试优化。首先,通过目标用户分析和竞品分析明确功能需求,如注册登录、预约匹配、实时语音等。技术选型上,前端采用Uni-app支持多端开发,后端选用PHP框架确保稳定性能,数据库使用MySQL保证数据一致性。系统设计阶段注重UI/UX设计和前后端开发,集成WebSocket实现语音聊天。最后,通过功能、性能和用户体验测试,确保系统的稳定性和用户满意度。
|
1月前
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
50 7
|
2月前
|
前端开发 C# 开发者
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
.NET使用Umbraco CMS快速构建一个属于自己的内容管理系统
46 12
|
2月前
|
Web App开发 前端开发 调度
一款基于 .NET + Blazor 开发的智能访客管理系统
一款基于 .NET + Blazor 开发的智能访客管理系统
|
2月前
|
开发框架 JavaScript 前端开发
精选2款.NET开源的博客系统
精选2款.NET开源的博客系统
|
2月前
|
前端开发 JavaScript C#
基于.NET8+Vue3开发的权限管理&个人博客系统
基于.NET8+Vue3开发的权限管理&个人博客系统
|
2月前
|
存储 监控 算法
企业内网监控系统中基于哈希表的 C# 算法解析
在企业内网监控系统中,哈希表作为一种高效的数据结构,能够快速处理大量网络连接和用户操作记录,确保网络安全与效率。通过C#代码示例展示了如何使用哈希表存储和管理用户的登录时间、访问IP及操作行为等信息,实现快速的查找、插入和删除操作。哈希表的应用显著提升了系统的实时性和准确性,尽管存在哈希冲突等问题,但通过合理设计哈希函数和冲突解决策略,可以确保系统稳定运行,为企业提供有力的安全保障。
|
2月前
|
机器学习/深度学习 自然语言处理 监控
智能客服系统集成技术解析和价值点梳理
在 2024 年的智能客服系统领域,合力亿捷等服务商凭借其卓越的技术实力引领潮流,它们均积极应用最新的大模型技术,推动智能客服的进步。
153 7
|
2月前
|
安全 前端开发 Android开发
探索移动应用与系统:从开发到操作系统的深度解析
在数字化时代的浪潮中,移动应用和操作系统成为了我们日常生活的重要组成部分。本文将深入探讨移动应用的开发流程、关键技术和最佳实践,同时分析移动操作系统的核心功能、架构和安全性。通过实际案例和代码示例,我们将揭示如何构建高效、安全且用户友好的移动应用,并理解不同操作系统之间的差异及其对应用开发的影响。无论你是开发者还是对移动技术感兴趣的读者,这篇文章都将为你提供宝贵的见解和知识。

热门文章

最新文章

推荐镜像

更多