【Spring MVC】(三)搭建Spring MVC+Spring+JDBC框架以及在此框架上进行项目开发2

简介: 【Spring MVC】(三)搭建Spring MVC+Spring+JDBC框架以及在此框架上进行项目开发2

5、Entity层(User实体类)


package cn.kgc.entity;
/**
 * @author:BeiisBei
 * @date:2019/11/8
 * @aim:
 */
public class User {
    private String name;
    private String pwd;
    public User(String name, String pwd) {
        this.name = name;
        this.pwd = pwd;
    }
    public User() {
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPwd() {
        return pwd;
    }
    public void setPwd(String pwd) {
        this.pwd = pwd;
    }
    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                ", pwd='" + pwd + '\'' +
                '}';
    }
}

6、改造Controller层


创建LoginServlet,实现以下业务功能:


跳转到系统登录页


实现登录/登出


改造View层


具体实现步骤如下:


1、跳转到系统登录页,login()方法实现跳转。

2、实现登录,doLogin()方法实现登录,登录成功则跳转到系统首页,否则跳转到登录页面。doLogin()方法主要进行用户信息匹配验证。


首先,通过方法入参(@RequestParam String name, @RequestParam String pwd) 来获取用户前台输入。


然后调用业务方法,将参数(name,pwd)传入后台,进行用户匹配,根据返回结果来判断是否登录成功。

package cn.kgc.servlet;
import cn.kgc.entity.User;
import cn.kgc.service.UserService;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.ModelAndView;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
/**
 * @author:BeiisBei
 * @date:2019/11/8
 * @aim:
 */
@Controller
@RequestMapping("/login")
public class LoginServlet {
    private Logger logger=Logger.getLogger(LoginServlet.class);
    @Resource
    private UserService userService;
    @RequestMapping("/login")
    public String login(String name,String pwd){
        logger.info("欢迎登录");
        return "login";
    }
    /**
     * 登录
     * @param name
     * @param pwd
     * @param request
     * @param session
     * @return
     */
    @RequestMapping("/doLogin")
    public ModelAndView doLogin(@RequestParam String name,
                                @RequestParam String pwd,
                                HttpServletRequest request,
                                HttpSession session){
        //调用service方法,进行用户匹配
        User user=userService.login(name,pwd);
        ModelAndView mav=new ModelAndView();
        logger.info(request.getParameter("name"));
        logger.info(user);
        if(null==user.getName()){     // 登录不成功
            logger.info("用户名或密码不正确");
            session.setAttribute("errMsg","用户名或密码不正确");
            mav.setViewName("login");
            throw new RuntimeException("用户名或密码不正确");
        }else {
            logger.info("登录成功");
            session.setAttribute("user",user);
            mav.addObject("user",user);
            mav.setViewName("redirect:../jsp/loginSuc.jsp");
        }
        return mav;
    }
    /**
     * 登出
     * @param name
     * @param session
     * @return
     */
    @RequestMapping("/logout")
    public String logout(@RequestParam String name,HttpSession session){
        session.invalidate();
        return "redirect:login";
    }
    /**
     * 局部异常
     * @param session
     * @param e
     * @param request
     * @return
     */
    @ExceptionHandler(value = {RuntimeException.class})
    public String errHandler(HttpSession session,RuntimeException e,HttpServletRequest request){
        session.invalidate();
        logger.info(e.getMessage());
        request.setAttribute("e",e);
        return "loginErr";
    }
}


指示符 —“redirect:” 转发


指示符 —“forward:” 重定向


1.登录成功后的当前用户信息需保存在session中


2.若登录失败,除了页面跳转到登陆页,还需在页面上进行错误提示


3.Servlet API对象作为处理方法的入参


1.HttpSession


2.HttpServletRequest


4.页面上使用EL表达式显示相应信息


异常处理


HandlerExceptionResolver


resolveException()


局部异常处理


仅能处理指定Controller中的异常


@ExceptionHandler


全局异常处理


对所有异常进行统一处理


配置SimpleMappingExceptionResolver


发生异常时使用对应的视图报告异常


20191110174551939.png


7、改造View层


1、login.jsp

<%--
  Created by IntelliJ IDEA.
  User: mu_bai
  Date: 2019/11/8
  Time: 14:14
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>登录界面</title>
</head>
<body>
<form action="/login/doLogin" method="post">
    <p><input type="text" name="name"/></p>
    <p><input type="password" name="pwd"/></p>
    <p><input type="submit"/></p>
</form>
</body>
</html>


2、loginErr.jsp

<%--
  Created by IntelliJ IDEA.
  User: mu_bai
  Date: 2019/11/8
  Time: 14:23
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>登入失败页面</title>
</head>
<body>
<h1>登入失败</h1>
<h1>${e.message}</h1>
<%--下面这个方法,errMsg在页面上获取不到,显示为NULL,标记下,解决了再更新代码--%>
<%--<%
    Object obj=request.getParameter("e");
    RuntimeException errMsg=null;
    if(obj!=null){
       errMsg=(RuntimeException) obj;
   }
%>
<h1><%=errMsg%></h1>--%>
</body>
</html>


3、loginSuc.jsp

