美文网首页
SpringBoot中使用JFinal的ActiveRecord

SpringBoot中使用JFinal的ActiveRecord

作者: AaChoxsu | 来源:发表于2018-03-26 11:54 被阅读0次

    在写分享前先看了看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配置文件
    <dependency>
      <groupId>com.zgxl.market</groupId>
      <artifactId>fastjson</artifactId>
      <version>1.0.0</version>
    </dependency>
    
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.42</version>
    </dependency>
    
    <dependency>
      <groupId>com.jfinal</groupId>
      <artifactId>jfinal</artifactId>
      <version>3.3</version>
    </dependency>
    
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid</artifactId>
      <version>3.3</version>
    </dependency>
    
    

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

    目录结构
    image
    测试效果

    Controller类方法定义

    Controller类方法定义

    swagger接口测试

    swagger接口测试 swagger接口测试

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

    相关文章

      网友评论

          本文标题:SpringBoot中使用JFinal的ActiveRecord

          本文链接:https://www.haomeiwen.com/subject/tfzlcftx.html