nhmicro微服务框架开发技术说明

2024-03-29 09:32

本文主要是介绍nhmicro微服务框架开发技术说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


框架描述
封装统一的dao层(micro-db),业务逻辑在groovy中实现。
groovy脚本放置在groovy路径下,启动时自动加载。修改时自动热部署提高调试效率。
通过复用MicroMvcTemplate和MicroServiceTemplate,降低代码量提高开发效率。
采用NhEsbServiceServlet作为controller的,调用MicroMvcTemplate子类groovy脚本。
采用springmvc作为controller的,调用MicroServiceTemplate子类groovy脚本。
Java调用groovy或groovy间调用,使用GroovyExecUtil.execGroovyRetObj(groovy文件名,方法名,…)


1,
MicroMvcTemplate封装方法有
a,分页查询 getInfoList4Page
b,插入新记录 createInfo
c,更新记录updateInfo
d,删除记录delInfo
e,根据id查询记录getInfoById
f,不分页查询记录getInfoListAll


2,
MicroServiceTemplate封装方法有
a,分页查询getInfoList4PageService
b,创建记录createInfoService
c,更新记录updateInfoService
e,删除记录delInfoService
f,使用占位符拼装sql sqlTemplateService
还有其他重载方法可直接根据sql进行增删改查,分页操作。


3,通过MicroMvcTemplate和MicroServiceTemplate与数据库交互,输入输出map中的value都是string类型


4、不使用封装好模板,直接执行查询sql的方法是,
List infoList=(MicroMetaDao.getInstance()).queryObjJoinByCondition(sql);
或调用?占位的sql
public List<Map<String, Object>> queryObjJoinByCondition(String sql,Object[] paramArray)


直接写sql进行更新操作  int status=(MicroMetaDao.getInstance()).updateObjByCondition(sql)
或调用?占位的sql
updateObjByCondition(sql,paramArray)


MicroMetaDao()底层是jdbctemplate,有特别复杂的操作时可调用getMicroJdbcTemplate() 获取MicroMetaDao底层jdbctemplate


5、根据物理uuid查一条记录的封装
(microdb2.0以后版本支持表的id字段和bizid字段为数字)
在service层可使用
public Map getInfoByIdService(Map requestParamMap,String tableName)
public Map getInfoByIdService(String id,String tableName)


在dao层可使用queryObjJoinById
Map retMap=(MicroMetaDao.getInstance()).queryObjJoinById(tableName, id);


6、根据业务bizid查一条记录的封装
在service层可使用
public Map getInfoByBizIdService(String bizId,String tableName,String bizCol)


在dao层可以使用
Map rowMap=(MicroMetaDao.getInstance()).queryObjJoinByBizId("cms_template_list", bizid值,bizid在表中的列名称);


7、使用groovy mvc和service模板时,传入的map参数和返回的结果map的value都是string类型的
比如requestParamMap.put("update_time",DateTimeUtil.getNowStrTime());
日期字段,insert或update时,可以用"now()"小写的。如requestParamMap.put("update_time","now()");


8、groovy中获取springbean或全局变量
在groovy中调用获取springbean,  MicroContextHolder.getContext().getBean("xxxx springbeanid");
在groovy中获取配置的全局变量,MicroContextHolder.getContextMap().get("xxxx key");
MicroContextHolder需要在xml中配置,map中可以配置其他的全局变量
<bean class="com.minxin.micro.rule.engine.context.MicroContextHolder" lazy-init="false">
<property name="contextMap">
<map>


</map>
</property>
</bean> 


9、关于事务配置
microdb内部使用jdbctemplate,也使用spring事务进行配置
如果controller层使用springmvc,建议在controller层配置事务
如果使用NhEsbServiceServlet作为controller层如下配置在WsGroovyCmdHandler中开启事务
        <!--micro 声明式事物管理,配置事物管理advice-->
    <tx:advice id="txAdviceMicro" transaction-manager="txManager">
        <tx:attributes>
            <tx:method name="execHandler" propagation="REQUIRED"/>
        </tx:attributes>
    </tx:advice>


    <!--micro 配置事物管理advice作用范围与作用条件-->
    <aop:config>
        <aop:pointcut id="serviceLayerTransactionMicro" expression="execution( * com.project.frame.handler.*..*(..))"/>
        <aop:advisor pointcut-ref="serviceLayerTransactionMicro" advice-ref="txAdviceMicro"/>
    </aop:config>






或使用MicroServiceTemplateSupport中的execGroovyRetObjByDbTran方法。


groovy中遇到需要局部使用特殊事务控制时,使用显示编程事务实现。
TransactionTemplate transactionTemplate = (TransactionTemplate) MicroDbHolder.getDbSource("default_transaction");
transactionTemplate.execute(new TransactionCallback() {
@Override
public Object doInTransaction(TransactionStatus status) {
xxxx
}


});


