160526: 51회차
종료하기 전 티스토리 네이버 로그아웃 할 것
1. 툴
동일
추가시:
2. 폴더
동일
추가시:
3. 사용할 사이트
동일
추가시:
4. 공부하는 것
- http://spring.io/tools/sts
- 스프링 개발 지원, 메이븐등의 플러그인 내장으로 Controller 개발 지원 편리.
- 개발 라이브러리 자동 지원.
1. 다운로드 및 설치
http://spring.io/tools/sts
spring-tool-suite-3.7.3.RELEASE-e4.5.2-win32-x86_64.zip spring/ sts 폴더에 다운 받아서 여기서 압축풀기로 품
설치 폴더 : javadb/spring/sts/
작업 폴더 : javadb/spring/workspace/
Maven 폴더 : C:/Users/blue/.m2/repository(자동생성)
- 스프링은 의존성 주입(DI : Dependency Injection)을 지원한다.
- 스프링은 확장성이 높다. 스프링 프레임워크에 통합하기 위해 간단하게 기존 라이브러리를
- 객체 사이의 의존관계를 자기 자신이 아닌 외부에 의해서 설정된다는 개념
- DI 컨테이너가 특정클래스가 필요로 하는 인스턴스를 자동으로 생성,
취득하여 연결 시켜주는 역할을 합니다.
- 스프링 컨테이너는 빈 객체를 저장하고 있으며, 각 객체간의 의존 관계를
관리해 줍니다.
1. Constructor Injection
생성자를 통해서 의존관계를 연결시키는 것을 말합니다.
[ Foo.java]
public class Foo{
private Bar bar;
public Foo(Bar bar){
this.bar = bar;
}
-XML 설정파일의 <constructor-arg>요소
생성자를 통해서 의존관계를 설정하기 위해서 XML 설정파일에서
<bean>요소의 하위 요소로<constructor-arg> 를 추가해야 합니다.
<bean id="foo" class="Foo">
<constructor-arg>
<ref bean = "bar"/>
</constructor>
</bean>
<bean id="bar" class="Bar" />
- 전달인자 2개인 생성자에 연결 관계 설정(index 생략가능)
<bean id="foo" class="Foo">
<constructor-arg index="0">
<ref bean = "bar"/>
</constructor>
<constructor-arg index="1">
<ref bean = "bar"/>
</constructor>
</bean>
- 생성자 전달값이 기본형 이거나 String 타입이라면 <ref> 태그 대신
<value>태그를 사용합니다.
<value>의 기본값은 String이며, type으로 파라메터 타입을 설정할
수 있습니다.
<bean id="foo" class="Foo">
<constructor-arg>
<value type="long">10<value>
</constructor>
</bean>
- [주의]<bean> 태그에 생성자와 관련된 정보(<constructor-arg> 태그)를
명시 하지 않으면 스프링은 기본생성자로 객체를 생성함으로,
파라미터가 있는 생성자 를 정의했다면 기본 생성자도 함께
정의해 주어야 합니다.
2. Setter Injection
- 클래스의 의존관계를 연결하기 위해서 setter메소드를 이용하는 방법입니다.
[ Foo.java]
public class Foo{
private Bar b;
Foo(){}//기본생성자(jvm 이 자동으로 만들어줌)
public void setB(Bar bar){
this.b= bar;
}
- <property> 요소를 사용합니다.
<bean id="foo" class="Foo">
<property name="b" ref="bar"> </property>
</bean>
<bean id="bar" class="Bar" />
- XML 네임스페이스를 이용한 프로퍼티 설정
네임스페이스가 "http://www.springframework.org/schema/p"인 접두어를
사용하면 프로퍼티값을 간편히 설정가능 합니다.
p:프로퍼티명="기본타입 데이타"
p:프로퍼티명-ref="빈 객체"
단, 프로퍼티이름이 Ref로 끝나는 경우는 <property>태그로 값 설정해야합니다.
3. static 메서드를 이용해서 싱클톤 패턴이 적용된 클래스
public class ParserFactory{
private static ParserFactory instance = new ParserFactory();
public static ParserFactory getInstance(){
return instance;
}
:
:
}
<bean id="parserFactory" class="www.spring.ParserFactory"
factory-method="getInstance">
4. 필요한 객체를 제공하는 룩업메소드를 구현하는 방식의 룩업 메서드 인젝션
publlic abstract class Processor{
public void process(String commName){
ComFactory factory = getComFactory();
Command command = factory.createComm(commName);
command.excute();
}
//의존 객체를 구할때 사용되는 룩업메소드
protected abstract ComFactory getComFactory();
}
<bean id="process" class="sts.spring.Processor">
<lookup-method name="getComFactory" bean="commFactory"/>
</bean>
<bean id="commFactory" class="sts.spring.ComFactoryImpl"/>
- <lookup-method>의 name속성은 룩업메소드이름,
bean속성은 룩업메소드가 리턴할 빈객체의 식별값을 입력합니다.
- 룩업메소드 규칙
접근제한자 : public, protected
리턴형 : void
매개변수 : 없다
추상메소드 : 가능
final형태 : 아님
- CGLIB 모듈필요(cglib-nodep-2.1.jar)
5. 콜렉션 타입 프로퍼티 설정
- list
객체목록 <ref>태그
래퍼 및 String <value>태그사용
Generic 사용시 type명시안해도 알맛게 변환해줌
<bean name=""................>
<property name="">
<list>
<ref bean =""/>
<ref bean =""/>
<bean class=""/>
</list>
</property>
</bean>
<bean name ="" class=""/>
<bean name="" class=""/>
<bean name=""................>
<property name="">
<list>
<value>0.2</value>
<value>0.3</value>
</list>
</property>
</bean>
<bean name=""................>
<property name="">
<list value-type="java.lang.Double">
<value>0.2</value>
<value>0.3</value>
</list>
</property>
</bean>
<bean name=""................>
<property name="">
<list>
<value type="java.lang.Doublue">0.2</value>
<value type="java.lang.Float">0.3</value>
</list>
</property>
</bean>
- Map
<entry></entry>
Map 저장할 한 개의 <키,값>을 표현한다.
<bean name=""................>
<property name="">
<map>
<entry>
<key><value type="java.lang.Doublue">0.2</value></key>
<ref bean="">
</entry>
<entry>
<key><value>rest</value></key>
<ref bean="">
</entry>
</map>
</property>
</bean>
<map>
<entry key="1" value="1th"/>
<entry key-ref="pro" value-ref="handle"/>
</map>
<map key-type="java.lang.Integer" value-type="java.leng.Doublue">
<entry>
....
</entry>
</map>
- Property
<props></props>태그사용
<bean name=""................>
<property name="">
<props>
<prop key="">....</prop>
<prop key="">....</prop>
</props>
</property>
</bean>
4. DI 패턴 실습 예제 1
Project Type: Spring Project --> Simple Spring Utility Project
Name: diApp1
Package: sts.di.app1
Library: 프로젝트 생성시 관련 Spring 라이브러리가 자동으로 다운로드
됩니다. 작업 컴퓨터는 인터넷에 연결되어 있어야 합니다.
>>>>> di.InterMessage.java
package sts.di.app1;
public interface InterMessage {
void sayHello();
}
>>>>> MessageBean.java
package sts.di.app1;
import java.io.IOException;
public class MessageBean implements InterMessage {
private String name;
private String greeting;
private Outputter outputter;
public void sayHello() {
String message = greeting + name + "!";
System.out.println(message);
try {
outputter.output(message);
} catch(IOException e) {
e.printStackTrace();
}
}
public MessageBean(String name) {
this.name = name;
}
public void setGreeting(String greeting) {
this.greeting = greeting;
}
public void setOutputter(Outputter outputter) {
this.outputter = outputter;
}
}
>>>>> appContext.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"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="messageBean" class="sts.di.app1.MessageBean" >
<constructor-arg>
<value>Spring</value>
</constructor-arg>
<property name="greeting">
<value>Hello, </value>
</property>
</bean>
</beans>
>>>>> HelloApp.java
package sts.di.app1;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
public class HelloApp {
/**
* @param args
*/
public static void main(String[] args) {
// ApplicationContext context = new ClassPathXmlApplicationContext("appContext.xml");
// InterMessage m = (InterMessage)context .getBean("messageBean");
Resource resource =
new ClassPathResource("appContext.xml");
BeanFactory factory = new XmlBeanFactory(resource);
InterMessage m = (InterMessage)factory.getBean("messageBean");
m.sayHello();
}
}
>>>>> Outputter.java
package sts.di.app1;
import java.io.IOException;
public interface Outputter {
void output(String message) throws IOException;
}
>>>>>FileOutputter.java
package sts.di.app1;
import java.io.FileWriter;
import java.io.IOException;
public class FileOutputter implements Outputter {
private String filePath;
public void output(String message) throws IOException {
FileWriter out = new FileWriter(filePath);
out.write(message);
out.close();
}
public void setFilePath(String filePath) {
this.filePath = filePath;
}
}
>>>>> appContext.xml에 추가
:
:
<property name="outputter" ref="outputter">
</property>
</bean>
<bean id="outputter" class="sts.di.app1.FileOutputter" >
<property name="filePath">
<value>out.txt</value>
</property>
</bean>
4. DI 패턴 실습 예제 2
Project Type: Spring Project --> Simple Spring Utility Project
Name: diApp2
Package: sts.di.app2
Library: 프로젝트 생성시 관련 Spring 라이브러리가 자동으로 다운로드
됩니다. 작업 컴퓨터는 인터넷에 연결되어 있어야 합니다.
>> >>> ArticleDTO.java
package sts.di.app2;
public class ArticleDTO {
private String name;
private String title;
private String content;
private String date;
public ArticleDTO() {
super();
// TODO Auto-generated constructor stub
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
public String getDate() {
return date;
}
public void setDate(String date) {
this.date = date;
}
}
>> >>>IArticleDAO.java
package sts.di.app2;
public interface IArticleDAO {
void insert(ArticleDTO article);
}
>>>>>OracleArticleDAO.java
package sts.di.app2;
public class OracleArticleDAO implements IArticleDAO {
public void insert(ArticleDTO article) {
System.out.println("OracleArticleDAO.insert() 실행");
}
}
>>>>> MysqlArticleDAO.java
package sts.di.app2;
public class MysqlArticleDAO implements IArticleDAO {
public void insert(ArticleDTO article) {
System.out.println("MysqlArticleDAO.insert() 실행");
}
}
>>>>> IWriteArticleMgr.java
package sts.di.app2;
public interface IWriteArticleMgr {
public void write(ArticleDTO article);
}
>>>>> WriteArticleMgr.java
package sts.di.app2;
public class WriteArticleMgr implements IWriteArticleMgr {
private IArticleDAO articleDAO;
public WriteArticleMgr(IArticleDAO articleDAO) {
this.articleDAO = articleDAO;
}
public void write(ArticleDTO article) {
System.out.println("WriteArticleServiceImpl.write() 메소드 실행");
articleDAO.insert(article);
}
}
>>>>> TestMain.java
package sts.di.app2;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
public class TestMain {
public static void main(String[] args) {
Resource resource = new ClassPathResource("appContext.xml");
BeanFactory beanFactory = new XmlBeanFactory(resource);
// DI 적용
IWriteArticleMgr articleMgr = (IWriteArticleMgr)beanFactory.getBean("writeArticleMgr");
articleMgr.write(new ArticleDTO());
}
}
>>>>> appContext.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"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean name="writeArticleMgr" class="sts.di.app2.WriteArticleMgr">
<constructor-arg>
<ref bean="articleDAO" />
</constructor-arg>
</bean>
<!-- <bean name="articleDAO" -->
<!-- class="sts.di.app2.MysqlArticleDAO"> -->
<!-- </bean> -->
<bean name="articleDAO"
class="sts.di.app2.OracleArticleDAO">
</bean>
</beans>
생성자 호출시
기본 생성자를 안 만들어놓고 호출하면
오류남 :>
- [주의]<bean> 태그에 생성자와 관련된 정보(<constructor-arg> 태그)를
명시 하지 않으면 스프링은 기본생성자로 객체를 생성함으로,
파라미터가 있는 생성자 를 정의했다면 기본 생성자도 함께
정의해 주어야 합니다.
p:프로퍼티 ="기본 타입 데이터"
멤버변수
p:프로퍼티명-ref="빈 객체"
이거는 오류 날 확률이 좀 있어서 ... 'ㅅ';;
룩업메소드 패스
콜렉션 타입 프로퍼티 설정
리스트
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="messageBean" class="sts.di.app1.MessageBean" >
<constructor-arg>
<value>Spring</value>
</constructor-arg>
<!-- 생성자로 di -->
<property name="greeting">
<value>Hello, </value>
</property>
<!-- setter로 di -->
</bean>
</beans>
[01] 스프링 MVC의 주요 구성 요소
- DispatcherServlet
클라이언트의 요청을 전달받는다. Controller(Action)에게
클라이언트의 요청을 전달하고, 컨트롤러가 리턴한 결과값을
View에 전달하여 알맞은 응답을 생성하도록 합니다.
- HandlerMapping
클라이언트의 요청 URL을 어떤 Controller(Action)가 처리할지를
결정한다. 요청 URL과 Controller클래스의 맵핑을 관리합니다.
- Controller(Action)
클라이언트의 요청을 처리한 뒤, 그 처리 결과를 ModelAndView
에 담아서 DispatcherServlet에 반환합니다.
스트럿츠의 Action과 동일한 역할을 수행한다.
- ModelAndView
Controller(Action)가 모델의 처리한 결과 및 뷰 선택에 필요한 정보를
담는다
- ViewResolver
Controller(Action)의 처리 결과를 생성할 뷰를 결정한다.
View정보가 논리적인 View이름일 경우에는 bean설정 파일에 정의되어
있는 ViewResolver클래스를 이용하여 클라이언트에게 출력할 View
객체를 얻게 됩니다.
- View
Controller(Action)의 처리 결과 화면을 생성합니다.
출력데이터를 설정합니다.
1. Spring의 MVC의 처리 순서
1) 클라이언트의 요청이 DispatcherServlet에게 전달
2) DispatcherServlet은 HandlerMapping을 사용하여 클라이언트의 요청을
처리할 Controller 객체 추출
3) DispatcherServlet은 컨트롤러 객체의 handleRequest()메소드를 호출
하여 클라이언트의 요청을 처리
4) 콘트롤러의 메소드는 처리 결과 정보를 담은 ModelAndView 객체를 리턴
5) DispatcherServlet은 ViewResolver로부터 응답 결과를 생성할 뷰 객체 추출
6) View는 클라이언트에게 전송할 응답을 생성
Spring MVC
2. DispatcherServlet,스프링 컨텍스트 설정 및 한글처리
- 자바 웹어플리케이션 설정파일인 web.xml에 세개의 정보를 설정합니다.
1) 클라이언트의 요청을 전달받을 DispatcherServlet 설정
2) 공통으로 사용할 어플리케이션 컨텍스트 설정
3) 한글처리용 필터 설정
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/spring/root-context.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>appServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>
/WEB-INF/spring/appServlet/dispatcher-servlet.xml
</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>appServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping> // 요기까지는 알아서 해주고
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>
org.springframework.web.filter.CharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list> //이거는 미제가 아니니까 나중에 써줘야함 ㅠㅠ
</web-app>
컨트롤러의 6가지 역할 ^>^
야! 다까먹었당 :>
아 이거 액션이 하는 거구나 (^_^)!
1요청
2요청분석
3모델사용
4리퀘스트에 저장
5결과를 보여줄 뷰페이지 리턴
5자나...?!
액션은 컨트롤러랑 같은 것
아! 뷰가 다양화되면서 view도 resolver가 필요한 것 -.-)
아오 3시 21분인뎅
6시 20분까지
3시간
남았고
발표는 1시간 정도 했으면 조캣당
그러면 2시간 남은 것
아니면 홈페이지^^
리다이렉트나 포워드나 넘나 비슷한 것
글고 디스패처 서블릿이 2개일 경우
설정 파일이 2개(여러개)이지만 - 같이 공통적으로 쓸 수 있는 게 아니라 따로 선언을 해줘야 함
중복되는 경우 - 뭐가 안되고 머리가 아프니까
컨텍스트 - 파람에서 공통으로 쓸거를 적으면 1/2에서 둘 다 접근이 가능하다.
그래서 root-context.xmlㅣ 최상위 인것
<center>
</center>
<center>
</center>
5. 수업
진도:
hw:
6. 할것
으으 아슬아슬하게 안지각...OTL
STS - 웹서버랑 - 문자형식이랑 - 웹브라우저 - 바꿔줄 것
그리고 DB development에서
'Programming' 카테고리의 다른 글
160530: 53회차 (0) | 2016.05.30 |
---|---|
160527: 52회차 (0) | 2016.05.27 |
160525: 50회차 (0) | 2016.05.25 |
160524: 49회차 (0) | 2016.05.24 |
160523: 48회차 (0) | 2016.05.23 |