자바 실전 구현 사용자 로그 인
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();
}
}
}
자바 실전 의 실현 사용자 로그 인 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 자바 실현 사용자 로그 인 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.