<%@ page import="cn.kgc.entity.User" %><%--
  Created by IntelliJ IDEA.
  User: mu_bai
  Date: 2019/11/8
  Time: 14:24
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>登入成功页面</title>
</head>
<%  Object obj=session.getAttribute("user");
    User user=null;
    String name=null;
    if(obj!=null){
        user=(User)obj;
        name=user.getName();
    }else {
        response.sendRedirect("/login/login");
    }
%>
<body>
<h1>登录成功了</h1>
<h3><%=name==null? "" : "欢迎你:"+name %></h3>
<form method="post" action="/login/logout">
    <input type="text" name="name" value="<%=name==null? "": name %>" readonly>
    <input type="submit" value="登出">
</form>
</body>
</html>


8、结果演示


1、登录界面


20191110174858106.png


2、登录成功界面(点击登出,会退回到登录界面)


20191110174949699.png


3、登录失败界面(会打印出我们设置的异常)


20191110175319469.png

目录
相关文章
|
3月前
|
安全 Java Ruby
我尝试了所有后端框架 — — 这就是为什么只有 Spring Boot 幸存下来
作者回顾后端开发历程,指出多数框架在生产环境中难堪重负。相比之下,Spring Boot凭借内置安全、稳定扩展、完善生态和企业级支持,成为构建高可用系统的首选,真正经受住了时间与规模的考验。
304 2
|
2月前
|
安全 前端开发 Java
《深入理解Spring》:现代Java开发的核心框架
Spring自2003年诞生以来,已成为Java企业级开发的基石,凭借IoC、AOP、声明式编程等核心特性,极大简化了开发复杂度。本系列将深入解析Spring框架核心原理及Spring Boot、Cloud、Security等生态组件,助力开发者构建高效、可扩展的应用体系。(238字)
|
4月前
|
XML JSON Java
Spring框架中常见注解的使用规则与最佳实践
本文介绍了Spring框架中常见注解的使用规则与最佳实践,重点对比了URL参数与表单参数的区别,并详细说明了@RequestParam、@PathVariable、@RequestBody等注解的应用场景。同时通过表格和案例分析,帮助开发者正确选择参数绑定方式,避免常见误区,提升代码的可读性与安全性。
|
2月前
|
消息中间件 缓存 Java
Spring框架优化:提高Java应用的性能与适应性
以上方法均旨在综合考虑Java Spring 应该程序设计原则, 数据库交互, 编码实践和系统架构布局等多角度因素, 旨在达到高效稳定运转目标同时也易于未来扩展.
147 8
|
3月前
|
监控 Kubernetes Cloud Native
Spring Batch 批处理框架技术详解与实践指南
本文档全面介绍 Spring Batch 批处理框架的核心架构、关键组件和实际应用场景。作为 Spring 生态系统中专门处理大规模数据批处理的框架,Spring Batch 为企业级批处理作业提供了可靠的解决方案。本文将深入探讨其作业流程、组件模型、错误处理机制、性能优化策略以及与现代云原生环境的集成方式,帮助开发者构建高效、稳定的批处理系统。
448 1
|
5月前
|
安全 Java 微服务
Java 最新技术和框架实操:涵盖 JDK 21 新特性与 Spring Security 6.x 安全框架搭建
本文系统整理了Java最新技术与主流框架实操内容,涵盖Java 17+新特性(如模式匹配、文本块、记录类)、Spring Boot 3微服务开发、响应式编程(WebFlux)、容器化部署(Docker+K8s)、测试与CI/CD实践,附完整代码示例和学习资源推荐,助你构建现代Java全栈开发能力。
634 0
|
4月前
|
Cloud Native Java API
Java Spring框架技术栈选和最新版本及发展史详解(截至2025年8月)-优雅草卓伊凡
Java Spring框架技术栈选和最新版本及发展史详解(截至2025年8月)-优雅草卓伊凡
898 0
|
5月前
|
Java Spring 容器
SpringBoot自动配置的原理是什么?
Spring Boot自动配置核心在于@EnableAutoConfiguration注解,它通过@Import导入配置选择器,加载META-INF/spring.factories中定义的自动配置类。这些类根据@Conditional系列注解判断是否生效。但Spring Boot 3.0后已弃用spring.factories,改用新格式的.imports文件进行配置。
967 0
|
6月前
|
人工智能 Java 测试技术
Spring Boot 集成 JUnit 单元测试
本文介绍了在Spring Boot中使用JUnit 5进行单元测试的常用方法与技巧,包括添加依赖、编写测试类、使用@SpringBootTest参数、自动装配测试模块(如JSON、MVC、WebFlux、JDBC等),以及@MockBean和@SpyBean的应用。内容实用,适合Java开发者参考学习。
716 0
|
2月前
|
JavaScript Java Maven
【SpringBoot(二)】带你认识Yaml配置文件类型、SpringMVC的资源访问路径 和 静态资源配置的原理!
SpringBoot专栏第二章,从本章开始正式进入SpringBoot的WEB阶段开发,本章先带你认识yaml配置文件和资源的路径配置原理,以方便在后面的文章中打下基础
333 3

热门文章

最新文章