자바 실전 구현 사용자 로그 인

머리말
在这里插入图片描述
在这里插入图片描述
2.사례 수요
1.login.html 로그 인 페이지,username&password 두 개의 입력 상 자 를 작성 합 니 다.
2.Druid 데이터베이스 연결 풀 기술 을 사용 하여 my sql,day 14 데이터베이스 에 있 는 user 표를 조작 합 니 다.
3.jdbcTemplate 기술 로 JDBC 봉인
4.로그 인 성공 후 SuccessServlet 전시 로 이동:로그 인 성공!사용자 이름
5.로그 인 실패 FailServlet 으로 건 너 뛰 기:로그 인 실패 비밀번호 오류
시작
우선 항목 을 만 들 고 html 페이지 를 작성 하 며 프로필,jar 패 키 지 를 설정 합 니 다.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="/day14/loginServlet" method="post">
       :<input type="text" name="username"> <br>
      :<input type="password" name="password"> <br>
    <input type="submit" value="  ">
</form>
</body>
</html>
在这里插入图片描述
druid.properties 프로필:

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql:///day14
username=root
password=root
#       
initialSize=5
#     
maxActive=10
#      
maxWait=3000
filters=stat
timeBetweenEvictionRunsMillis=60000
minEvictableIdleTimeMillis=300000
validationQuery=SELECT 1
testWhileIdle=true
testOnBorrow=false
testOnReturn=false
poolPreparedStatements=false
maxPoolPreparedStatementPerConnectionSize=200
jar 패키지 가 져 오기:
在这里插入图片描述
네 번 째,두 번 째 단계
在这里插入图片描述
user 클래스 생 성:

package com.wzc.domain;
//      
public class User {
    private int id;
    private String username;
    private String password;
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

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

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}
다섯,세 번 째 단계
jdbcUtils 도구 클래스 만 들 기

package com.wzc.util;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

//JDBC      Druid   
public class JDBCUtils {
    private static DataSource ds ;
    static {
        try {
//                  
            Properties pro = new Properties();
//          ClassLoader      ,       
            InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
            pro.load(is);
//                    
             ds = DruidDataSourceFactory.createDataSource(pro);
        } catch (IOException e) {
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        }
//              
    }
    /*       */
    public static DataSource getDataSource(){
        return ds;
    }
    /*    connection  */
    public static Connection getConnection() throws SQLException {
        return ds.getConnection();
    }

}
UserDao 클래스 를 만 들 고 login 방법 을 제공 합 니 다.

package com.wzc.dao;

import com.wzc.domain.User;
import com.wzc.util.JDBCUtils;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;

//      user   
public class UserDao {
//      JDBCTemplate    
    private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());

    /**
     *     
     * @param loginUser         
     * @return user        ,        null
     */
    public User login(User loginUser){
        try{
            //          sql
            String sql = "select * from user where username = ? and password = ?";
//          query  
            User user = template.queryForObject(sql, new BeanPropertyRowMapper<User>(User.class),
                    loginUser.getUsername(), loginUser.getPassword());
            return user;
        } catch (DataAccessException e){
            e.printStackTrace();
//                
            return null;
        }
        }

}
loginServlet 클래스 작성:

package com.wzc.web.servlet;

import com.wzc.dao.UserDao;
import com.wzc.domain.User;
import org.apache.commons.beanutils.BeanUtils;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.util.Map;

@WebServlet("/loginServlet")
public class LoginServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//           
        req.setCharacterEncoding("utf-8");
/*//             
        String username = req.getParameter("username");
        String password = req.getParameter("password");
//          user  
        User loginUser = new User();
        loginUser.setUsername(username);
        loginUser.setPassword(password);*/
//                
        Map<String,String[]> map = req.getParameterMap();
//          User  
        User loginUser = new User();
//          BeanUtils  
        try {
            BeanUtils.populate(loginUser,map);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            e.printStackTrace();
        }
//          UserDao login  
        UserDao dao = new UserDao();
        User user = dao.login(loginUser);
//          user
        if (user == null){
//                
            req.getRequestDispatcher("/failServlet").forward(req,resp);
        }else{
//                
//                
            req.setAttribute("user",user);
//              
            req.getRequestDispatcher("/successServlet").forward(req,resp);
        }
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doGet(req,resp);
    }
}
여섯,네 번 째 단계
SuccessServlet 클래스 작성:

package com.wzc.web.servlet;

import com.wzc.domain.User;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet(name = "/successServlet")
public class SuccessServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//          request     user  
        User user = (User)request.getAttribute("user");
        if (user !=null){
            //       
//            
            response.setContentType("text/html;charset=utf-8");
//          
            response.getWriter().write("    !"+user.getUsername()+",   ");
        }
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            this.doPost(request,response);
    }
}
FailServelt 클래스 작성

package com.wzc.web.servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet("/failServlet")
public class FailServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//       
//            
        response.setContentType("text/html;charset=utf-8");
//          
        response.getWriter().write("    ,        ");
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            this.doPost(request,response);
    }
}

잘못된 계 정과 비밀 번 호 를 입력 하 십시오.
在这里插入图片描述
로그 인 실패 알림:
在这里插入图片描述
7.총화
login.html 에서 form 폼 의 action 경로 쓰기:가상 경로+Servlet 의 자원 경로
**BeanUtils 도구 류,데이터 패 키 징 간소화:**javaBean 패 키 징 에 사용
javaBean:표준 자바 류 기능:패키지 데이터
네 가지 요구 가 있 습 니 다.
1.클래스 는 Public 에 의 해 수식 되 어야 합 니 다.
2.빈 인삼 의 구조 기 를 제공 해 야 합 니 다.
3.멤버 변 수 는 private 수식 을 사용 해 야 합 니 다.
4.공공 setter 와 getter 방법 제공
속성:setter 와 getter 방법 으로 캡 처 한 결과 물
예:getUsername()C>UsernameC>username
보 이 는 username 은 속성 입 니 다.
방법 은 세 가지 가 있다.
1.setProperty()
2.getProperty()
3.populate(Object obj,Map map):map 집합 키 값 을 정보 에 맞 게 대응 하 는 자바 빈 대상 에 밀봉 합 니 다(가장 많이 사용)

package com.wzc.test;

import com.wzc.domain.User;
import org.apache.commons.beanutils.BeanUtils;
import org.junit.Test;

import java.lang.reflect.InvocationTargetException;

public class BeanUtilsTest {
    @Test
    public void test(){
        User user = new User();
        try {
            BeanUtils.setProperty(user,"hehe","male");
            System.out.println(user);
            String gender = BeanUtils.getProperty(user, "hehe");
            System.out.println(gender);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            e.printStackTrace();
        } catch (NoSuchMethodException e) {
            e.printStackTrace();
        }
    }
}
자바 실전 의 실현 사용자 로그 인 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 자바 실현 사용자 로그 인 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!

좋은 웹페이지 즐겨찾기