问题一:
每个公司都有部门树结构,但是大公司的部门树每年可能会发生调整;
一般开发中我们都是直接根据部门ID去查询或者过滤数据或者做权限管控;
部门调整以后,可能就会查询不到数据或者过滤数据出问题;
如何解决:每年调整的部门ID和原来的部门ID做映射关系(Map),如若传变更后的部门ID,就通过映射出的原部门和新部门(多个ID)传List,去查询或过滤数据;
问题二:
项目类型:审批流程项目
项目数据流程:前端通过调用Camunda流程引擎传递表单入参,同时Camunda流程引擎会针对该单据产生一条流程ID,
前端再将流程ID传递给后端,后端通过流程ID(Feign接口)调用Camunda获取数据,获取的是一个json数据,该json包含了所有节点的数据;
后端每次只获取当前这个节点处理后的数据入库保存,通过数据处理,将结果返回给前端进行界面展示;
问题:发现每次发包的时候,如果有人在使用环境,就会发生一个异常场景,前端界面已经提交了数据,但是流程走不到下一个节点,
通过定位发现,这种异常场景的时候,后端获取的json数据,最后一条数据是空的,即前端提交正常,Camunda产生的数据也是正常的,
但是后端获取的数据就是少一条,继续定位发现是发版本的时候,如果有人使用,这个时候,token会过期,后端拿着过期的token当然获取不到数据;
解决办法:因为该异常场景比较少,且人为可控制,所以,给管理员单独做了一个数据同步的接口,通过流程ID对应的单号,直接同步数据,做数据全量刷新;
原理:通过流程ID删除流程表中的旧数据,通过流程ID重新调用Camunda获取json数据,将所有节点数据入库保存;