自动生成javabean
上篇说到创建入口类,继承JFinalConfig
我们注意到在这个类中有如下代码
public void configPlugin(Plugins me) {
// 配置 druid 数据库连接池插件
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 中自动化搞定
_MappingKit.mapping(arp);
me.add(arp);
}
在后面配置ActiveRecord插件中,配置_MappingKit,我们看一下这个类
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方法的内部配置了表名,主键的列名,对应的实体类,当然,这些都是自动生成的,不用我们一行一行的写了
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 默认使用的包名)
String modelPackageName = "com.o2o.common.model";
// model 文件保存路径 (MappingKit 与 DataDictionary 文件默认保存路径)
String modelOutputDir = baseModelOutputDir + "/..";
// 创建生成器
Generator generator = new Generator(getDataSource(), baseModelPackageName, baseModelOutputDir, modelPackageName, modelOutputDir);
// 设置是否生成链式 setter 方法
generator.setGenerateChainSetter(false);
// 添加不需要生成的表名
// generator.addExcludedTable("tb_shangjiaoperation1");
// 设置是否在 Model 中生成 dao 对象
generator.setGenerateDaoInModel(true);
// 设置是否生成链式 setter 方法
generator.setGenerateChainSetter(true);
// 设置是否生成字典文件
generator.setGenerateDataDictionary(false);
// 设置需要被移除的表名前缀用于生成modelName。例如表名 "osc_user",移除前缀 "osc_"后生成的model名为 "User"而非 OscUser
generator.setRemovedTableNamePrefixes("tb_base");
// 生成
generator.generate();
}
}
注释中写的很清楚,可以配置哪些东西,配置完成后运行main方法,就可以自动生成javabean和映射了;
创建Controller
在创建controller之前,还是要看一下入口类的相关配置
public void configRoute(Routes me) {
//第一个参数是访问的路径,第二个参数配置Controller,第三个参数是视图的路径
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个Controller,以后如果每增加一个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");
}
}
在访问路由中的路径时,比如(“/”),会进入到index方法中,访问其他方法需要在路由中配置的路径+方法名(“/toLogin”会访问toLogin方法),这个类展示了两种渲染方式,分别是转发(render)和重定向(redirect),此外还有renderJavascript, renderJson等其他渲染方式
至此JFinal的框架最基本的使用就配置完成了,我们可以在tomcat中运行项目或者使用以下的代码运行
public static void main(String[] args) {
/**
* 特别注意:Eclipse 之下建议的启动方式
*/
JFinal.start("src/main/webapp", 8080, "/", 5);
/**
* 特别注意:IDEA 之下建议的启动方式,仅比 eclipse 之下少了最后一个参数
*/
// JFinal.start("src/main/webapp", 80, "/");
}