上一期我們已經搭建好了一個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" 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>
然後運作就出來資料了