JFinal2.2Controller学习(三)

1.储备知识

jfinal框架采用了传统的MVC架构设计,来不及解释了,快上车。jfinal的Controller是线程安全的,所谓的线程安全就是在多线程访问时,采用了加锁机制来保护数据。这样的做的好处是不会出现脏数据。

2.开始旅程

Controller中,最好保证它的纯洁性,不要写复杂的的业务逻辑代码。当然你要是喜欢的话,那就把一大堆的业务代码写在Controller中,反正维护你代码的人会一直问候你的。Controller 其实主要负责action请求的分发和返回就好。

2.1 写行代码(醒醒脑)

在工程中新建html类型的文件,命名login.html,代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>登录页面</title>
</head>
<body>
    <form action="/sinlogin/login">
        <label>账号:</label><input type="text" name="user.name"> <br /><br /> 
        <label>密码:</label><input type="text" name="user.pwd"><br /><br />
        <button type="submit">登录</button>
    </form>
</body>
</html>

页面中有两个input和一个button配合工作。从代码中可以看出一些细节,比如action的指向,比如表单元素的name。

2.2剧情回顾(configRoute配置)

    /**
     * 配置路由
     */
    public void configRoute(Routes me) {
          //第一个参数是访问controller的key
          //第二个参数是要映射的controller
          // 第三个参数为该Controller的视图存放路径
          // 第三个参数省略时默认与第一个参数值相同,在此即为 "/sinlogin"路径
        me.add("/sinlogin",LoginController.class);
    }
2.3主角登场(Controller)

public class LoginController extends Controller{
     /**
     *固定写法,配置默认的根路由
     */ 
     public void index(){
         render("login.html");
     }
     
    /**
     *login方法
     */
     public void login(){
         String name = getPara("user.name");     //获取用户名
         String pwd = getPara("user.pwd");          //获取用户密码
         //输出页面上提交的信息,不出意外信息输出正常
         System.out.println("该用户的用户名是:"+name+",密码是:"+pwd);
     }
}

2.4成双成对(数据展示)

我们已经学会了提交数据到后台,那如果想从后台获取数据展示在页面上该怎么办么?别急,车子还没停下来,我们一起开。滴滴滴滴

     public void index(){
         //定义变量并赋值初始化
         String name = "yetangtang";
         String pwd = "123456";
         //利用setAttr 方法将数据传递给view(视图) 
         setAttr("name",name);
         setAttr("pwd",pwd);
         //渲染页面
         render("login.html");
     }

接下来修改html页面的代码,具体如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>登录页面</title>
</head>
<body>
    <form action="/sinlogin/login">
        <label>账号:</label><input type="text" name="user.name" value="${name!}"> <br /><br /> 
        <label>密码:</label><input type="text" name="user.pwd" value="${pwd!}"><br /><br />
        <button type="submit">登录</button>
    </form>
</body>
</html>

好厉害,你已经成功get新技能了。大神,请收下我的膝盖~

3.更多方法预览

getPara 系列方法 :获取页面传递参数;
getModel 与 getBean 系列方法 :获取model(实体);
setAttr 方法 :展示数据到view;
getFile 系列方法:处理文件上传;
renderFile 方法:处理文件下载 ;
render 系列方法 :渲染视图并返回客户端;
session 操作方法 :处理session对象存储与管理。

PS:愿小伙伴们学习进步,有坑大家一起填。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值