自動(dòng)生成javabean
上篇說到創(chuàng)建入口類厚者,繼承JFinalConfig
我們注意到在這個(gè)類中有如下代碼
public void configPlugin(Plugins me) {
// 配置 druid 數(shù)據(jù)庫連接池插件
DruidPlugin druidPlugin = new DruidPlugin(PropKit.get("jdbcUrl"), PropKit.get("user"), PropKit.get("password"));
me.add(druidPlugin);
// ehcache插件
EhCachePlugin ehCachePlugin = new EhCachePlugin();
me.add(ehCachePlugin);
// 配置ActiveRecord插件
ActiveRecordPlugin arp = new ActiveRecordPlugin(druidPlugin);
arp.setShowSql(false);
arp.setDevMode(true);
// 所有映射在 MappingKit 中自動(dòng)化搞定
_MappingKit.mapping(arp);
me.add(arp);
}
在后面配置ActiveRecord插件中,配置_MappingKit晃琳,我們看一下這個(gè)類
public class _MappingKit {
public static void mapping(ActiveRecordPlugin arp) {
arp.addMapping("tb_base_manager", "id",Manager.class);
arp.addMapping("tb_base_navigation", "id",Navigation.class);
arp.addMapping("tb_base_role","id",Role.class);
arp.addMapping("tb_base_manager_role", "id",ManagerRole.class);
arp.addMapping("tb_base_role_navigation","id",RoleNavigation.class);
arp.addMapping("tb_point_record", "point_record_id",PointRecord.class);
}
}
mapping方法的內(nèi)部配置了表名,主鍵的列名琐鲁,對(duì)應(yīng)的實(shí)體類卫旱,當(dāng)然,這些都是自動(dòng)生成的围段,不用我們一行一行的寫了
public class _JFinalDemoGenerator {
public static DataSource getDataSource() {
PropKit.use("application.properties");
DruidPlugin druidPlugin = O2OConfig.createDruidPlugin();
druidPlugin.start();
return druidPlugin.getDataSource();
}
public static void main(String[] args) {
// base model 所使用的包名
String baseModelPackageName = "com.o2o.common.model.base";
// base model 文件保存路徑
String baseModelOutputDir = PathKit.getWebRootPath() + "/src/main/java/com/o2o/common/model/base";
// model 所使用的包名 (MappingKit 默認(rèn)使用的包名)
String modelPackageName = "com.o2o.common.model";
// model 文件保存路徑 (MappingKit 與 DataDictionary 文件默認(rèn)保存路徑)
String modelOutputDir = baseModelOutputDir + "/..";
// 創(chuàng)建生成器
Generator generator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
// 設(shè)置是否生成鏈?zhǔn)?setter 方法
generator.setGenerateChainSetter(false);
// 添加不需要生成的表名
// generator.addExcludedTable("tb_shangjiaoperation1");
// 設(shè)置是否在 Model 中生成 dao 對(duì)象
generator.setGenerateDaoInModel(true);
// 設(shè)置是否生成鏈?zhǔn)?setter 方法
generator.setGenerateChainSetter(true);
// 設(shè)置是否生成字典文件
generator.setGenerateDataDictionary(false);
// 設(shè)置需要被移除的表名前綴用于生成modelName顾翼。例如表名 "osc_user",移除前綴 "osc_"后生成的model名為 "User"而非 OscUser
generator.setRemovedTableNamePrefixes("tb_base");
// 生成
generator.generate();
}
}
注釋中寫的很清楚蒜撮,可以配置哪些東西暴构,配置完成后運(yùn)行main方法跪呈,就可以自動(dòng)生成javabean和映射了;
創(chuàng)建Controller
在創(chuàng)建controller之前,還是要看一下入口類的相關(guān)配置
public void configRoute(Routes me) {
//第一個(gè)參數(shù)是訪問的路徑取逾,第二個(gè)參數(shù)配置Controller耗绿,第三個(gè)參數(shù)是視圖的路徑
me.add("/", IndexController.class, "/WEB-INF/view/index");
me.add("/navigation", NavigationController.class,"/WEB-INF/view/navigation");
me.add("/manager", ManagerController.class,"/WEB-INF/view/manager");
me.add("/role", RoleController.class,"/WEB-INF/view/role");/
}
我們配置了4個(gè)Controller,以后如果每增加一個(gè)controller就要在這里增加一行路由信息砾隅,以IndexController為例误阻,編寫IndexController,繼承com.jfinal.core.Controller類
public class IndexController extends Controller {
static ManagerService managerService = new ManagerService();
public void index() {
render("index.html");
}
//登陸
public void login() throws Exception{
...
redirect("/toLogin");
}
public void toLogin() {
render("login.html");
}
public void logout() {
...
redirect("toLogin");
}
}
在訪問路由中的路徑時(shí)晴埂,比如(“/”)究反,會(huì)進(jìn)入到index方法中,訪問其他方法需要在路由中配置的路徑+方法名(“/toLogin”會(huì)訪問toLogin方法)儒洛,這個(gè)類展示了兩種渲染方式精耐,分別是轉(zhuǎn)發(fā)(render)和重定向(redirect),此外還有renderJavascript, renderJson等其他渲染方式
至此JFinal的框架最基本的使用就配置完成了,我們可以在tomcat中運(yùn)行項(xiàng)目或者使用以下的代碼運(yùn)行
public static void main(String[] args) {
/**
* 特別注意:Eclipse 之下建議的啟動(dòng)方式
*/
JFinal.start("src/main/webapp", 8080, "/", 5);
/**
* 特別注意:IDEA 之下建議的啟動(dòng)方式琅锻,僅比 eclipse 之下少了最后一個(gè)參數(shù)
*/
// JFinal.start("src/main/webapp", 80, "/");
}