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

相关文章

SpringBoot中HTTP连接池的配置与优化

《SpringBoot中HTTP连接池的配置与优化》这篇文章主要为大家详细介绍了SpringBoot中HTTP连接池的配置与优化的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、HTTP连接池的核心价值二、Spring Boot集成方案方案1:Apache HttpCl

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

VSCode中配置node.js的实现示例

《VSCode中配置node.js的实现示例》本文主要介绍了VSCode中配置node.js的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一.node.js下载安装教程二.配置npm三.配置环境变量四.VSCode配置五.心得一.no

Gradle在国内配置镜像加速的实现步骤

《Gradle在国内配置镜像加速的实现步骤》在国内使用Gradle构建项目时,最大的痛点就是依赖下载贼慢,甚至卡死,下面教你如何配置国内镜像加速Gradle下载依赖,主要是通过改写repositori... 目录引言一、修改 build.gradle 或 settings.gradle 的 reposito

使用easy connect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题

《使用easyconnect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题》:本文主要介绍使用easyconnect之后,maven无法... 目录使用easGWowCy connect之后,maven无法使用,原来需要配置-DJava.net.pr

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构

史上最全nginx详细参数配置

《史上最全nginx详细参数配置》Nginx是一个轻量级高性能的HTTP和反向代理服务器,同时也是一个通用代理服务器(TCP/UDP/IMAP/POP3/SMTP),最初由俄罗斯人IgorSyso... 目录基本命令默认配置搭建站点根据文件类型设置过期时间禁止文件缓存防盗链静态文件压缩指定定错误页面跨域问题

nginx负载均衡及详细配置方法

《nginx负载均衡及详细配置方法》Nginx作为一种高效的Web服务器和反向代理服务器,广泛应用于网站的负载均衡中,:本文主要介绍nginx负载均衡及详细配置,需要的朋友可以参考下... 目录一、 nginx负载均衡策略1.1 基本负载均衡策略1.2 第三方策略1.3 策略对比二、 nginx配置2.1

一文带你搞懂Redis Stream的6种消息处理模式

《一文带你搞懂RedisStream的6种消息处理模式》Redis5.0版本引入的Stream数据类型,为Redis生态带来了强大而灵活的消息队列功能,本文将为大家详细介绍RedisStream的6... 目录1. 简单消费模式(Simple Consumption)基本概念核心命令实现示例使用场景优缺点2