美文网首页
2018-05-20MVC整体设计

2018-05-20MVC整体设计

作者: 初学者hao | 来源:发表于2018-05-20 21:56 被阅读0次
  1. 整体设计架构
graph LR
JSP-->Servlet;
Servlet-->DAO;
DAO-->MySQL;
Servlet-->JSP;
DAO-->Servlet;
MySQL-->DAO;
  • View:JSP
    1. 呈现数据:从request中获取Servlet放入的属性
    2. 接收用户的输入
    3. 编写JS代码给出对应的提示
  • Controller:Servlet
    1. 获取请求信息:获取请求参数
    2. 验证请求参数的合法性:验证失败需要返回页面,并给出提示信息
    3. 把请求参数封装为一个JavaBean
    4. 调用DAO的方法获取返回的结果
    5. 把返回的结果放入到request中
    6. 响应页面:转发重定向
  • Model:DAO
    1. 获取数据库连接
    2. 执行CRUD(增删改查)操作
    3. 返回结果
  • Model:MySQL
    1. 用于存储数据

注意:

1. 不能跨层访问

2. 只能自上向下依赖,而不能自下向上依赖

  1. 多个请求对应一个Servlet
  1. Servlet映射为*.do:可以接受一切.do结尾的请求
    <servlet-mapping>
        <servlet-name>Servlet</servlet-name>
        <url-patten>*.do</url-patten>
    </servlet-mapping>
  1. 在Servletde doGet和doPost方法中:
    • 获取ServletPath:/*.do:String servletPath=request.getServletPath();
    • 去除/和.do,得到*的字符串:
    String methodName=servletPath.subString(1);
    methodName=methodName.subString(0),methodName.length()-3);
    
    • 利用反射获取methodName对应的方法
        
        Method method=getClass().getDeclaredMethod(methodName,HttpServletRequest.class,HttpServletResponse.class);
        //利用反射调用对应的方法
        method.invoke(this,request,response);
    
  1. 查询:MVC整个流程
  • query.do-->doPost-->query-->JSP
  1. 模糊查询
  1. SQL: String sql="SELECT id,name,address,phone FROM customers WHERE "+"name LIKE ? AND address LIKE ? AND phone LIKE ?"
  2. 填充占位符:重写get方法
    public String getName(){
        if(name==null){
            name = "%";
        }else{
            name="%"+name+"%";
        }
        return name;
    }
  1. 把查询条件封装为一个JavaBean

相关文章

网友评论

      本文标题:2018-05-20MVC整体设计

      本文链接:https://www.haomeiwen.com/subject/gaqxjftx.html