10,支持like查询
将key从requestParamMap删除,拼装自定义where条件,调用service模板的方法
public Map getInfoList4PageService(Map requestParamMap,String tableName,Map pageMap,String cusWhere)
例如:
Map requestParamMap=getRequestParamMap(httpRequest);
String noticeNameValue=requestParamMap.get("dbcol_ext_notice_name");
requestParamMap.remove("dbcol_ext_notice_name");
String cusWhere="";
if(noticeNameValue!=null && !"".equals(noticeNameValue)){
cusWhere="meta_content->>'\$.dbcol_ext_notice_name' like '%"+noticeNameValue+"%'";
}
Map pageMap=new HashMap();
pageMap.put("page", page);
pageMap.put("rows", rows);
pageMap.put("sort", sort);
pageMap.put("order", order);
Map retMap=GroovyExecUtil.execGroovyRetObj("MicroServiceTemplate", "getInfoList4PageService",requestParamMap, tableName,pageMap,cusWhere);




11、如果使用了NhEsbServiceServlet作为controller层,groovy中返回自定义httpResponse时,
需要设置httpRequest.setAttribute("forwardFlag", "true");否则可能追加多余字段返回。
HttpServletResponse httpResponse = gContextParam.getContextMap().get("httpResponse");
httpResponse.getOutputStream().write(retStr.getBytes("UTF-8"));

httpRequest.setAttribute("forwardFlag", "true");


12、增改查时都可以输入部分自定义sql
查询时(分页,不分页)
tableName可输入join连接字符串连接多个表
cusWhere可输入自定义的where条件sql串(可以和原功能叠加)
cusSelect可输入自定义select字符串
public  Map getInfoList4PageService(Map requestParamMap,String tableName,Map pageMap,String cusWhere,String cusSelect) 
public List getInfoListAllService(Map requestParamMap,String tableName,Map sortMap,String cusWhere,String cusSelect)
例如getInfoList4PageService(Map requestParamMap,"t_account a left join t_user u on a.user_code=u.user_code",Map pageMap,String cusWhere,"a.*,u.user_name")




插入时
cusCol可输入自定义的列字符串(可以和原功能叠加)
cusValue可输入自定义value字符串(可以和原功能叠加)
public Integer createInfoService(Map requestParamMap,String tableName,String cusCol,String cusValue) 
例如插入时记录数据库时间createInfoService(requestParamMap, tableName,"create_time","now()") 


更新时
cusCondition可输入自定义where条件sql串(可以和原功能叠加)
cusSetStr可输入自定义set字符串(可以和原功能叠加)
public Integer updateInfoService(Map requestParamMap,String tableName,String cusCondition,String cusSetStr)
例如更新时记录数据库时间updateInfoService(requestParamMap, tableName,cusCondition,"update_time=now()") 




13,MicroServiceTemplate中添加sqlTemplateService方法,用于做sql替换
替换的语法是velocity
判断是否为null #if(\${param.p1})
判断是否为"" #if(\${param.p1}!='')
判断不为null且不为"" #if(\$!{param.p1}!='')
例如以下的代码
Map paramMap=new HashMap();
paramMap.put("p1", "1");
paramMap.put("p2", "2");
paramMap.put("p3", "3");
paramMap.put("p4", "4");
paramMap.put("p5", "5");
String sql=
"select * from aaa where 1=1"+
"#if(\${param.p1})"+
" and c1='\${param.p2}'   "+
"#end"+
"#if(\${param.p2})"+
" and c2= #sqlreplace(\${param.p2}) "+
"#end"+
"#if(\${param.p3})"+
" and c3 like '%\${param.p3}%' "+
"#end"
;


List placeList=new ArrayList();
String retStr=sqlTemplateService(sql,paramMap,placeList);
System.out.println(retStr);
System.out.println(placeList);


返回如下的sql替换结果
select * from aaa where 1=1 and c1=1  true  and c2=? true and c3 like '%3%' true 
[2]


14,MicroServiceTemplate中生成序列号
public Integer getSeqByMysql(String seqKey)




15,MicroServiceTemplate中直接根据查询sql分页
不必拼装count查询sql
public Map getInfoList4PageServiceByMySql(String sql,Map pageMap) 



这篇关于nhmicro微服务框架开发技术说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

Spring Boot Actuator使用说明

《SpringBootActuator使用说明》SpringBootActuator是一个用于监控和管理SpringBoot应用程序的强大工具,通过引入依赖并配置,可以启用默认的监控接口,... 目录项目里引入下面这个依赖使用场景总结说明:本文介绍Spring Boot Actuator的使用,关于Spri

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas