jfinal学习笔记【2】-连接数据库-laymi(雷米快速开发平台)

  • Post author:
  • Post category:其他

上一期我们已经搭建好了一个jfinal框架,这里说明下,我本来的目的是想搭建一个类似jeecg的快速开发平台,一键生产代码一键生成api文档等集成支付定时等等的常用插件,我并不是在重复的造轮子!jeecg太庞大了,不是说不好,有很多东西对于小白(我这种刚进入这个行业半年的)来说,很多东西看不懂,更不好维护,大神当然没问题,可我们是小白!我们虽然每晚都加班到好晚,可是我们在成长的路上,因为没有一个完整的教程,后台发现了jfinal,就有一个想法自己做个类似于jeecg的开速开发平台,写一个最基本的教程,小白能看懂的,每个插件的集成怎么集成的,又是怎么用的,然后复制粘贴就行了,快速开发框架的作用就剩下更多的时间去干工作以外的事,jfinal最适合不过了!这里只是记录学习的过程,有些东西不要太追究为什么,我也不懂,我只是找别人的教程按自己的想法实践整理!

让我们一起加油!

1:添加jar  这是jfinal demo下的几个jar我用的是mysql数据库  这个项目暂时也是基于mysql的 其他数据库应该也差不多

2:然后配置下res下的文件  我也不知道我建的项目为什么没有res文件夹,不管了 直接把demo下的复制过来了

a_little_config里是配置数据库的  反正拿来用了

先新建一个数据库  user表吧

根据jfinal规则  字段用驼峰  然后表名下划线这样的

然后就是rec里的文件了  txt是这样的

jdbcUrl = jdbc:mysql://localhost:3306/jfinal?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
user = root
password =
devMode = true

log4j是这样的,反正demo里有 配置上再说

# log4j.rootLogger=WARN, stdout, file
log4j.rootLogger=ERROR, stdout, file
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%n%-d{yyyy-MM-dd HH:mm:ss}%n[%p]-[Thread: %t]-[%C.%M()]: %m%n

# Output to the File
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.DatePattern='_'yyyy-MM-dd'.log'
log4j.appender.file.File=./jfinal_demo.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%n%-d{yyyy-MM-dd HH\:mm\:ss}%n[%p]-[Thread\: %t]-[%C.%M()]\: %m%n

然后配置LaymiConfig.java 按着demo里来吧

@Override
	public void configConstant(Constants me) {
		// 加载少量必要配置,随后可用PropKit.get(...)获取值
		PropKit.use("a_little_config.txt");
		me.setDevMode(PropKit.getBoolean("devMode", false));
		
	}

添加一个方法

public static DruidPlugin createDruidPlugin() {
		return new DruidPlugin(PropKit.get("jdbcUrl"), PropKit.get("user"), PropKit.get("password").trim());
	}

然后发现demo里有个代码生成器

创建一个LaymiGenerator的类

package com.laymi.index;

import javax.sql.DataSource;

import com.jfinal.kit.PathKit;
import com.jfinal.kit.PropKit;
import com.jfinal.plugin.activerecord.generator.Generator;
import com.jfinal.plugin.druid.DruidPlugin;

public class LaymiGenerator {
	public static DataSource getDataSource() {
		PropKit.use("a_little_config.txt");
		DruidPlugin druidPlugin = LaymiConfig.createDruidPlugin();
		druidPlugin.start();
		return druidPlugin.getDataSource();
	}
	
	public static void main(String[] args) {
		// base model 所使用的包名
		String baseModelPackageName = "com.laymi.admin.model.base";
		// base model 文件保存路径
		String baseModelOutputDir = PathKit.getWebRootPath() + "/../src/com/laymi/admin/model/base";
		
		// model 所使用的包名 (MappingKit 默认使用的包名)
		String modelPackageName = "com.laymi.admin.model";
		// model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
		String modelOutputDir = baseModelOutputDir + "/..";
		
		// 创建生成器
		Generator generator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
		// 设置是否生成链式 setter 方法
		generator.setGenerateChainSetter(false);
		// 添加不需要生成的表名
		generator.addExcludedTable("adv");
		// 设置是否在 Model 中生成 dao 对象
		generator.setGenerateDaoInModel(true);
		// 设置是否生成链式 setter 方法
		generator.setGenerateChainSetter(true);
		// 设置是否生成字典文件
		generator.setGenerateDataDictionary(true);
		// 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
		generator.setRemovedTableNamePrefixes("t_");
		// 生成
		generator.generate();
	}
}

