• 用户登录以及过滤器


    过滤器:
    1,写一个普通的类实现filter接口
    2,实现其中的doFilter方法,这里写业务
    3,在web.xml中配置过虑器

    用户登录:

    1.写好登录的dao,service类和相应方法;

    2.前台写一个form,包含帐号和密码两个input;提交时url写查询登录用户的servlet的url

    3.后台拿到前台传过来的参数,以此为条件进行查询

    此处只写重点

    LoginDaoImpl

    package dao.impl;

    import java.sql.SQLException;

    import org.apache.commons.dbutils.QueryRunner;
    import org.apache.commons.dbutils.handlers.BeanHandler;

    import util.DbUtil;
    import dao.LoginDao;
    import entity.U;

    public class LoginDaoImpl implements LoginDao {

    QueryRunner qr = DbUtil.getQueryRunner();
    @Override
    public U login(U u) {
    String sql="select*from u where name=? and password=?";
    U uu=new U();
    try {
    uu=qr.query(sql, new BeanHandler<U>(U.class),u.getName(),u.getPassword());
    } catch (SQLException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    return uu;
    }

    }

    LoginServiceImpl

    package service.impl;

    import service.LoginService;
    import dao.LoginDao;
    import dao.impl.LoginDaoImpl;
    import entity.U;

    public class LoginServiceImpl implements LoginService {

    private LoginDao loginDao=new LoginDaoImpl();
    @Override
    public U login(U u) {
    U uu = loginDao.login(u);
    return uu;
    }

    }

    LoginServlet

    package servlet;

    import java.io.IOException;

    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;

    import service.LoginService;
    import service.impl.LoginServiceImpl;
    import entity.U;

    public class LoginServlet extends HttpServlet {

    private LoginService loginService=new LoginServiceImpl();

    @Override
    public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html;charset=utf-8");
    String name = request.getParameter("name");
    String password = request.getParameter("password");
    try {
    U u=new U();
    u.setName(name);
    u.setPassword(password);
    U uu = loginService.login(u);

    if(uu!=null){
    request.getSession().setAttribute("u", uu);
    request.getRequestDispatcher("/empList").forward(request, response);
    }else{
    request.getSession().setAttribute("message", "用户名或密码错误,请重试");
    response.sendRedirect(request.getContextPath()+"/userlogin.jsp");
    }
    } catch (Exception e) {
    e.printStackTrace();
    response.sendRedirect(request.getContextPath()+"/error.jsp");
    }


    }
    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
    }
    }

    LoginFilter.java

    package filter;

    import java.io.IOException;

    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    //登录过滤器
    public class LoginFilter implements Filter {

    @Override
    public void doFilter(ServletRequest arg0, ServletResponse arg1,
    FilterChain chain) throws IOException, ServletException {
    HttpServletRequest request=(HttpServletRequest)arg0;
    HttpServletResponse response=(HttpServletResponse)arg1;
    //设置字符编码
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html;charset=utf-8");
    //拿到请求的uri,如;/servletTest/login
    String uri = request.getRequestURI();
    System.out.println("uri======"+uri);
    //拿到uri中第二个“/”的下标
    int index = uri.lastIndexOf("/");
    System.out.println("/的下标是:"+index);
    //截取从第二个“/”开始到最后的所有字符,判断当前访问的是哪个方法
    String method = uri.substring(index+1);
    System.out.println("当前访问的方法---"+method);
    //如果是登录请求或者访问登录页面,则放行
    if("login".equals(method)||"userlogin.jsp".equals(method)||"".equals(method)){
    //放行
    System.out.println("已放行");
    chain.doFilter(request,response);
    }else{//不是登录请求
    //拿到session,判断session中有没有保存的登录信息
    System.out.println("不放行");
    Object obj = request.getSession().getAttribute("u");
    if(obj!=null){
    //session中有保存的用户信息,证明已登录,放行
    chain.doFilter(request, response);
    }else{
    //否则就是没登录,不予放行
    request.setAttribute("message", "请先登录");
    request.getRequestDispatcher("/userlogin.jsp").forward(request, response);
    }
    }
    }
    @Override
    public void init(FilterConfig arg0) throws ServletException {
    }
    @Override
    public void destroy() {
    }
    }

    web.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
    <display-name>servletTest</display-name>
    <filter>
    <filter-name>loginFilter</filter-name>
    <filter-class>filter.LoginFilter</filter-class>
    </filter>
    <filter-mapping>
    <filter-name>loginFilter</filter-name>
    <!-- 对所有的请求拦截判断 -->
    <url-pattern>/*</url-pattern>
    </filter-mapping>
    <servlet>
    <servlet-name>login</servlet-name>
    <servlet-class>servlet.LoginServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>count</servlet-name>
    <servlet-class>servlet.CountServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>addEmp</servlet-name>
    <servlet-class>servlet.AddEmpServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>deleteEmp</servlet-name>
    <servlet-class>servlet.DeleteEmpServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>findUpdEmp</servlet-name>
    <servlet-class>servlet.FindUpdEmpServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>updateEmp</servlet-name>
    <servlet-class>servlet.UpdateEmpServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>findEmp</servlet-name>
    <servlet-class>servlet.FindEmpServlet</servlet-class>
    </servlet>
    <servlet>
    <servlet-name>empList</servlet-name>
    <servlet-class>servlet.FindEmpsServlet</servlet-class>
    </servlet>

    <servlet-mapping>
    <servlet-name>login</servlet-name>
    <url-pattern>/login</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
    <servlet-name>count</servlet-name>
    <url-pattern>/count</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
    <servlet-name>addEmp</servlet-name>
    <url-pattern>/addEmp</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
    <servlet-name>deleteEmp</servlet-name>
    <url-pattern>/deleteEmp</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
    <servlet-name>findUpdEmp</servlet-name>
    <url-pattern>/findUpdEmp</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
    <servlet-name>updateEmp</servlet-name>
    <url-pattern>/updateEmp</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
    <servlet-name>findEmp</servlet-name>
    <url-pattern>/findEmp</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
    <servlet-name>empList</servlet-name>
    <url-pattern>/empList</url-pattern>
    </servlet-mapping>

    <welcome-file-list>
    <welcome-file>userlogin.jsp</welcome-file>
    </welcome-file-list>
    </web-app>

    userlogin.jsp

    <%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>用户登录页面</title>
    </head>
    <body>
    <form action="/servletTest/login" method="post">
    <h2>用户登录</h2>
    帐号:<input type="text" name="name"/><p>
    密码:<input type="text" name="password"/><p>
    &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type="submit" value="提交"/><p>
    ${message }
    </form>
    </body>
    </html>

  • 相关阅读:
    mysql sum 重复计算_mysql join sum时数据重复问题及解决方案
    mysql数据库中,查询一个表的下一条数据减上一条数据的值的写法
    FROM_UNIXTIME 格式化MYSQL时间戳函数
    Mysql 中日期类型bigint和datetime互转
    mysql 按照指定字段的指定数据进行排序 filed函数
    MYSQL使用group by,如何查询出总记录数
    iptables添加开放端口
    MySQL之You can't specify target table for update in FROM clause解决办法
    epoll 使用 LT + 非阻塞 IO 和 ET + 非阻塞 IO 比较
    sizeof和strlen的比较
  • 原文地址:https://www.cnblogs.com/xyzq/p/5749972.html
Copyright © 2020-2023  润新知