JSP到MVC开发模式的转变(3)

本文介绍如何在JSP+DAO基础上引入Servlet实现MVC模式。通过具体示例展示控制层(C层)的设计与实现,包括数据验证、业务逻辑处理及视图跳转。

 

3、  MVC开发模式

 

为了实现MVC的模式,需要在JSP+DAO的模式中加入一个控制层,也就是C层的部分,这就需要我们再建立一起起控制作用的Servlet,我们先建一个包com.test.servlet,在其下建立一个LoginServlet.java,其代码如下:

package com.test.servlet;

 

import javax.servlet.*;

import javax.servlet.http.*;

 

import com.test.model.*;

import com.test.factory.*;

 

import java.io.*;

import java.util.*;

 

public class LoginServlet extends HttpServlet {

 

public void doGet(HttpServletRequest request, HttpServletResponse response)

                    throws IOException, ServletException {

           this.doPost(request, response);

}

 

public void doPost(HttpServletRequest request, HttpServletResponse response)

                    throws IOException, ServletException {

           // 完成验证,替换Login_success.jsp

           List errors = new ArrayList();

           String path = "login.jsp";

           // 1、接受请求内容

           String id = request.getParameter("id");

           String password = request.getParameter("password");

           // 2、进行数据合法性验证,是否为空,长度是否满足等

           // 要将接收到的内容设置到Person对象,才能传递到DAO中操作

           // 所以可以在Person中加入验证方法

           Person person = new Person();

           person.setId(id);

           person.setPassword(password);

           person.setErrors(errors);

           // 3、如果合法则进行数据库验证

           if (person.isValidate()) {

                    // 数据合法,可以进行数据库验证

                    if (DaoFactory.getPersonDaoInstance().isLogin(person)) {

                             // 登陆成功

                             //request.setAttribute("name", person.getName());

                             path = "login_success.jsp";

                    } else {

                             // 登陆ID或密码错误

                             errors.add("登陆ID或密码错误");

                    }

           }

           //保存用户信息

           request.setAttribute("person", person);

           //保存错误信息

           request.setAttribute("errors", errors);

           request.getRequestDispatcher(path).forward(request, response);

}

}

         在这个类中覆写了HttpServlet的doGet()和doPost()方法,在doPost()方法中,通过request对象收集表单中的信息,并将收集到的信息赋予Person对象,因为只要通过Person对象才能将信息通过工厂传入Dao中进行处理。

         在这里,我们可以再增加一个对用户提交表单数据合法化的验证功能,这个功能方法可以放到起数据收集作用的Bean中,那就是Person,因为在这里有收集上来的所有表单数据项,我们可以在Person类中再增加一个isLogin()方法,如下:

public boolean isValidate() {

       boolean flag = true;

 

       //验证ID

       if ("".equals(this.id) || this.id == null)

       {

           errors.add("登陆ID不能为空");

           flag = false;

       }

       else

       {

           //进行长度验证

           if (this.id.length() < 3 || this.id.length() > 8)

           {

              errors.add("用户名的长度只能是3~8位");

              flag = false;

           }

       }

       //验证密码

       if ("".equals(this.password) || this.password == null)

       {

           errors.add("密码不能为空");

           flag = false;

       }

       else

       {

           //进行长度验证

           if (this.password.length() < 3 || this.password.length() > 8)

           {

              errors.add("密码的长度只能是3~8位");

              flag = false;

           }

       }

   

       this.errors = errors;

       return flag;

    }

 

         其中的errors是用来存储错误信息的,需要生命一个集合变量,并构建Setter和Getter方法:

//用于保存错误信息的属性

    private List errors;

public void setErrors(List errors)

    {

       this.errors = errors;

    }

   

    public List getErrors()

    {

       return this.errors;

    }

 

    到此,我们可就构建好了MVC的C部分,现在需要部署一个这个Servlet,打开web.xml文件,增加对Servlet的部署,如下:

 

 

       login

       com.test.servlet.LoginServlet

   

 

 

   

       login

       /LoginServlet.do

   

    这就将这个Servlet部署到了系统中,当系统拦截到LoginServlet.do的请求时就会交由com.test.servlet.LoginServlet这个类来处理。前台页面提交请求也需要作出相应的修改,那就是表单提交的Action,需要修改为:

 

 

此外对错误信息的显示,可以通过已经保存的Attribute获取,如下:

 

内容概要:本文为《科技类企业品牌传播白皮书》,系统阐述了新闻媒体发稿、自媒体博主种草与短视频矩阵覆盖三大核心传播策略,并结合“传声港”平台的AI工具与资源整合能力,提出适配科技企业的品牌传播解决方案。文章深入分析科技企业传播的特殊性,包括受众圈层化、技术复杂性与传播通俗性的矛盾、产品生命周期影响及2024-2025年传播新趋势,强调从“技术输出”向“价值引领”的战略升级。针对三种传播方式,分别从适用场景、操作流程、效果评估、成本效益、风险防控等方面提供详尽指南,并通过平台AI能力实现资源智能匹配、内容精准投放与全链路效果追踪,最终构建“信任—种草—曝光”三位一体的传播闭环。; 适合人群:科技类企业品牌与市场负责人、公关传播从业者、数字营销管理者及初创科技公司创始人;具备一定品牌传播基础,关注效果可量化与AI工具赋能的专业人士。; 使用场景及目标:①制定科技产品全生命周期的品牌传播策略;②优化媒体发稿、KOL合作与短视频运营的资源配置与ROI;③借助AI平台实现传播内容的精准触达、效果监测与风险控制;④提升品牌在技术可信度、用户信任与市场影响力方面的综合竞争力。; 阅读建议:建议结合传声港平台的实际工具模块(如AI选媒、达人匹配、数据驾驶舱)进行对照阅读,重点关注各阶段的标准化流程与数据指标基准,将理论策略与平台实操深度融合,推动品牌传播从经验驱动转向数据与工具双驱动。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值