然后运行这个类生成代码,刷新项目就好了

继续配置LaymiConfig.java

/**
	 * 配置插件
	 */
	public void configPlugin(Plugins me) {
		// 配置C3p0数据库连接池插件
		DruidPlugin druidPlugin = createDruidPlugin();
		me.add(druidPlugin);
		
		// 配置ActiveRecord插件
		ActiveRecordPlugin arp = new ActiveRecordPlugin(druidPlugin);
		// 所有映射在 MappingKit 中自动化搞定
		_MappingKit.mapping(arp);
		me.add(arp);
	}

然后admin下面创建user包

然后创建UserController集成Controller

package com.laymi.admin.user;

import com.jfinal.core.Controller;

public class UserController extends Controller {
	public void index() {
		render("user.html");
	}
	public void add() {
	}
}

admin添加user.html

<!DOCTYPE html>
<html>
  <head>
    <title>用户table</title>
	
    <meta name="keywords" content="keyword1,keyword2,keyword3">
    <meta name="description" content="this is my page">
    <meta name="content-type" content="text/html; charset=UTF-8">
    
    <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->

  </head>
  
  <body>
    <a href="/user/add">添加</a>
        <table border="1">
            <tr>
                <td>
                    用户名
                </td>
                <td>
                    年龄
                </td>
                <td>
                    姓名
                </td>
                <td>
                    密码
                </td>
                <td>
                    操作
                </td>
            </tr>
            <tr>
                <td>
                </td>
                <td>
                </td>
                <td>
                </td>
                <td>
                </td>
                <td>
                    <a href="/user/delete/${student.studentid}">删除</a>
                    <a href="/user/get/${student.studentid}">修改</a>
                </td>
            </tr>
            </#list>

        </table>
  </body>
</html>

配置后端路由

package com.laymi.index;

import com.jfinal.config.Routes;
import com.laymi.admin.LoginController;
import com.laymi.admin.user.UserController;
/**
* @ClassName: AdminRoutes
* @Description: 配置后端路由(供管理系统)
* @author: liuzy
* @date: 2017年4月2日 
* @version: 1.0 版本初成
 */
public class AdminRoutes extends Routes {

	@Override
	public void config() {
		//设置页面base路径
        setBaseViewPath("/view/admin");
        //用户登录控制器
        add("/",LoginController.class,"/"); //第三个参数是视图的路径
        add("/user", UserController.class,"/");
	}

}

运行下看看

http://127.0.0.1/user

添加UserService

package com.laymi.admin.user;

import com.jfinal.plugin.activerecord.Page;
import com.laymi.admin.model.LaymiUser;
public class UserService {
	public static final UserService service = new UserService();
	public Page<LaymiUser> paginate(int pageNumber, int pageSize) {
		return LaymiUser.dao.paginate(pageNumber, pageSize, "select *", "from laymi_user order by id asc");
	}
}

修改controller

package com.laymi.admin.user;

import com.jfinal.core.Controller;

public class UserController extends Controller {
	public void index() {
		setAttr("userPage", UserService.service.paginate(getParaToInt(0, 1), 10));
		render("user.html");
	}
	public void add() {
	}
}

修改页面

<!DOCTYPE html>
<html>
  <head>
    <title>用户table</title>
	
    <meta name="keywords" content="keyword1,keyword2,keyword3">
    <meta name="description" content="this is my page">
    <meta name="content-type" content="text/html; charset=UTF-8">
    
    <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->

  </head>
  
  <body>
    <a href="/user/add">添加</a>
        <table border="1">
            <tr>
                <td>
                    用户名
                </td>
                <td>
                    姓名
                </td>
                <td>
                    年龄        
                </td>
                <td>
                    密码
                </td>
                <td>
                    操作
                </td>
            </tr>
            #for(x : userPage.getList())
            <tr>
                <td>#(x.userName)
                </td>
                <td>#(x.name)
                </td>
                <td>#(x.age)
                </td>
                <td>#(x.userPassword)
                </td>
                <td>
                    <a href="/user/delete/${student.studentid}">删除</a>
                    <a href="/user/get/${student.studentid}">修改</a>
                </td>
            </tr>
            #end

        </table>
  </body>
</html>

然后运行就出来数据了


版权声明:本文为lzy1357986420原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。