天天看點

jfinal學習筆記【2】-連接配接資料庫-laymi(雷米快速開發平台)

上一期我們已經搭建好了一個jfinal架構,這裡說明下,我本來的目的是想搭建一個類似jeecg的快速開發平台,一鍵生産代碼一鍵生成api文檔等內建支付定時等等的常用插件,我并不是在重複的造輪子!jeecg太龐大了,不是說不好,有很多東西對于小白(我這種剛進入這個行業半年的)來說,很多東西看不懂,更不好維護,大神當然沒問題,可我們是小白!我們雖然每晚都加班到好晚,可是我們在成長的路上,因為沒有一個完整的教程,背景發現了jfinal,就有一個想法自己做個類似于jeecg的開速開發平台,寫一個最基本的教程,小白能看懂的,每個插件的內建怎麼內建的,又是怎麼用的,然後複制粘貼就行了,快速開發架構的作用就剩下更多的時間去幹工作以外的事,jfinal最适合不過了!這裡隻是記錄學習的過程,有些東西不要太追究為什麼,我也不懂,我隻是找别人的教程按自己的想法實踐整理!

讓我們一起加油!

1:添加jar  這是jfinal demo下的幾個jar我用的是mysql資料庫  這個項目暫時也是基于mysql的 其他資料庫應該也差不多

jfinal學習筆記【2】-連接配接資料庫-laymi(雷米快速開發平台)

2:然後配置下res下的檔案  我也不知道我建的項目為什麼沒有res檔案夾,不管了 直接把demo下的複制過來了

jfinal學習筆記【2】-連接配接資料庫-laymi(雷米快速開發平台)

a_little_config裡是配置資料庫的  反正拿來用了

先建立一個資料庫  user表吧

根據jfinal規則  字段用駝峰  然後表名下劃線這樣的

jfinal學習筆記【2】-連接配接資料庫-laymi(雷米快速開發平台)

然後就是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" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >-->

  </head>
  
  <body>
    <a href="/user/add" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >添加</a>
        <table >
            <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}" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >删除</a>
                    <a href="/user/get/${student.studentid}" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >修改</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" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >-->

  </head>
  
  <body>
    <a href="/user/add" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >添加</a>
        <table >
            <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}" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >删除</a>
                    <a href="/user/get/${student.studentid}" target="_blank" rel="external nofollow"  target="_blank" rel="external nofollow" >修改</a>
                </td>
            </tr>
            #end

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

然後運作就出來資料了