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

消息盒子包含业务通知(Messages)和工作流审批(Workflow)。业务通知比如采购人员下达采购订单PO后,需要通知仓库人员准备收货。工作流审批是以审批为基础的单据流程控制。
在实现消息盒子过程中,遇到一个客户需要将消息同时发送到电子邮件系统中,于是撰此文以分享实现过程。
客户的目的很简单,发送消息的同时,也将此消息抄送到相应的邮件帐户中:

实施部分
1 搭建电子邮件服务器
有以下几种选择
1 与Outlook搭配的邮件服务器Exchange Server是一个很好的邮件服务器,只是配置稍微复杂一点。
2 Magic WinMail ,WinWebMail 免费版可发布50-100个帐户,超过此限制需要购买授权。
3 hMailServer 开源,免费,无限制。提供COM接口可供二次开发。
最终选择hMailServer作为ERP系统的邮件服务器。配置过程此处略过。
安装好hMailServer后,创建域名EnterpriseSolution.com,并启用它。

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

在这个程序中, 可以将ERP用户的邮件同步到hMailServer的帐户表中。
点击同步按钮,打开ERP帐户选择窗体,再点击确认之后,ERP中的帐户就同步到hMailServer邮件系统中。

查看hMailServer的帐户:

开发部分
下面详细讲解一下上面的同步程序是如何实现的,它是一个简单的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
解析大型.NET ERP系统 电子邮件系统帐户集成的更多相关文章
- 解析大型.NET ERP系统 十三种界面设计模式
成熟的ERP系统的界面应该都是从模板中拷贝出来的,各类功能的界面有规律可遵循.软件界面设计模式化或是艺术性的创作,我认可前者,模式化的界面客户容易举一反三,降低学习门槛.除了一些小部分的功能界面设计特 ...
- 解析大型.NET ERP系统架构设计 Framework+ Application 设计模式
我对大型系统的理解,从数量上面来讲,源代码超过百万行以上,系统有超过300个以上的功能,从质量上来讲系统应该具备良好的可扩展性和可维护性,系统中的功能紧密关联.除去业务上的复杂性,如何设计这样的一个协 ...
- 解析大型.NET ERP系统 权限模块设计与实现
权限模块是ERP系统的核心模块之一,完善的权限控制机制给系统增色不少.总结我接触过的权限模块,以享读者. 1 权限的简明定义 ERP权限管理用一句简单的话来说就是:谁 能否 做 那些 事. 文句 含义 ...
- 解析大型.NET ERP系统 设计异常处理模块
异常处理模块是大型系统必备的一个组件,精心设计的异常处理模块可提高系统的健壮性.下面从我理解的角度,谈谈异常处理的方方面面.我的设计仅仅限定于Windows Forms,供参考. 1 定义异常类型 . ...
- 解析大型.NET ERP系统 20条数据库设计规范
数据库设计规范是个技术含量相对低的话题,只需要对标准和规范的坚持即可做到.当系统越来越庞大,严格控制数据库的设计人员,并且有一份规范书供执行参考.在程序框架中,也有一份强制性的约定,当不遵守规范时报错 ...
- 解析大型.NET ERP系统 业务逻辑设计与实现
根据近几年的制造业软件开发经验,以我开发人员的理解角度,简要说明功能(Feature)是如何设计与实现的,供参考. 因架构的不同,技术实现上会有所差异,我的经验仅限定于Windows Form程序. ...
- 解析大型.NET ERP系统 数据审计功能
数据审计,英语表达是Audit,是追踪数据变化的过程,记录数据变化前后的值,供参考分析.通过设置,ERP可以追踪一个表的所有字段的变化,也可以只记录指定的字段的值变化.欧美企业每年都有独立的审计部门, ...
- 解析大型.NET ERP系统 通用附件管理功能
大型系统具备一个通用的附件管理功能,对于单据中无法清晰表达的字段,用一个附件图片或附件文档表示是最好的方法了.比如物料清单附加一张CAD图纸,销售订单评审功能中附加客户的各种表格,通用附件功能对系统起 ...
- 解析大型.NET ERP系统 高质量.NET代码设计模式
1 缓存 Cache 系统中大量的用到缓存设计模式,对系统登入之后不变的数据进行缓存,不从数据库中直接读取.耗费一些内存,相比从SQL Server中再次读取数据要划算得多.缓存的基本设计模式参考下面 ...
随机推荐
- 【.net 深呼吸】细说CodeDom(2):表达式、语句
在上一篇文章中,老周厚着脸皮给大伙介绍了代码文档的基本结构,以及一些代码对象与CodeDom类型的对应关系. 在评论中老周看到有朋友提到了 Emit,那老周就顺便提一下.严格上说,Emit并不是针对代 ...
- Android 判断一个 View 是否可见 getLocalVisibleRect(rect) 与 getGlobalVisibleRect(rect)
Android 判断一个 View 是否可见 getLocalVisibleRect(rect) 与 getGlobalVisibleRect(rect) [TOC] 这两个方法的区别 View.ge ...
- WPF 微信 MVVM 【续】发送部分QQ表情
今天主要记录的就是发送QQ表情, WPF 微信 MVVM里写了,后期为了发送QQ表情,需要把TextBox替换为RichTextBox,接下来就说说替换的过程. 一.支持Binding的RichTex ...
- Linux之搭建自己的根文件系统
Hi!大家好,我是CrazyCatJack.又和大家见面了.今天给大家带来的是构建Linux下的根文件系统.希望大家看过之后都能构建出符合自己需求的根文件系统^_^ 1.内容概述 1.构造过程 今天给 ...
- ASP.NET MVC一次删除多笔记录
批量删除数据记录,如下面的截屏: 先选中想删除的记录,然后点一下删除铵钮,系统将把选中的记录一次性删除.在此,Insus.NET不想每删除一笔记录连接一次数据库. 因此需要把选择的记录一次上传至服务器 ...
- ADO.NET一小记-select top 参数问题
异常处理汇总-后端系列 http://www.cnblogs.com/dunitian/p/4523006.html 最近使用ADO.NET的时候,发现select top @count xxxx 不 ...
- 【干货分享】流程DEMO-付款申请单
流程名: 付款申请单 业务描述: 包括每月固定开支.固定资产付款.办公用品付款.工资发放.个人所得税缴纳.营业税缴纳.公积金.社保缴纳和已签订合同的按期付款,最后是出纳付款,出纳核对发票. 流程发起 ...
- Atitit 解决Unhandled event loop exception错误的办法
Atitit 解决Unhandled event loop exception错误的办法 查看workspace/.metadata/.log org.eclipse.swt.SWTError: No ...
- 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'T_Shell' 中的标识列插入显式值。
--允许将显示值插入表的标识列中-ON:允许 OFF:不允许set identity_insert T_shell ONset identity_insert T_Shell OFF
- 在Linux虚拟机下配置jdk的环境变量
1.到Oracle公司的官网里下载好jdk,网址 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133 ...