씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

[Spring] security(비밀번호 암호화)
Java 관련/Spring Legecy

[Spring] security(비밀번호 암호화)

2022. 4. 8. 12:56
728x90

우선 mymemberregist.jsp에서 PW 부분 input type="password"로 바꿔주세요!!

			<tr>
				<th>PW</th>
				<td><input type="password" name="memberpw" /></td>
			</tr>

27. pom.xml : spring-security-web

		<!-- spring-security-web -->
		<!-- https://mvnrepository.com/artifact/org.springframework.security/spring-security-web -->
		<dependency>
		    <groupId>org.springframework.security</groupId>
		    <artifactId>spring-security-web</artifactId>
		    <version>${org.springframework-version}</version>
		</dependency>

​

​

28. /WEB-INF/spring/appServlet/security-context.xml (security)

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	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">

	<bean id="bcryptPasswordEncoder" class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder" />

</beans>

​

29. web.xml

​

이제 Controller에서

	@RequestMapping(value="registres.do", method=RequestMethod.POST)
	public String registRes(MYMemberDto dto) {
		logger.info("[Controller] : registres.do");
		
		System.out.println("암호화 전 : " + dto.getMemberpw());
		passwordEncoder.encode(dto.getMemberpw());
		System.out.println("암호화 후 : " + dto.getMemberpw());
		
		if(biz.registRes(dto) > 0) {
			return "redirect:loginform.do";
		}
		return "redirect:registform.do";
	}

registres.do로 이동했을때 암호화를 시키는코드로 수정하면 회원가입 시 password가 암호화 되어있을겁니다.

​

30. mymember-mapper.xml (login에서 'AND MEMBERPW = #{memberpw}' 삭제)

	<select id="login" parameterType="myMemberDto" resultType="myMemberDto">
		SELECT MEMBERNO, MEMBERID, MEMBERPW, MEMBERNAME
		FROM MYNOMEMBER
		WHERE MEMBERID = #{memberid}
	</select>

비밀번호에 대한 조건문이 사라진다면 일단 id가 있는지부터 확인하고 비밀번호에 대한것은

	@RequestMapping(value="/ajaxlogin.do", method=RequestMethod.POST)
	@ResponseBody
	public Map<String, Boolean> ajaxLogin(HttpSession session, @RequestBody MYMemberDto dto){
		logger.info("[Controller] : ajaxlogin.do");
		
		MYMemberDto res = biz.login(dto);
		boolean check = false;
		if(res != null) {
			
			if(passwordEncoder.matches(dto.getMemberpw(), res.getMemberpw())) {
				
				session.setAttribute("login", res);
				check = true;
			} else {
				logger.info("[Controller] : password failed");
			}
			
		}
		
		Map<String, Boolean> map = new HashMap<String, Boolean>();
		map.put("check", check);
		
		return map;
	}

해당 코드에서 db에 저장되어있는 비밀번호와 입력된 비밀번호를 매치시켜서 확인합니다.

728x90

'Java 관련 > Spring Legecy' 카테고리의 다른 글

Spring] update(버전설정 잡기)  (0) 2022.04.10
[Spring] 파일 업로드 / 다운로드(file upload / download)  (0) 2022.04.09
[Spring] transation(트랜잭션 - 원자성)  (0) 2022.04.07
[Spring] Interceptor(인터셉터)  (0) 2022.04.06
[Spring] Login / Regist(로그인 / 회원가입)  (0) 2022.04.05
    'Java 관련/Spring Legecy' 카테고리의 다른 글
    • Spring] update(버전설정 잡기)
    • [Spring] 파일 업로드 / 다운로드(file upload / download)
    • [Spring] transation(트랜잭션 - 원자성)
    • [Spring] Interceptor(인터셉터)
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바