`
zhangym195
  • 浏览: 124257 次
  • 性别: Icon_minigender_1
  • 来自: 黑龙江
社区版块
存档分类
最新评论

jBPM jPDL 用户开发手册 3.2.3 - 第17章

阅读更多

17 邮件支持

本章描述了jBPM jPDL中随包发行的邮件支持。

17.1. jPDL中的邮件

从流程中发送邮件有四种指定的方式。

17.1.1. 邮件动作

邮件动作能够用来发送邮件而不是在流程图中显示一个节点。

允许你在在流程的任何地方来指定动作,你可以像这样指定一个邮件动作:

<mail actors="#{president}" subject="readmylips" text="nomoretaxes" />

Subjecttext属性也能作为一个元素来指定,像这样:

<mail actors="#{president}" >

  <subject>readmylips</subject>

  <text>nomoretaxes</text>

</mail>

每个域都可以包含JSF那样的表达式。例如:

<mail to='#{initiator}' subject='websale' text='your websale of #{quantity} #{item} was approved' />

更多的关于表达式的信息,查看21.3 表达式部分

有两个属性用来指定收集人:actorstoto属性应该解析成一个分号分隔的邮件地址列表。actors属性应该解析成一个分号分隔的actorId的列表。那些actorId将使用地址解析来解析成邮件地址。

<mail to='admin@mycompany.com' subject='urgent' text='the mailserver is down :-)' />

更多的关于如何指定收件人的信息,查看17.3 指定收件人部分

邮件可以定义成模板而且在流程中你可以重写模板的属性,如:

<mail template='sillystatement' actors="#{president}" />

更多的关于模板的信息,查看17.4 邮件模板部分

17.1.2. 邮件节点

就跟邮件动作(mail actions)一样,邮件发送也能被建模成节点。那样的话,运行时行为是相同的,但是邮件将在流程图中显示成一个节点。

邮件节点所支持的属性和元素同邮件动作完全相同。

<mail-node name="send email" to="#{president}" subject="readmylips" text="nomoretaxes">

  <transition to="the next node" />

</mail-node>

邮件节点完全应该有一个离开转换。

17.1.3. 任务分派邮件

当任务获得被分配的参与者时通知邮件能够发送。在一个任务上使用notify="yes"属性,如:

<task-node name='a'>

  <task name='laundry' swimlane="grandma" notify='yes' />

  <transition to='b' />

</task-node>

设置notifyyestrueon将导致jBPM给分配到任务上的参与者发送邮件。邮件是基于模板(查看17.4 邮件模板部分)并且包含一个到web应用的任务页面的链接。

17.1.4. 任务提醒邮件

同使用分派(assignments)一样,邮件(emails)能够作为任务提醒被发送。jPDL 中的reminder元素基于定时器。最常用的属性是duedaterepeat。唯一的不同是没有动作(action)指定。

<task-node name='a'>

  <task name='laundry' swimlane="grandma" notify='yes'>

    <reminder duedate="2 business days" repeat="2 business hours"/>

  </task>

  <transition to='b' />

</task-node>

 

17.2. 邮件表达式

torecipientssubjecttext能够被包含像JSF的表达式。更多的关于表达式的信息,查看21.3表达式部分。

表达式中的变量:swimlanes process变量、transient变量beans被配置jbpm.cfg.xml中。

这些表达式能够同本章后面解释的地址解析进行组合。例如:假设在你的流程中有一个swimlanepresident,然后看下面的邮件规范:

<mail actors="#{president}" subject="readmylips" text="nomoretaxes" />

那将为特定的流程执行发送邮件到扮演president的那个人。

17.3. 指定收件人

17.3.1. 多个收件人

actorsto域中,多个收件人可以使用分号(;)或冒号(:)来进行分隔。

17.3.2. 密送邮件

有时除正常的收件人外你还想发送邮件到一个BCC目标。当前,有两个支持的方法:第一你可以在流程定义中指定一个bccActorsbcc属性(根据actorsto)。

<mail to='#{initiator}' bcc='bcc@mycompany.com' subject='websale' text='your websale of #{quantity} #{item} was approved' />

第二个方法是总是发送一个BCC邮件到你在中心配置(jbpm.cfg.xml)中的一个属性中配置的某个位置上:

<jbpm-configuration>

  ...

  <string name="jbpm.mail.bcc.address" value="bcc@mycompany.com" />

</jbpm-configuration>

 

17.3.3. 地址解析

在所有的jBPM中,actorsactorId's引用。这是一个作为流程参与人标识符的字符串。一个地址解析翻译actorId's成为邮件地址。

如果你想应用地址解析使用属性actors而如果你要直接指定邮件地址而不想应用地址解析使用属性to

一个地址解析器应该实现下列的接口:

public interface AddressResolver extends Serializable {

  Object resolveAddress(String actorId);

}

一个地址解析器应该返回3个类型中的1个:字符串(String)、字符串集合(Collection of String)或字符串数组(array of String)。

所有字符串应该为给定的 actorId代表邮件地址。

地址解析器实现应该是使用名字jbpm.mail.address.resolver配置在jbpm.cfg.xml中的bean。如:

<jbpm-configuration>

  ...

  <bean name='jbpm.mail.address.resolver' class='org.jbpm.identity.mail.IdentityAddressResolver' singleton='true' />

</jbpm-configuration>

 

jBPM的身份构件包括一个地址解析器。那个地址解析器将查找给定actorIdUser。如果用户存在,那个用户的邮件被返回,否则为null。更多关于身份构件信息能够在12.11 身份构件中找到。

17.4. 邮件模板

代替在processdefinition.xml中指定邮件,邮件能够指定模板文件中。当一个模板被使用时,processdefinition.xml文件中的每个域仍然能够被覆盖。邮件模板应该在XML文件中像这样来指定:

<mail-templates>

 

  <variable name="BaseTaskListURL" value="http://localhost:8080/jbpm/task?id=" />

 

  <mail-template name='task-assign'>

    <actors>#{taskInstance.actorId}</actors>

    <subject>Task '#{taskInstance.name}'</subject>

    <text><![CDATA[Hi,

Task '#{taskInstance.name}' has been assigned to you.

Go for it: #{BaseTaskListURL}#{taskInstance.id}

Thanks.

---powered by JBoss jBPM---]]></text>

  </mail-template>

 

  <mail-template name='task-reminder'>

    <actors>#{taskInstance.actorId}</actors>

    <subject>Task '#{taskInstance.name}' !</subject>

    <text><![CDATA[Hey,

Don't forget about #{BaseTaskListURL}#{taskInstance.id}

Get going !

---powered by JBoss jBPM---]]></text>

  </mail-template>

 

</mail-templates>

像你在这个例子(BaseTaskListURL)中看到的一样,extra变量能够定义在邮件模板中,它在表达式中是有效的。

包含模板的资源应该在jbpm.cfg.xml中像这样进行配置:

<jbpm-configuration>

  ...

  <string name="resource.mail.templates" value="jbpm.mail.templates.xml" />

</jbpm-configuration>

17.5. 邮件服务器配置

最简单的配置邮件服务器的方法在jbpm.cfg.xml文件中使用jbpm.mail.smtp.host这个配置属性,如:

<jbpm-configuration>

  ...

  <string name="jbpm.mail.smtp.host" value="localhost" />

</jbpm-configuration>

作为选择,当更多的属性需要被指定时,应该用关键字' resource.mail.properties '给定资源引用的属性文件,如:

<jbpm-configuration>

  ...

  <string name='resource.mail.properties' value='jbpm.mail.properties' />

</jbpm-configuration>

17.6. From地址配置

jPDL邮件中From地址的缺省值使用的是jbpm@noreply。邮件的from地址可以在jBPM的配置文件jbpm.xfg.xml中使用关键字'jbpm.mail.from.address'来配置,如:

<jbpm-configuration>

  ...

  <string name='jbpm.mail.from.address' value='jbpm@yourcompany.com' />

</jbpm-configuration>

17.7. 自定义邮件支持

jBPM中所有的邮件支持是以一个类为中央的:org.jbpm.mail.Mail,这是一个ActionHandler实现。无论何时邮件在流程xml中指定,都将代理到邮件类。它可能继承自Mail类然后再为你的特殊需求定制某些功能。为了配置你的类使用邮件代理,在jbpm.cfg.xml文件中像这样来指定'jbpm.mail.class.name'配置字符串:

<jbpm-configuration>

  ...

  <string name='jbpm.mail.class.name' value='com.your.specific.CustomMail' />

</jbpm-configuration>

 定制的mail类在解析期间被读取并且动作将在引用配置了(或缺省的)邮件类名的流程中被配置。所以如果你改变这个属性,所有已经部署的流程将仍然引用旧的邮件名。但他们将能够通过使用一条简单的update语句很容易地被更新到jbpm数据库。

17.8. 邮件服务器

如果你需要一个易于安装的邮件服务器,那么就检出JBossMail Server Apache James吧。

 

:-s

分享到:
评论

相关推荐

    jbpm-jpdl-suite-3.2.3.zip

    jbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3.zipjbpm-jpdl-suite-3.2.3....

    jbpm-jpdl-suite-3.2.3安装配置.doc

    - 修改jbpm-jpdl-3.2.3\db目录下的jbpm.jpdl.mysql.sql文件,为每个SQL语句末尾添加分号,以便正确执行脚本。 4. **jbpm-jpdl-suite-3.2.3部署**: - 在MySQL中执行修改后的jbpm.jpdl.mysql.sql脚本,初始化jbpm...

    jbpm-jpdl-suite-3.2.3的安装配置

    - **docs**目录:包含文档和手册,用于指导用户安装、配置和使用jBPM-jPDL。 - **samples**目录:提供了一些示例项目,帮助用户了解如何使用jBPM-jPDL实现具体业务流程。 安装配置jBPM-jPDL-suite-3.2.3通常涉及...

    JBoss_jBPM_jPDL用户开发手册_3.2.3.pdf 中文-(转)zhangym

    《JBoss_jBPM_jPDL用户开发手册_3.2.3.pdf》作为开发者的重要参考资料,详细介绍了如何使用jBPM和jPDL进行流程开发。手册内容可能涵盖: - **安装与配置**:指导读者设置开发环境,包括JBoss服务器的部署和jBPM的...

    jbpm-jpdl-3.2.3.zip

    jbpm-jpdl-3.2.3.zip 是一个包含开源工作流引擎jbpm的版本3.2.3的压缩包。jbpm(Java Business Process Management)是一个强大的业务流程管理系统,它提供了完整的业务流程建模、执行和管理能力,特别适合于需要...

    jbpm-jpdl-3.2.3(server部分).rar

    这个是jbpm-jpdl-3.2.3.zip的server部分,有60多兆, 只要将"jbpm-jpdl-3.2.3(没有server部分).rar"和这个合在一起就是整个的jbpm-jpdl-3.2.3.zip "jbpm-jpdl-3.2.3(没有server部分).rar"在我的另外一个上传资源里面

    jbpm-jpdl-suite-3.2.GA.zip-6

    jbpm-jpdl-suite-3.2.GA.zip

    JBoss+jBPM+jPDL用户开发手册_3.2.3

    《JBoss+jBPM+jPDL用户开发手册_3.2.3》是针对企业级应用开发的一个详尽指南,特别关注于工作流管理和流程自动化。这个手册详细介绍了如何使用JBoss中间件平台,结合jBPM(Java Business Process Management)和jPDL...

    jBPM jPDL 用户指南 (Version 3.2.3) - 第2章

    **jbPM jPDL 用户指南 (Version 3.2.3) - 第2章** jbPM(Java Business Process Management)是一种开源的工作流管理系统,专为Java开发者设计,它提供了业务流程建模、执行和监控的功能。jPDL(jBPM Process ...

    工作流框架JBoss+jBPM+jPDL用户开发手册

    6. JBoss+jBPM+jPDL用户开发手册_3.2.3.pdf:这可能是jBPM 3.2.3版本的官方用户手册,提供了该版本的详细技术指南和最佳实践。内容可能包括API使用、工作流生命周期管理、持久化机制、错误处理、自定义扩展等关键...

    JBPM-3.2.2

    5. **文档和示例**:为了帮助开发者更好地理解和使用JBPM,通常会提供详细的用户手册和示例代码,指导如何配置、部署以及编程接口的使用。 6. **测试和调试工具**:可能包含了一些辅助工具,如命令行工具或调试器,...

    jbpm-jpdl-3.2.3(没有server部分)

    这个是jbpm-jpdl-3.2.3的zip,本来这个是85M的zip, 我删除了server 文件夹(这个文件夹有60多M) 这个server部分在我的另外一个资源里面,一般开发用不到这个server文件夹 如果需要的话,就下载不需要积分, 这个没有...

    jbpm-jpdl  

    jbpm-jpdl-3.2.3

    工作流插件 jbpm activiti

    工作流插件 activiti-5.15.1 jbpm-4.3 jbpm-4.4 jbpm-jpdl-suite-3.2.3

    jBPM开发:配置EclipseIDE开发环境参考.pdf

    ### jBPM开发:配置EclipseIDE开发环境详解 #### 一、配置开发工具 **1. 安装 Eclipse Designer到 Myeclipse6** - **步骤**: - 将`jbpm-jpdl-suite-3.2.3/designer/eclipse/plugins`目录下的所有文件及文件夹...

    jBPM工作流应用

    首先从网站上下载jBPM开发包(jbpm-jpdl-suite-3.2.3.zip),据说现在jBPM3已经升到3.2.6了,而且据说已经推出了jBPM4了。将jbpm-jpdl-suite-3.2.3.zip解压缩后,里面有个\designer文件夹,这个是eclipseIDE的jBPM...

Global site tag (gtag.js) - Google Analytics