java activerecordplugin_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{

// 这里可以直接注入您自己的datasource

@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=falsepom.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

目录结构

a10cbde162bf7725262ac3a77e466201.png

测试效果

Controller类方法定义

f43f0e810b39b876c9cd5181bd05a05b.png

swagger接口测试

a59476d9ce33c3a837892fd9cf494030.png

cc105915d387d50bdbd9563f9eda1a14.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值