为保证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系统 电子邮件系统帐户集成的更多相关文章

  1. 解析大型.NET ERP系统 十三种界面设计模式

    成熟的ERP系统的界面应该都是从模板中拷贝出来的,各类功能的界面有规律可遵循.软件界面设计模式化或是艺术性的创作,我认可前者,模式化的界面客户容易举一反三,降低学习门槛.除了一些小部分的功能界面设计特 ...

  2. 解析大型.NET ERP系统架构设计 Framework+ Application 设计模式

    我对大型系统的理解,从数量上面来讲,源代码超过百万行以上,系统有超过300个以上的功能,从质量上来讲系统应该具备良好的可扩展性和可维护性,系统中的功能紧密关联.除去业务上的复杂性,如何设计这样的一个协 ...

  3. 解析大型.NET ERP系统 权限模块设计与实现

    权限模块是ERP系统的核心模块之一,完善的权限控制机制给系统增色不少.总结我接触过的权限模块,以享读者. 1 权限的简明定义 ERP权限管理用一句简单的话来说就是:谁 能否 做 那些 事. 文句 含义 ...

  4. 解析大型.NET ERP系统 设计异常处理模块

    异常处理模块是大型系统必备的一个组件,精心设计的异常处理模块可提高系统的健壮性.下面从我理解的角度,谈谈异常处理的方方面面.我的设计仅仅限定于Windows Forms,供参考. 1 定义异常类型 . ...

  5. 解析大型.NET ERP系统 20条数据库设计规范

    数据库设计规范是个技术含量相对低的话题,只需要对标准和规范的坚持即可做到.当系统越来越庞大,严格控制数据库的设计人员,并且有一份规范书供执行参考.在程序框架中,也有一份强制性的约定,当不遵守规范时报错 ...

  6. 解析大型.NET ERP系统 业务逻辑设计与实现

    根据近几年的制造业软件开发经验,以我开发人员的理解角度,简要说明功能(Feature)是如何设计与实现的,供参考. 因架构的不同,技术实现上会有所差异,我的经验仅限定于Windows Form程序. ...

  7. 解析大型.NET ERP系统 数据审计功能

    数据审计,英语表达是Audit,是追踪数据变化的过程,记录数据变化前后的值,供参考分析.通过设置,ERP可以追踪一个表的所有字段的变化,也可以只记录指定的字段的值变化.欧美企业每年都有独立的审计部门, ...

  8. 解析大型.NET ERP系统 通用附件管理功能

    大型系统具备一个通用的附件管理功能,对于单据中无法清晰表达的字段,用一个附件图片或附件文档表示是最好的方法了.比如物料清单附加一张CAD图纸,销售订单评审功能中附加客户的各种表格,通用附件功能对系统起 ...

  9. 解析大型.NET ERP系统 高质量.NET代码设计模式

    1 缓存 Cache 系统中大量的用到缓存设计模式,对系统登入之后不变的数据进行缓存,不从数据库中直接读取.耗费一些内存,相比从SQL Server中再次读取数据要划算得多.缓存的基本设计模式参考下面 ...

随机推荐

  1. CSS的未来

    仅供参考 前言 完成<CSS核心技术与实战>这本书,已有一个多月了,而这篇文章原本是打算写在那本书里面的,但本章讲解的内容,毕竟属于CSS未来的范畴,而这一切都还不能够确定下来,所以这一章 ...

  2. 使用Monit监控本地进程

    目前用它监控某些服务,失败自动重启,同时监控特定的日志文件,如果有变化,就发邮件报警 安装不细写了,网上好多 我先用cat /proc/version看了下我的系统是el6的,于是wget http: ...

  3. JavaScript 对数据处理的5个API

    JavaScript对数据处理包括向上取整.向下取整.四舍五入.固定精度和固定长度5种方式,分别对应ceil,floor,round,toFixed,toPrecision等5个API,本文将对这5个 ...

  4. nodejs进阶(5)—接收请求参数

    1. get请求参数接收 我们简单举一个需要接收参数的例子 如果有个查找功能,查找关键词需要从url里接收,http://localhost:8000/search?keyword=地球.通过前面的进 ...

  5. 香蕉云APP,2016下半年开发日记

    2016-6-17  数据库设计不应该过多依赖范式,适度的冗余可以加快搜索速度,在服务器的配置还可以的情况下,可以采用冗余来解决查找慢的问题.还一个是要选择好数据库引擎,例如 InnoDB 和 myi ...

  6. 如何在Elasticsearch中安装中文分词器(IK+pinyin)

    如果直接使用Elasticsearch的朋友在处理中文内容的搜索时,肯定会遇到很尴尬的问题--中文词语被分成了一个一个的汉字,当用Kibana作图的时候,按照term来分组,结果一个汉字被分成了一组. ...

  7. NGINX引入线程池 性能提升9倍

    1. 引言 正如我们所知,NGINX采用了异步.事件驱动的方法来处理连接.这种处理方式无需(像使用传统架构的服务器一样)为每个请求创建额外的专用进程或者线程,而是在一个工作进程中处理多个连接和请求.为 ...

  8. Android中的LinearLayout布局

    LinearLayout : 线性布局 在一般情况下,当有很多控件需要在一个界面列出来时,我们就可以使用线性布局(LinearLayout)了,  线性布局是按照垂直方向(vertical)或水平方向 ...

  9. Android之网络数据存储

    一.网络保存数据介绍 可以使用网络来保存数据,在需要的时候从网络上获取数据,进而显示在App中. 用网络保存数据的方法有很多种,对于不同的网络数据采用不同的上传与获取方法. 本文利用LeanCloud ...

  10. Linux课堂笔记(一)

    一.Linux应用领域及版本介绍. 1.服务器.嵌入式.桌面应用等. (1)在服务器领域中,需要安全和稳定,特别是越老的内核版本越安全.越稳定. (2)Linux主要分内核版和发行版. 内核版本2.6 ...