티스토리 뷰

Spring

Spring(2)_DB연결&Security

clumsy0g 2019. 12. 12. 15:31

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();
              }

    }

}

  1. pom.xml 관련 모듈 의존설정
  2. spring-security.xml 파일 추가 및 설정
  3. 경로에 따른 controller와 view 페이지 생성 및 매칭
  4. 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>

경로 참고

  1. 뷰인 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를 이용한 인증처리

  1. DB에 테이블 생성
  2. 스프링 시큐리티 설정 spring-security.xml
    • jdbc-user-service 추가하고 dataSource 를 참조시킨다
  3. 컨트롤러 생성 및 jsp 뷰파일 매핑
  4. web.xml
    • securityFilter 추가
    • contextConfigLocation에 spring-security.xml 참조시키기
  5. 뷰인 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
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/04   »
1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30
글 보관함