티스토리 뷰
pom.xml
<!-- mybatis 3.1.1 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.1.1</version>
</dependency>
<!-- mybatis-spring 1.1.1 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.1.1</version>
</dependency>
<!-- Spring-JDBC -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<!-- PostgreSQL -->
<!-- https://mvnrepository.com/artifact/org.postgresql/postgresql -->
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>42.2.5</version>
</dependency>
root-context.xml
<?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 https://www.springframework.org/schema/beans/spring-beans.xsd">
<!-- Root Context: defines shared resources visible to all other web components -->
<!-- properties -->
<bean
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations" value="classpath:/jdbc.properties" />
<property name="fileEncoding" value="UTF-8" />
</bean>
<!-- JDBC-PostgreSQL -->
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName"
value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
<!-- MyBatis-Spring -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:mybatis-config.xml" />
<property name="dataSource" ref="dataSource" />
</bean>
<!-- <property name="mapperLocations" value="classpath:/mappers/*.xml" /> -->
<bean id="sqlSession" name="sqlSession"
class="org.mybatis.spring.SqlSessionTemplate"
destroy-method="clearCache">
<constructor-arg name="sqlSessionFactory"
ref="sqlSessionFactory" />
</bean>
</beans>
SqlSessionFactoryBean은 sql문을 관리하는 하나의 공장을 만드는 것.
mapper를 어디서 읽어올지도 설정한다. ( 하나하나 설정하는 것이 번거로우므로.
일단 주석처리 해둔다. 나중에 생성할것이므로. 파일 생성안한 상태에서 저렇게 해두면 서버스타트할때 오류난다)
( classpath 란 src/main/java, src/main/resource 경로를 의미한다.
확인 방법은 링크 참고 : https://f10024.tistory.com/3 )
resources에 mybatis-config.xml / jdbc.properties 생성
jdbc.properties
jdbc.driverClassName=org.postgresql.Driver
#jdbc.url=jdbc:postgresql://127.0.0.1:5432/ktd_db
jdbc.url=jdbc:postgresql://192.168.0.78:5432/ktd_db
#jdbc.url=jdbc:postgresql://61.32.6.18:55432/ktd_db
jdbc.username=ktd
jdbc.password=ktd
mybatis-config.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
</configuration>
위의 세줄을 적어야 해당 파일로서 기능할수 있다.
mybatis-config.xml에서는 주로 두가지를 설정한다.
properties
mybatis에서 사용할 컬럼과 테이블명을 (name) 실제 DB의 컬럼과 테이블명(value)으로 매칭되도록 정의할 수 있다. 이는 나중에 sql문을 정의할때 사용된다.
예를 들어,
라고 정의한 경우,
mapper의 sql문에서는
SELECT * FROM ${tblMember}
로 사용될 수 있다.
- typeAliaes
자바타입에 사용할 이름을 정하는 것. ( aliaes )
alias와 java type을 매칭시켜주면 되는데, 크게 두가지 방식이 있다.
첫번째는, 하나하나 지정해주는 방법.
<typeAlias alias="Author" type="domain.blog.Author"/>
두번째는, java type (java파일. 즉 class) 가 있는 위치만 지정한뒤, 해당 class 파일에서 alias 애노테이션을 주는 방법이다.
<typeAliases>
<package name="domain.blog"/>
</typeAliases>
@Alias("author")
public class Author {
...
}
( 참고 : https://mybatis.org/mybatis-3/configuration.html )\
JDBC test
데이터베이스에 잘 연결되었는지 확인. junit을 이용하면 Server를 실행시키지 않고도 java파일을 테스트 할 수 있다.
src/test/java 에 junit 파일을 생성 후 아래와 같이 코딩
package com.yjjo.app;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import org.junit.Test;
public class JDBCTest {
@Test
public void test() {
String driver = "org.postgresql.Driver";
String url = "jdbc:postgresql://192.168.0.78:5432/ktd_db";
String id = "ktd";
String pw = "ktd";
Connection conn = null;
try {
Class.forName(driver);
conn = DriverManager.getConnection(url, id, pw);
System.out.println("데이터 베이스에 정상적으로 접속했습니다");
conn.close();
} catch (ClassNotFoundException e) {
System.out.println("해당 클래스를 찾을 수 없습니다");
e.printStackTrace();
} catch (SQLException e) {
System.out.println(e.getMessage());
e.printStackTrace();
}
}
}
- pom.xml 관련 모듈 의존설정
- spring-security.xml 파일 추가 및 설정
- 경로에 따른 controller와 view 페이지 생성 및 매칭
- web.xml
- securityFilter 추가
- contextConfigLocation에 spring-security.xml 참조시키기
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/root-context.xml</param-value>
<param-value>classpath:/spring-security.xml</param-value>
</context-param>
경로 참고
뷰인 jsp 페이지에서 security 태그로 코딩
tag lib 추가
<%@ taglib prefix="sec" uri="http://www.springframework.org/security/tags"%>
authorize 태그 : access에 명시된 권한
(로그인 authenticated 했는지 or 특정 권한 role ) 이 있을때에만 보여지는 태그
<sec:authorize access="isAuthenticated()"> <sec:authentication property="name"/>님 환영합니다. </sec:authorize>
로그아웃 클릭시 로그아웃 처리 후 디폴트로 루트경로 (/) 로 리다이렉트
5
5.2 DB를 이용한 인증처리
- DB에 테이블 생성
- 스프링 시큐리티 설정 spring-security.xml
- jdbc-user-service 추가하고 dataSource 를 참조시킨다
- 컨트롤러 생성 및 jsp 뷰파일 매핑
- web.xml
- securityFilter 추가
- contextConfigLocation에 spring-security.xml 참조시키기
- 뷰인 jsp 페이지에서 security 태그로 코딩
junit test - src/main/java 폴더 missing
'Spring' 카테고리의 다른 글
[기타 팁] Ajax 요청시 data에 String을 쓰면 안된다? (0) | 2019.12.18 |
---|---|
Spring(5)_MVC(2)_Ajax&JSON (0) | 2019.12.12 |
Spring(4)_Interceptor (0) | 2019.12.12 |
Spring(3)_DB연결(2)&MVC (0) | 2019.12.12 |
Spring(1)_설정파일 (0) | 2019.12.12 |