NCC业务和通知消息配置

2023-10-16 06:30
文章标签 配置 业务 消息 通知 ncc

本文主要是介绍NCC业务和通知消息配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

NCC业务和通知消息配置

·目录

  • NCC业务和通知消息配置
    • 业务和通知类消息
      • 1、注册消息类型
      • 2、注册消息模板
      • 3、注册业务消息配置信息
      • 4、代码实现
      • 5、业务函数字段的设置
      • 6、消息设置已读/未读和删除
        • 方法1:用平台封装好的接口
          • 代码处理
          • 定位消息
        • 方法2:直接调用底层接口
          • 代码处理
          • 参数解释
      • 7、业务消息发送与页面跳转原理
        • 消息发送原理
        • 消息跳转原理
          • 通知消息的跳转
          • 业务消息的跳转

业务和通知类消息

以任务分配为例

1、注册消息类型

  • 打开“动态建模平台->开发配置->消息管理->消息模板类型注册”,在业务消息的企业报表模块下新建一个消息模板分类
    在这里插入图片描述
  • 这里预置了两个业务函数字段,这里的字段是靠系统预置和元数据字段无法满足消息内容配置的时候,需要通过新增的这个自定义变量去实现。如果没有需求的话可不预置

2、注册消息模板

  • 新建好了之后在“动态建模平台->客户化配置->同一沟通平台->消息模板-全局”中就能看到上一步建好的分类,然后在对应分类下新建一个消息模板
    在这里插入图片描述
  • 可以看到右侧有三个页签,系统变量是平台预置好的,不需要关心,元数据和业务函数是我们预置的,具体实现参考第5步。

3、注册业务消息配置信息

  • 设置好模板之后,打开“动态建模平台->客户化配置->同一沟通平台->业务消息配置”节点
    在这里插入图片描述
  • 左树是不能新增的,这里需要我们自己去写SQL插入,我这里的插入SQL如下:
insert into pub_msgres_reg (CODE, CREATIONTIME, CREATOR, DR, FOLDERNAME, INNERCODE, METAID, MODIFIEDTIME, MODIFIER, MODULEID, MSGTEMPTYPE_CODE, NAME, PK_BILLTYPECODE, PK_MSGRES_REG, RESID, TS) values ('ufoe_taskassign', null, '~', 0, '', null, '766e7c90-2de7-415a-8d3f-4c690721aa2f', null, '~', '1820', 'TASKASSIGN', '任务分配', 'UFOE', '1001ZE10000000000001', '', '2020-11-14 17:25:24');
  • 其中“MSGTEMPTYPE_CODE”字段是第1步里面新建的那个分类的编码,我这里是“TASKASSIGN”
    在这里插入图片描述
  • 数据插入之后就可以在“业务消息配置”左边树里看到数据了
  • 然后配置好消息模板和消息接收人,然后就可以开始编写代码了
    在这里插入图片描述

4、代码实现

注:代码可参考nccloud.ufoepub.msg.utils.UfoeBuziMsgUtils类

/*** 发送NCC消息-任务分配* * @param taskAssignVO* @param sender        消息发送人* @param pk_group      集团主键* @return* @throws BusinessException*/
public static void sendNCCMessage(TaskAssignVO taskAssignVO, String sender, String pk_group) throws BusinessException {UfoeBuziMsgDTO dto = new UfoeBuziMsgDTO();// 构造消息体dto.setSender(sender);// 消息发送时间取当前时间dto.setSendtime(new UFDateTime());// 发送通知消息dto.setMsgsourcetype(UfoeMsgConsts.MSG_TYPE_NOTICE);dto.setPk_group(pk_group);dto.setPk_org(taskAssignVO.getPk_receiveorg());//设置跳转单据传递的参数dto.setParam("pk_org=" + taskAssignVO.getPk_receiveorg());// 设置应用编码,用于跳转dto.setAppcode(UfoeMsgConsts.APPCODE_RECEIVETASK);// 设置消息类型dto.setMsgType(UfoeMsgConsts.MSG_TYPE_NOTICE);//设置单据主键(用于消息状态设置时定位该消息)dto.setBillid(taskAssignVO.getPk_taskassign());// 构造消息配置信息dto.setMsgrescode(UfoeMsgConsts.MSG_CONFIG_TASKASSIGN);// 设置接收的组织dto.setPkorgs(new String[] { taskAssignVO.getPk_receiveorg() });// 给元数据字段赋值dto.setBillVO(taskAssignVO);// 给业务函数字段赋值dto.setCalculater(new TaskAssignBusiVarCalculater(taskAssignVO));UfoeBuziMsgUtils.sendBuziMsgReturnReceiver(dto);
}

其中有一个params字段,可以设置用户自定义的参数,用于页面跳转时的传参。以“key=value”的形式传递,多个参数之间用“&”隔开。不过要注意的是,如果发送的是业务消息,需要在前面加一个“?”

5、业务函数字段的设置

  • 业务函数是消息配置时,系统预置字段和元数据字段无法满足消息模板配置的需求时,需要预置额外的字段去实现
  • 业务函数字段需要实现nc.message.templet.bs.IMsgVarCalculater接口或者继承平台的nc.message.templet.bs.AbstractBusiVarCalculater类,里面对业务函数字段值进行解析并赋值,详情请参考: nccloud.ufoepub.msg.calculater.TaskAssignBusiVarCalculater
