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

相关文章

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

mysql5.7.15winx64配置全过程

《mysql5.7.15winx64配置全过程》文章详细介绍了MySQL5.7.15免安装版的配置步骤,包括解压安装包、设置环境变量、修改配置文件、初始化数据目录、安装服务、启动数据库、登录及密码修改... 目录前言一、首先下载安装包二、安android装步骤1.第一步解压文件2.配置环境变量3.复制my-

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

Conda国内镜像源及配置过程

《Conda国内镜像源及配置过程》文章介绍Conda镜像源使用方法,涵盖临时指定单个/多个源、永久配置及恢复默认设置,同时说明main(官方稳定)、free(逐渐弃用)、conda-forge(社区更... 目录一、Conda国内镜像源二、Conda临时使用镜像源指定单个源临时指定多个源创建环境时临时指定源

MySQL配置多主复制的实现步骤

《MySQL配置多主复制的实现步骤》多主复制是一种允许多个MySQL服务器同时接受写操作的复制方式,本文就来介绍一下MySQL配置多主复制的实现步骤,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 环境准备2. 配置每台服务器2.1 修改每台服务器的配置文件3. 安装和配置插件4. 启动组复制4.

通过配置nginx访问服务器静态资源的过程

《通过配置nginx访问服务器静态资源的过程》文章介绍了图片存储路径设置、Nginx服务器配置及通过http://192.168.206.170:8007/a.png访问图片的方法,涵盖图片管理与服务... 目录1.图片存储路径2.nginx配置3.访问图片方式总结1.图片存储路径2.nginx配置

nginx配置错误日志的实现步骤

《nginx配置错误日志的实现步骤》配置nginx代理过程中,如果出现错误,需要看日志,可以把nginx日志配置出来,以便快速定位日志问题,下面就来介绍一下nginx配置错误日志的实现步骤,感兴趣的可... 目录前言nginx配置错误日志总结前言在配置nginx代理过程中,如果出现错误,需要看日志,可以把