• java中的mvc设计模式(个人心得)


    今天分享的是javaweb中的MVC设计模式,如果你还没开始学java,不要紧,只要通过本文的阅读,按照我说的做,就可以创建一个自己的网站,同时还能带你熟悉MVC这种设计模设计;

    废话不多说进入正题:

    MVC :模型+视图+控制器

    很多领域都用到这种设计模式,不仅仅是在web端,而在javaweb中模型对应Bean,视图对应service,控制器对应servlet;

    我更愿意把其理解为分层设计模式,从用户开始请求的html/jsp主页面开始,

    请求会从主页面发出===》》servlet进行分配任务==》》业务层service==》》数据层(dao)==》》Bean(模型穿插于各个层中,用来传递数据)

    如果到这里你还处于迷糊状态不要紧,建站离你只有读完这篇文章的距离;

    javaweb中有三大组件:servlet(控制器)、Filter(过滤器)、Listener(监听器)

    他们都需要在web.xml中进行配置,具体配置可以百度,很简单;

    servlet生命周期:(接口、实现类)

    init(ServletConfig sconfig);当开启服务器时,这个方法就会被服务器调用,可以理解为servlet出生了;用来给servlet初始化,基本不用;

    service(ServletRequest req,ServletResponse res);每个请求都要经过这个方法的处理分配;后期演化出doGet()doPost()等,最后还是由      service来调用这些演化来的方法,万变不离其中;(我会提供一个BaseServlet类来给学习者建站)

    destroy();当服务器即将关闭时,这个方法会被服务器调用,用来做一些收尾工作,但是我们一般不会在这里写代码,所以基本不用;

    Filter生命周期:(接口)

    方法基本同servlet只是用doFilter(ServletRequest request,ServletResponse response,FilterChain chain);替换了service方法;

    过滤器作用:可以过滤请求,当过滤器加到用户请求的页面或者servlet上时,请求就会先到过滤器,过滤器只有调用了FilterChain中的doFilter(request,response);请求才会到达所要请求的资源上,也就是说过滤器可以拦截请求;注意跟servlet一样每次请求都会调用doFilter方法;当然过滤器不光能做拦截,还可以用来进行对全站的配置,比如全站编码问题只要是全站设置就要想到用它因为servlet做不到;过滤器还可以做很多事,比如ip统计,页面静态化,粗粒度权限过滤等,其实都体现在对用户发送来的数据、请求头的特殊处理,或者是服务器响应给客户端数据、响应头的特殊处理,一旦需要这种操作,就可以考虑使用过滤器

    Listener生命周期:(接口)

    以ServletContextListener举例:contextInitialized(ServletContextEvent event);contextDestroyed(ServletContextEvent event);

    这两个方法前一个用来给ServletContext域的创建监听,后一个是用来给ServletContext销毁时监听;其它监听器都是这个原理;

    八大监听器接口,六个是对Servlet中的三大域对象进行监听已经与对象属性的监听,其中对ServletContext域进行监听的最有用,因为ServletContext是由服务器创建的,可以用来给项目来做初始化,event.getServletContext()是一个很重要的方法;

    剩下两个负责监听javaBean,但是他们都跟HttpSession相关,涉及到session的钝化、活化、序列化这里不做深入研究,这两个倾听器我一直都不知道是干什么用的,知道的人告诉我下,所以我认为基本没什么用;

    记住:拿到需求,首先分析你负责的这部分功能需要使用哪些组件来完成,完成的步骤,流程图;


    基于MVC模型开始创建我们的项目我这里用注册来做讲解,比较简单,其实多复杂的业务,也就那么回事,把注册弄会了,其它都会了;

    代码我习惯从数据层开始写,每写完一个功能就进行测试,代码注释一定要有;

    需求分析:

    获取用户从表单传递来的数据,把数据进行bean封装(我提供工具类不用担心,一键封装),将数据传递给业务层(用户名+密码),

    业务层中处理登录业务第一步:调用数据层方法从数据库中查询是否有这个用户(findByUserName(String username))

    业务层第二步:if()判断用户名是否已经存在,存在就给它抛个异常,带上异常信息让servlet处理;

    不存在调用数据层方法(addUser(User user);)将以上逻辑封装到regist(User user);注册方法中,在servlet中调用此方法,并将信息页面转发给用户。

    数据层:数据层主要是JDBC技术(提供我自己的Jdbcutils),用其对数据库进行增删改查,我的工具类基本把能封装的都封装了,两三行代码就能完成增删改查,如果是多条件查询,可能需要拼接sql语句,字符串拼接应该难不住你吧。(服务器端验证无非就是if判断,把各种情况想到,就不会出错)

    依赖关系 数据层依赖Bean 业务层依赖数据层  servlet依赖业务层  请求依赖servlet(动态页面)

    (只要学会我的所有工具类使用,轻松建站,但是每个工具类后面都跟着各种技术、设计模式,要想完全弄明白,就需要你去研究se知识了,来个三万行代码入个门先吧,少年,以上就是所谓的码农每天干的工作,增删改查+业务,要想摆脱码农成为大牛,不是会用框架就可以了,其实你会发现越用框架,离底层代码就越远,好处是带来方便更面向对象,成为大牛第一步,把你用的框架从头写一遍,万变不离其中的道理,全部写一遍离成为架构师就进一步,如果你还有时间可以学习activiti,Redis,JVM原理优化,storm集群,如果你还有时间可以学习下node.js,分布式,大数据.......我只能打等等,我这个小菜鸟就知道这么多了,下次分享ssh框架使用经验以及收获)

    package cn.wyx.dao;
    
    import java.sql.SQLException;
    import java.util.List;
    
    import org.apache.commons.dbutils.QueryRunner;
    import org.apache.commons.dbutils.handlers.BeanListHandler;
    
    import com.mchange.v2.c3p0.impl.NewPooledConnection;
    
    import cn.wyx.TxQueryRunner.TxQueryRunner;
    import cn.wyx.domain.Java_Book;
    
    public class BookDao {
        private QueryRunner qr = new TxQueryRunner();
        public List<Java_Book> findAll(){
            String sql="select * from Book";
            List<Java_Book> books=null;
            try {
                books = qr.query(sql,new BeanListHandler<Java_Book>(Java_Book.class));
                return books;
            } catch (SQLException e) {
                throw new RuntimeException(e);
            }
        }
        public List<Java_Book> findById(String id){
            String sql="select * from Book where id=?";
            try {
                List<Java_Book> books = qr.query(sql, new BeanListHandler<Java_Book>(Java_Book.class), id);
                return books;
            } catch (SQLException e) {
                throw new RuntimeException(e);
            }
        }
    }

    以上是数据层两个方法演示使用,除了异常处理,就是两三行代码,当然这是因为我的业务比较简单。你要是玩个分页,就需要个大几行了,不过也不难;

    需要资源的给评价;另出售python全栈学习资料,想学python人工智能、java高级架构的朋友可以关注我博客,知识在于分享。

  • 相关阅读:
    SpringCloud Ribbon实现负载均衡,SpringCloud Ribbon自定义策略
    springCloud zookeeper整合,Java Zookeeper微服务注册中心整合
    SpringCloud Eureka安装和使用,SpringCloud使用Eureka作为服务注册中心
    Linux yum安装Consul服务中心,Centos7在线安装consul
    SpringCloud consul安装和使用,Windows Consul安装和使用,Java consul服务中心安装和使用
    哔哩哔哩视频下载到电脑,bilibili UWP下载的视频重命名,blibli视频下载到电脑
    elasticsearch kibana安装和配置
    elasticsearch安装和配置,elasticsearch启动报错:can not run elasticsearch as root
    cmd打开当前文件所在目录,cmd进入当前文件目录,cmd进入指定目录
    京东到家 首页 笔记
  • 原文地址:https://www.cnblogs.com/wangyinxu/p/8460262.html
Copyright © 2020-2023  润新知