/*** 翻译任务分配中的业务函数字段* @author youjw11**/
public class TaskAssignBusiVarCalculater extends AbstractBusiVarCalculater {//个性化规则private static final String PERSONALRULE = "personalRule";//任务所属节点类型private static final String TASKNODETYPE = "taskNodeType";Map<String, String> varMap = new HashMap<String, String>();public TaskAssignBusiVarCalculater(TaskAssignVO taskAssignVO) {StringBuffer personalRule = new StringBuffer();if (taskAssignVO.getFlag_reassign().booleanValue() == true) {personalRule.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("1820001_0","01820001-1059")/*@res "接收组织可再分配、"*/);}else {personalRule.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("1820001_0","01820001-1060")/*@res "接收组织不可再分配、"*/);}if (taskAssignVO.getFlag_privfml().booleanValue() == true) {personalRule.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("1820001_0","01820001-1061")/*@res "可进行个性化公式设置、"*/);}else {personalRule.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("1820001_0","01820001-1062")/*@res "不可进行个性化公式设置、"*/);}if (taskAssignVO.getFlag_privprint().booleanValue() == true) {personalRule.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("1820001_0","01820001-1063")/*@res "可进行个性化打印设置"*/);}else {personalRule.append(nc.vo.ml.NCLangRes4VoTransl.getNCLangRes().getStrByID("1820001_0","01820001-1064")/*@res "不可进行个性化打印设置"*/);}String sendOrgName = OrgUtil.getOrgName(taskAssignVO.getPk_assignorg());//设置个性化规则的值varMap.put(PERSONALRULE, personalRule.toString());//设置任务所属节点类型varMap.put(TASKNODETYPE, sendOrgName);}@Overridepublic String calculateValue(String express) {if (varMap.containsKey(express)) {if (StringUtils.isEmpty(express)) {return "";}else {return varMap.get(express);}}return "";}public Map<String, String> getVarMap() {return varMap;}public void setVarMap(Map<String, String> varMap) {this.varMap = varMap;}
}

6、消息设置已读/未读和删除

7、业务消息发送与页面跳转原理

消息发送原理
  • 消息发送无非就是构造 nccloud.message.vo.NCCMessage ,这个类里面含有消息的所有数据,包括消息内容、发送方信息、接收方信息等所有信息
  • 但是业务消息内容和接收方都是通过读取“业务消息配置”节点来实现的,这个时候就需要用到 nc.buzimsg.vo.BuziMsgSendingContext 。通过设置它的信息来匹配配置信息,从而取出消息模板配置的内容。元数据和业务函数的值就是通过这个类里面的billVO和calculater两个字段来赋值的
    在这里插入图片描述
  • 通过调用平台消息发送接口 nccloud.buzimsg.itf.IBuziMsgSending 来发送消息,我们只需要设置好上面两个类相应的值,就能匹配到相应的配置信息,从而进行消息的发送。
消息跳转原理
  • 消息跳转的话在 nccloud.message.vo.NCCMessage 的成员变量 nccloud.message.vo.NCCMessageVO 类中可设置消息体的跳转信息
通知消息的跳转
  • 我们先来看看前端代码
    在这里插入图片描述

  • 当消息体里面传了应用编码,但是没传单据类型的时候,可直接跳转到对应的小应用,并将一些配置信息拼接进去。
    在这里插入图片描述

  • 也可以在detail字段中拼接“PURL”,如果这个里面指定了跳转信息,则直接跳过去,否则就按设置的单据类型跳转。

  • 现在我们来看后端代码
    在这里插入图片描述

  • 结合前后端代码,总结一下detail字段的格式为:

    单据主键@单据类型编码@单据号@appcode@PURL=appcode=应用编码&pagecode=页面编码

    • 数据不一定要全,但是格式得按这个来
业务消息的跳转
  • 前端代码:
    在这里插入图片描述
  • 先会判断传入的params中是否有“|”字符,有就代表需要选择打开的交易类型,会弹一个框,选择需要跳转的交易类型
    如果没有该字符则直接按传入的信息跳转
    在这里插入图片描述
    前端代码中的this.state.message对应的就是后端代码中的NCCMessage里的NCCMessageVO里面的信息,具体开发过程需要传递字段的话可参考前端代码拼接的字段去设置想要的值

这篇关于NCC业务和通知消息配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/219683

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

业务协同平台--简介

一、使用场景         1.多个系统统一在业务协同平台定义协同策略,由业务协同平台代替人工完成一系列的单据录入         2.同时业务协同平台将执行任务推送给pda、pad等执行终端,通知各人员、设备进行作业执行         3.作业过程中,可设置完成时间预警、作业节点通知,时刻了解作业进程         4.做完再给你做过程分析,给出优化建议         就问你这一套下

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

log4j2相关配置说明以及${sys:catalina.home}应用

${sys:catalina.home} 等价于 System.getProperty("catalina.home") 就是Tomcat的根目录:  C:\apache-tomcat-7.0.77 <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" /> 2017-08-10