欢迎使用优快云-markdown编辑器

本文介绍如何在Maven项目中配置并使用JFinal框架,包括导入依赖、设置过滤器、定义控制器及路由,还演示了如何连接数据库进行基本的CRUD操作。

总结


配置JFinala

在maven项目里导入JFinal的jar包,修改web.xml

<filter>
<filter-name>jfinal</filter-name>
<filter-class>com.jfinal.core.JFinalFilter</filter-class>
<init-param>
<param-name>configClass</param-name>
<param-value>demo.DemoConfig</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>jfinal</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

添加 java 文件,在项目 src 目录下创建 demo 包,并在 demo 包下创建 DemoConfig 文件

package demo;

import com.jfinal.config.*;

public class DemoConfig extends JFinalConfig {
    public void configConstant(Constants me) {
    me.setDevMode(true);
    }
    public void configRoute(Routes me) {
    me.add("/hello", HelloController.class);
    }
    public void configEngine(Engine me) {}
    public void configPlugin(Plugins me) {}
    public void configInterceptor(Interceptors me) {}
    public void configHandler(Handlers me) {}

在 demo 包下创建 HelloController 类文件, 内容如下

package demo;
import com.jfinal.core.Controller;
public class HelloController extends Controller {
    public void index() {
    renderText("Hello JFinal World.");
    }
}

然后运行JFinal


测试路由

在configRout方法里添加路由

public void configRoute(Routes me) {
        me.add("/index",Index.class);
    }

index类的配置

public class Index extends Controller{
    public void index(){
        render("index.html");
    }

连接数据库

在configPlugin方法中配置数据库插件,我这里使用c3p0连接池

public void configPlugin(Plugins me) {
        loadPropertyFile("sql.txt");
        C3p0Plugin c3p0Plugin = new C3p0Plugin(getProperty("jdbcUrl"),
        getProperty("user"), getProperty("password"));
        me.add(c3p0Plugin);
        ActiveRecordPlugin arp = new ActiveRecordPlugin(c3p0Plugin);
        me.add(arp);
        arp.addMapping("complain","comp_id", Complain.class);
    }

数据库配置文件

jdbcUrl=jdbc:mysql://localhost/demo?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull
user=123
password=123
devMode=true

测试数据库连接,简单的CRUD操作

Complain complain = new Complain();

complain.setComp_id("2");
complain.setComp_company("A");
complain.setComp_name("Jack");
complain.setComp_mobile("123");
complain.save();

complain = complain.findById("2");
String comp_name = complain.getComp_name();
complain.setComp_name("jerry");
boolean update = complain.update();
System.out.println(update);

boolean deleteById = complain.deleteById("3");

访问WEB-INF时遇到的小问题

访问WEB-INF下面的页面需要配置setBaseViewPath才能访问

public void configRoute(Routes me) {
        me.setBaseViewPath("WEB-INF/jsp");
        me.add("/index",Index.class);
        me.add("/user",UserController.class,"nsfw/user");
    }

me.add(“/user”,UserController.class,”nsfw/user”);的最后一个参数是进入setBaseViewPath配置路径下面的子目录的,最终的路径就是:WEB-INF/jsp/nsfw/user/index.html

先看效果: https://pan.quark.cn/s/c7070e7537b1 [!NOTE] 每到答辩季我就会喜获stars,谢谢大家的支持! 欢迎推广传播本repo(https://.com/atomiechen/THU-PPT-Theme),也欢迎贡献变体,提供更多选择 清华简约主题PPT模板 Repo stars 2020年春夏之交,答辩期间很多同学都在寻找清华主题的答辩模板。 一方面有使用LaTeX制作Beamer的模板(见Overleaf上的模板THU Beamer Theme),另一方面民间也存在着一些PPT模板。 很多人可能不适应Beamer的使用(主要是内容和排版设计不是可见即所得,定制有门槛),以及我找到的PPT模板也都不太好使(要么图案设计太复杂、不好看,要么没有制作成PPT母版导致每次使用都要复制粘贴+微调,不方便)。 我制作了清华简约主题的PPT模板,后续有新的设计我会逐渐加入,也欢迎有兴趣有想法的朋友们添砖加瓦! 内容 所有模板均为 文件。 此外也提供转换脚本用于 Pandoc自动生成PPTX。 各个版本的修改历史见 CHANGELOG.md。 下载 推荐直接从 Releases 下载最新发布版。 也可以在 仓库 单独下载所需文件。 效果 16:9比例,v1留边、v1顶边、v3留边白底、v3顶边白底: demo 16:9比例,其他风格模板:v1扁平、v2扁平、v1暗光 demo2 其他变体设计参见 variants/README.md。 使用方式 可以基于所提供的文件自行修改内容,也可以在新建的PPT文稿中应用该模板。 后者在 MS Office 2019 For Mac 的 PowerPoint 里的具体使用方式为:首先选择幻灯片尺...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值