‘壹’ jfinal如何捕获sql异常
在 jfinal 中,可以通过在全局拦截器中捕获 SQL 异常乱森,具体步骤如下:
1. 新建一个全局拦截器类,实现 Interceptor 接口,在其中重写 intercept() 方法。
2. 在 intercept() 方法中,通过 try-catch 块捕游旦获 SQL 异常,然后将异常信息打印出来,或者将其记录到日志中。
原因是,JFinal 是一个基于 Java 的轻量级 Web 框架,其底层使用了高效、稳定的 ORM 框架 ActiveRecord,可以方便地进行数据访问和操作。但在实际开发中,可能会出现 SQL 执行异常的情况,比如语法错误、连接超时等,需要进行相应的处理。
通过在全局拦截器中捕获 SQL 异常,可以对异常进行统一处理,从而提高代码的可维护性和稳定性。例如,可以将异常信息记录到日志中,便于开发人员快速定位和解决问题;或者向用户返回友好的错误提示,提高用哗磨亩户体验。
需要注意的是,在捕获 SQL 异常时,应该避免直接将异常信息输出到前端页面,以免给攻击者提供攻击突破口。同时,也应该避免将敏感信息记录到日志中,以免造成安全隐患。
‘贰’ 说说你为什么不用JFinal
原因有三点:
1、它没有给我带来便利, 并且找不到使用它的理由。
2、很难与其他主流框架进行整合。
3、过度封装并且使用它的同时我很难遵守代码规范。
先说说第一点, 对比spring系列, 并没有感觉它有多么便利, 创建一个Jfinal工程我需要1分钟, 创建一个Spring工程我也需要1分钟, 但是在实际开发时, Jfinal所消耗的时间会更多, 因为它不灵活。
并且代码比较啰嗦, 比如创建一个Controller, 我需要继承他的一个公共类, 并且需要在配置类里配置好它的路由, 并且需要在接口方法中使用getRequest方法。
JFinal WEB MVC和Struts简要对比:
JFinal遵循COC原则,零配置,无xml,而struts需要配置来支持action、result、interceptor配置与使用。
JFinal开发效率非常之高,相对Struts开发效率能提升五到十倍。
JFinal代码量非常省,相对Struts开发能省50%到70%代码量。
JFinal遵循Restful规范,而struts自身未提供Restful支持。Struts可以通过插件来支持restful,但支持不彻底使用不方便。
JFinal提供数据库支持,属于一站式解决方案,而struts仅为WEBMVC框架并未提供数据库支持。
JFinal学习成本极低,只需两个小时学习即可上手开发,而Struts学习成本相对较高。
JFinal相对Struts来说更加轻量级,JFinal打包jar文件仅173KB,而struts则为1.8MB。
JFinal ORM和Hibernate简要对比:
JFinal采用ActiveRecord实现数据库操作支持,较Hibernate开发效率提升六到十倍。
JFinal ActiveRecord较Hibernate学习成本低,一小时内能上手开发。
JFinal零配置,对数据库支持五个无特点:无xml、无annotation、无getter、无setter、无attribute,极大降低了代码量,统计证实代码量节省70%到95%。
JFinal数据库操作完全采用原生sql,相对Hibernate采用的HQL学习成本低,功能更强大,性能更高,稳定性好。
‘叁’ jfinal如何实现缓存持久化
Cache 缓存
1 :EhCache
EhCachePlugin是JFinal集成的缓存插件,通过使用EhCachePlugin可以提高系统的并发访问速度。
网页链接
ehcache.xml简介
EhCache的使用需要有ehcache.xml配置文件支持,该配置文件中配置了很多cache节点,每个cache节点会配置一个name属性,例如:<cache name="blog" …>,该属性是CacheKit取值所必须的。其它配置项如eternal、overflowToDisk、timeToIdleSeconds、timeToLiveSeconds详见EhCache官方文档。cache节点配置为都写入磁盘即可.
2: Redis
RedisPlugin是支持 Redis的极速化插件。使用RedisPlugin可以极度方便的使用redis,该插件不仅提供了丰富的API,而且还同时支持多redis服务端。Redis拥有超高的性能,丰富的数据结构,天然支持数据持久化,是目前应用非常广泛的nosql数据库。对于redis的有效应用可极大提升系统性能,节省硬件成本。网页链接
3:j2cache
开源中国教主红薯的二级缓存,性能非常高,是 EhCache+Redis二合一的处理方式
网页链接
‘肆’ jfinal中动态sql是一般是怎么使用的
动态sql一般用在存储过程中,可以在存储过程中使用DDL或DML语句,如创建删除操作。 语法:execute immediate 'DDL或DML语句'