SpringBoot中使用JFinal的ActiveRecordPlugin插件

在写分享前先看了看jfinal-3.3的文档章节:5.13 任意环境下使用 ActiveRecordActiveRecordPlugin 可以独立于 java web 环境运行在任何普通的 java 程序中,使用方式极度简单,相对于 web 项目只需要手动调用一下其 start() 方法即可立即使用。

以下是代码示例:
public class ActiveRecordTest{
   public static void main(String[] args){
       DruidPlugin dp=new DruidPlugin("localhost","userName","password");
       ActiveRecordPlugin arp=new ActiveRecordPlugin(dp);
       arp.addMapping("blog",Blog.class);
       // 与web环境唯一的不同是要手动调用一次相关插件的start()方法
       dp.start();
       arp.start();
       // 通过上面简单的几行代码,即可立即开始使用
      newBlog().set("title","title").set("content","cxt text").save();
       Blog.dao.findById(123);
   }
}

注意:ActiveRecordPlugin 所依赖的其它插件也必须手动调用一下 start()方法,如上例中的dp.start()

下面进入正题:

创建一个插件类

ActiveRecordPluginConfig类
package com.choxsu.elastic.config;
import com.alibaba.druid.filter.stat.StatFilter;
import com.alibaba.druid.wall.WallFilter;
import com.choxsu.elastic.entity._MappingKit;
import com.jfinal.plugin.activerecord.ActiveRecordPlugin;
import com.jfinal.plugin.druid.DruidPlugin;
import com.jfinal.template.source.ClassPathSourceFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.sql.Connection;
/**
 * @author chox su
 * @date 2017/11/29 10:16
 */
 @Configuration
 public class ActiveRecordPluginConfig{
    @Value("${spring.datasource.username}")
    private String username;

    @Value("${spring.datasource.password}")
    private String password;

    @Value("${spring.datasource.url}")
    private String url;

    @Bean
    public ActiveRecordPlug ininitActiveRecordPlugin(){
        DruidPlugindruidPlugin=newDruidPlugin(url,username,password);
        // 加强数据库安全
        WallFilterwallFilter=newWallFilter();
        wallFilter.setDbType("mysql");
        druidPlugin.addFilter(wallFilter);
        // 添加 StatFilter 才会有统计数据
        // druidPlugin.addFilter(new StatFilter());
        // 必须手动调用start
        druidPlugin.start();
        ActiveRecordPlugin arp=new ActiveRecordPlugin(druidPlugin);
        arp.setTransactionLevel(Connection.TRANSACTION_READ_COMMITTED);
        _MappingKit.mapping(arp);
        arp.setShowSql(false);
        arp.getEngine().setSourceFactory(new ClassPathSourceFactory());
        arp.addSqlTemplate("/sql/all_sqls.sql");
        // 必须手动调用start
        arp.start();
        return arp;
    }
}

application.yml配置文件
server:
  port: 1013
spring:
  application:
    name: name:elastic
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    username: root
    password: root
    url: jdbc:mysql://192.168.3.44:3306/jfinal_club?characterEncoding=utf8&useSSL=false
pom.xml配置文件

  com.zgxl.market
  fastjson
  1.0.0



  mysql
  mysql-connector-java
  5.1.42



  com.jfinal
  jfinal
  3.3



  com.alibaba
  druid
  3.3


主要用到的是上面这几个maven dependency

目录结构
SpringBoot中使用JFinal的ActiveRecordPlugin插件_第1张图片
image
测试效果

Controller类方法定义

SpringBoot中使用JFinal的ActiveRecordPlugin插件_第2张图片
Controller类方法定义

swagger接口测试

SpringBoot中使用JFinal的ActiveRecordPlugin插件_第3张图片
swagger接口测试
SpringBoot中使用JFinal的ActiveRecordPlugin插件_第4张图片
swagger接口测试

sql管理功能这里没贴上来,但我已经测试通过了,springboot打包成jar启动可以找到sql路径,之前我是使用PathKit.getRootPath这种方式,这种方式打包成jar后就找不到路径;按照ActiveRecordPluginConfig类配置即可

你可能感兴趣的:(SpringBoot中使用JFinal的ActiveRecordPlugin插件)