SpringMVC登录案例

学习了一周的springMVC
今天搭建一个SpringMVC的登录案例
主要是用来巩固一下拦截器的是使用。

1.首先配置web.xml 配置
主要是配置encodingfilter和dispatcher

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
    <!--字符集设置-->
    <filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>


    <!--调度器配置-->
    <servlet>
        <servlet-name>dispatcher</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>dispatcher</servlet-name>
        <url-pattern>*.form</url-pattern>
    </servlet-mapping>
</web-app>

2.配置dispatcher指定的servlet.xml
主要配置拦截器的相关属性

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="
        http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">
    <!--指定注解解析的包-->
    <context:component-scan base-package="com.jsu.controller"/>
    <!--配置拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
           <!-- 指定拦截器的bean -->
            <bean class="com.jsu.intercepter.LoginIntercepter">

                <property name="allowAdress">
                    <!--允许通过的请求的列表-->
                    <list>
                        <value>login.form</value>
                        <value>add.form</value>
                    </list>
                </property>
            </bean>
        </mvc:interceptor>
    </mvc:interceptors>


</beans>

前车之鉴:千万不能使用如下配置不然会无法识别拦截器的拦截名单

<property name="allowAdress">
                    <!--允许通过的请求的列表-->
                    <list>
                        <value>
                            login.form
                        </value>
                        <value>
                            add.form
                        </value>
                    </list>
                </property>

3.配置intercepter的类
主要通过实现handlerintercepter接口

public class LoginIntercepter implements HandlerInterceptor {
    //拦截名单
    List<String> allowAdress;

    public void setAllowAdress(List<String> allowAdress) {
        this.allowAdress = allowAdress;
    }

    /**
     * 请求方法执行前所执行的方法
     * 返回true 则进行拦截
     * 否则不进行拦截
     */
    @Override
    public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o) throws Exception {
        //获取请求的路径
        String url = httpServletRequest.getRequestURL().toString();
        //查看是否已经有请求
        Object user = httpServletRequest.getSession().getAttribute("user");

        if (user != null){
            return true;
        }
        for (String temp : allowAdress) {
            if (url.endsWith(temp)) {
                return true;
            }
        }
        //重定向到login页面
        httpServletResponse.sendRedirect(httpServletRequest.getContextPath()+"/login.jsp");
        return false;
    }

    @Override
    public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {

    }

    @Override
    public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {

    }
}

4.配置controller类

@Controller
public class LoginController {
    @RequestMapping("/login")
    public String login(User user,HttpSession session){
        //校验
        if ("zzz".equals(user.getName())&&"123".equals(user.getPassword())) {

            session.setAttribute("user", user);
            return "redirect:index.jsp";
        }
        return "redirect:login.jsp";
    }

    @RequestMapping("/add")
    public String add(){
        System.out.println("add");
        return "redirect:index.jsp";
    }
}

5.配置实体类

public class User{

    private String name;
    private String password;



    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }
}

6.demo结果

SpringMVC登录案例

SpringMVC登录案例

错误结果就重定向到login.jsp页面

上一篇:nothing added to commit but untracked files present


下一篇:PHP 打印调用函数入口地址(堆栈),方便调式