기본 콘텐츠로 건너뛰기

[ JAVA ] Spring Framework 설정하기.

  대표적인 프레임워크인 Spring Framework 을 자바환경에서 설정하는 방법을 정리해 보도록 한다. 실제로 구성해 본 적이 없기 때문에 자바 개발 초보의 입장에서 진행하도록 한다.

  가장 먼저 할 작업은 이클립스를 설치하는 것이다. 이 글을 쓰는 시점에는 Eclipse Kepler JEE 버전을 사용하고 있다. 그러나 여러 가지 프로젝트를 구성하려고 한다면 JEE 버전의 이클립스를 사용하는 것이 좋다. 물론 다른 버전이라도 상관이 없을 듯 하다. (단지, 지원되지 않는 프로젝트 템플릿이 있다면 추가로 설정해야 하고 필요한 것들을 설치해야 하는 수고가 따른다. 근데 버전이 굉장히 많구나… -_-) 설치가 다 되어 환경 설정이 끝난 상태라면 이클립스를 실행하도록 한다.


Install Spring IDE Plugin


  실행된 이클립스에서 아래와 같이 새로운 소프트웨어 설치 메뉴를 실행하도록 한다.




  아래와 같이 열린 "설치" 다이얼로그 화면에서 "Work with" 항목에 있는 "Add" 버튼을 누른다. 다른 옵션들은 별도로 변경하지 않는다.




  열린 "Add Repository" 다이얼로그 화면에서 아래와 같이 Name 과 Location 값을 입력한다.


  "OK" 버튼을 누르면 지정한 정보에 속하는 활용 가능한 플러그인 목록이 보여지게 된다. 아래와 같이 기본적인 선택을 하도록 한다. (Integrations / Spring IDE, Uncategorized 를 선택하지 않는 이유는 선행 설치가 필요한 다른 플러그인을 요구하며, 현재로서는 그다지 큰 필요가 없기 때문이다. 향후에 다시 설치가 가능하다)




  "Next" 버튼을 누르면 아래의 그림과 같이 설치될 내용이 보여지게 된다.




  위의 설치 목록을 보면 "Will not be installed" 와 "Will be installed" 로 구분되어 표시되는 것을 볼 수 있다. 지금은 몇 가지 설치가 불가능한 대상이 있지만, 그대로 진행하도록 한다. "Next" 버튼을 눌러서 진행하도록 한다.




  설치가 가능한 목록들로만 정리된 내용이 다시 보이게 되므로 "Next" 버튼을 눌러서 계속 진행하도록 한다.




  마지막으로 위의 그림과 같이 라이센스에 대한 문구와 수용 여부를 묻는 창이 나타난다. 라이센스를 수용하는 것으로 설정하고 "Finish" 버튼을 눌러 계속 진행한다. 아래의 그림과 같이 설치를 위한 프로그램들을 다운로드 하는 것을 확인할 수 있다.




  설치 중간에 아래의 그림과 같이 "보안 경고" 창이 나올 수도 있다. 이런 경우는 설치와 관련된 경고를 하는 내용이므로 "OK" 버튼을 눌러서 진행하도록 한다. (내용은 서명되지 않은 내용이 포함된 소프트웨어를 설치하는데 인증 또는 유효성을 확인할 수 없다는 것이다. 마치 ActiveX 설치할 때 물어보는 것과 같다)




  설치가 완료되면 이클립스를 재 시작할 것인지를 물어보는 창이 뜬다. "Yes" 버튼을 눌러서 다시 시작하도록 한다.




  잠시 후에 이클립스가 다시 시작되면 "Help > About Eclipse" 메뉴를 실행하도록 한다. 그럼 아래의 그림과 같이 설치된 프로그램에 대한 정보를 확인할 수 있다.




  "Installation Details" 버튼을 눌러서 상세 보기를 하고 "Installed Software" 탭을 보면 Spring IDE 관련 플러그인들이 설치된 것을 확인할 수 있다.




  아까 위에서 언급했던 것과 같이 설치 과정 중에서 어떤 문제가 발생해서 설치가 불안하다면 다시 재 설치 또는 추가 설치를 하려고 할 때 "이미 등록된 주소입니다" 라는 메시지와 함께 설치를 할 수 없는 상황이 생길 수 있다. 이런 경우는 이클립스에서 플러그인 설치에 관련된 정보를 지워주면 다시 설치가 가능하다.


  "Windows > Preferences" 메뉴를 실행한다. 이미 Overview 화면에 Spring IDE, SpringSource Tool Suite Overview" 등 관련된 링크가 생성된 것을 확인할 수 있다.




  실행된 화면의 좌측에 있는 Tree 구성에서 "Install/Update" > "Available Software Sites" 를 선택하면 우측 화면에 설치된 프로그램의 목록이 나타난다. 설치가 제대로 수행되지 않은 항목이 있다면 선택을 하고 "Remove" 버튼을 눌러서 삭제할 수 있다.




  이렇게 해서 기본적인 프로그램 (플러그인) 설치 방법을 알아 보았다.


Sample Project (Dynamic Web Project)


  웹 프로젝트는 Standard 버전에서는 보이지 않는다. 여러 가지 유형의 프로젝트를 구성하는 경우라면 기본적으로 JEE 버전의 이클립스를 사용하도록 한다. 여기서 부터는 JEE 버전의 이클립스를 사용하는 것으로 설명한다.


  처음 이클립스를 실행하면 "Welcome" 페이지 때문에 프로젝트 탐색기가 보이지 않는다. Welcome 창을 최소화 하면 된다. 그래도 보이지 않으면 아래와 같이 선택하면 된다.




  간단하게 Spring Framework 플러그인을 사용해 보기 위해서 간단한 샘플을 구성해 보도록 하자. 이클립스의 프로젝트 탐색기 (Project Explorer) 의 빈 공간에서 마우스 우측버튼을 누르고 "New" > "Project" 를 선택하도록 한다.




  열린 프로젝트 선택 창에서 "Dynamic Web Project (동적 웹 프로젝트)" 를 선택하도록 한다. 프로젝트 관련 설정 창이 열린 것을 확인할 수 있다. 단, 웹 프로젝트를 사용하는 것이기 때문에 기본적으로 사용할 웹 런타임이 필요하다. 아래의 그림과 같이 Apache Tomcat v7.0 버전을 설치하도록 한다.





  위와 같이 처리하면 화면 상에는 별도로 보이는 것이 없지만 이클립스의 오른쪽 하단에 설치가 되고 있는 것을 확인할 수 있다. 설치가 완료될 때까지 기다리도록 한다.


  이제 아래와 같이 기본 설정된 Tomcat 정보를 기준으로 필요한 내용을 설정하고 "Next" 버튼을 눌러서 계속 진행하도록 한다.


  빌드 경로 상에 존재하는 소스 폴더에 대한 설정을 처리하는 창이 보이지만, 특별히 소스의 경로를 변경하거나 빌드의 출력 경로를 변경할 것이 없다면 "Next" 버튼을 눌러서 계속 진행한다.


  웹 모듈 설정 창에서는 설정 파일이 반드시 필요한 것이기 때문에 선택하고 "Finish" 버튼을 누르도록 한다.


  잠시 프로젝트 구성이 진행되고 나면 아래의 그림과 같이 프로젝트 탐색기에 프로젝트가 생성되어 있는 것을 확인할 수 있다.



  프로젝트 구조가 완성되었으므로 Spring Framework 을 사용할 환경을 설정하여야 한다. "SpringWebSample" 프로젝트를 선택하고 마우스 우측 버튼을 눌러서 "Spring Tools > Add Spring Project Nature" 를 선택하도록 한다.




  아래의 그림과 같이 프로젝트 명칭에 작은 "S" 표시가 되고 프로젝트 구성 목록에 "Spring Elements" 항목이 추가된 것을 확인할 수 있다.




  웹 환경 설정을 수정해야 하는 부분이 있으므로 프로젝트 탐색기에서 "WebContent > WEB-INF > web.xml" 파일을 더블클릭 한다. 그러면 오른쪽의 소스 창에 관련된 소스가 보여진다.




  기본적으로 web.xml 파일은 위의 그림에서 오른쪽에 보이는 것과 같이 편집이 쉽도록 XML 구성 편집기로 보여진다. 물론 파일을 열 때 연결된 에디터를 변경해서 순수 XML 파일 편집기로도 열 수 있다.


  우선 오른쪽의 소스 창에서 id 항목에 "WebApp_ID" 라는 부분 웹 어플리케이션을 식별하기 위한 아이디 역할을 담당하므로 프로젝트 이름인 "SpringWebSample" 로 변경하도록 한다.


  그리고 아래쪽의 "welcome-file-list" 는 웹 어플리케이션 사이트에 접속을 했을 때 보여질 파일들의 리스트를 설정한 것으로 이 파일들 중에 하나만 있으면 표시된다. 만일 중복해서 파일들이 존재하는 경우는 우선 순위에 따라서 첫 번째 파일로 보여진다. 여기서는 index.jsp 하나만 남기로 모두 삭제하도록 한다. (삭제는 welcome-file-list 를 선택하면 오른쪽에 "Outline" 창이 보이므로 거기서 마우스 우측버튼에서 "Remove" 를 선택하거나 소스 창에서 해당 항목을 선택하고 마우스 우측번튼에서 "Remove"를 선택하여 삭제하면 된다. 당연히 다중 선택도 가능하다)




  기본 실행 설정이 되었으므로 웹 어플리케이션에 접속했을 때 보여질 index.jsp 파일을 작성하면 된다.  루트 경로 (중요한 부분이지만 WebContent 항목이 실제 웹 어플리케이션 사이트의 루트 경로가 된다) 에서 마우스 우측 버튼을 눌러서 "New > JSP File" 을 선택하도록 한다.




  파일 설정 창에서 이름을 index.jsp 라고 지정하고 "Next" 버튼을 눌러서 진행한다.




  JSP 템플릿을 선택하는 창이 나타나는데 여기서는 단순한 샘플을 구성할 것이기 때문에 기본 값을 그대로 사용하도록 한다. "Finish" 버튼을 눌러서 파일을 생성하도록 한다.




  생성된 index.jsp 파일의 태그 사이에 아무 것이나 브라우저로 접근했을 때 보여질 문장으로 추가하도록 한다.


  이제 실행을 위해서 웹 어플리케이션을 WAR (Web Application ARchive) 파일로 만들고 실제 톰캣이 실행되는 위치로 배포를 해야 한다.  "SpringWebSample" 프로젝트를 선택하고 마우스 우측 버튼에서 "Export > WAR File" 을 선택하도록 한다.




  WAR 파일이 저장될 위치를 지정하기 위해서 Export 설정 창에서 "Browse" 버튼을 누르고 대상 경로를 설정하도록 한다. 이 때 이미 배포되었던 파일이 있을 수 있다면 "Overwrite existing file" 항목을 선택하도록 한다.




  WAR 파일이 위치해야 할 경로는 Tomcat 이 실행되고 있는 경로 밑의 "webapps" 폴더 아래가 된다. 이 경로를 설정하도록 한다.




  "저장" 버튼을 눌러 파일을 저장하고 "Finish" 버튼을 누른 후에 Tomcat 의 webapps 폴더 밑으로 "SpringWebSample" 이라는 이름의 폴더가 생기로 웹 어플리케이션이 추가된 것을 확인할 수 있다. (물론 Tomcat 이 실행되고 있다는 가정하에서 그렇다는 것이다. 톰캣의 설정에 대한 것은 이전 게시글을 참고하도록 한다.




  실행된 내용은 다음과 같다. WAR 로 배포된 SpringWebSample은 가상 폴더처럼 URL 상의 서브 폴더가 되어 서비스가 된다.



  이렇게 해서 기본적으로 Spring Framework 을 이클립스에서 사용하기 위한 환경은 설정이 된 것이다. 즉, 이클립스에서 외부 라이브러리 (여기서는 Spring Framework)를 더 쉽게 사용하기 위해서 필요한 플러그인을 적용한 것이다. 다시 말하면 연결 고리만 설정을 한 것이지 실제 Spring Framework 을 설치한 것은 아니라는 것이다.

Spring Framework 설정

  가장 먼저 해야할 작업은 스프링 프레임워크 공식 사이트에서 스프링 프레임워크를 다운로드 하는 것이다.



  "Quick Start" 버튼을 누르면 "Download" 가 보이는 위치로 이동하게 된다. 이글을 작성하고 있는 시점의 최종 버전은 "4.0.2" 버전이다.



  이 방식은 Maven 이나 Gradle 을 이용해서 현재 작업 중인 프로젝트에 Spring Framework을 추가하는 방식이고 매뉴얼로 다운로드 하기 위해서는 여기를 통해서 Zip 파일 형태로 받을 수가 있다.  다운로드한 파일을 압축 해제하면 다음과 같이 폴더가 생성된다.



  libs 폴더에는 많은 *.jar 파일들이 존재한다. 실제 이 파일들을 사용하면 된다. 다시 이클립스로 돌아와서 프로젝트 탐색기에서 "SpringWebSample > WEB-INF > lib" 폴더를 선택하고 마우스 우측 버튼의 "Import" 를 선택한다.



  이제 가져올 외부 라이브러리를 선택할 수 있는 "Import" 창에서 "General > File System" 을 선택하고 "Next" 버튼을 누른다.



  "File System" 창에서 "Browse" 버튼을 누르고 Spring Framework이 존재하는 경로를 설정하면 경로에 존재하는 모든 jar 파일들의 리스트가 보이고 왼쪽의 "libs" 체크를 하여 모두 선택되도록 하고 "Finish" 버튼을 누른다.


  이제 이클립스의 "WEB-INF/lib" 폴더에 스프링 프레임워크의 *.jar 파일들이 추가된 것을 확인할 수 있다. 물론 Ctrl + C / V 를 이용해서 처리하는 것도 가능하다.


  스프링 프레임워크를 제대로 사용하기 위해서는 종속 라이브러리 2개가 필요하다. "JSTL" 과 "Common Logging" 라이브러리다. 이 두 라이브러리가 없는 경우는 JSP 처리 중에 오류가 발생하게 된다.


  두 라이브러리를 다운로드하고 압축을 해제한 후에 각 jar 를 스프링 프레임워크 라이브러리를 추가한 것과 같이 추가하도록 한다.


  이제 스프링 프레임워크 라이브러리를 추가했으니 실제 사용하는 법을 알아보도록 한다. 샘플은 스프링 프레임워크를 이용한 컨트롤 역할을 수행하는 클래스 (Spring Controller Class) 를 만들어 보는 것이다. 기본적인 구조는 Controller Bean 하나와 이 컨트롤러에 연동되는 JSP 파일 하나다.

  자바에서는 라이브러리의 기본 단위가 *.jar 이므로 여기서도 패키지를 만들어 보도록 한다. 이클립스에서 "SpringWebSample" 프로젝트 밑의 "Java Resource > src" 를 선택하고 마우스 우측 버튼의 "new > Package" 를 선택하도록 한다.


  "New Java Package" 창에서 이름은 원하는 이름을 지정하도록 한다. (샘플에서는 net.msfl.controller 라고  지정) 그리고 "Finish" 버튼을 누른다.


  이제 "src" 폴더 밑에 빈 "net.msfl.controller" 패키지가 생성된 것을 확인할 수 있다.


  이제 이 패키지에 Controller 역할을 담당할 클래스를 추가하면 된다. net.msfl.controller 패키지를 선택하고 마우스 우측 버튼의 "New > Class" 를 선택한다.


  "New Java Class" 창에서 이름을 "SpringWebSampleController" 로 지정하고 "Finish" 버튼을 누른다.


  이제 생성된 기본 클래스를 이클립스의 빈 팩키지 아래에서 확인할 수 있다.


  이제 아래와 같이 클래스의 소스에 필요한 스프링 프레임워크의 개체 정보를 Import 하도록 한다.


  위의 import 는 스프링 프레임워크에서 제공하는 MVC 패턴을 운영하기 위한 기본 정보라고 생각하면 된다. 이제 아래와 같이 클래스의 골격과 내부 루틴을 작성하도록 한다.


  위의 코드는 스프링 프레임워크에서 인식할 수 있도록 Annotation을 이용한 것으로 아래의 내용을 이해하여야 한다.

  • @Controller - 클래스의 선언 앞에 @Controller 표기는 스프링 프레임워크에게 이 클래스가 Controller 형태의 Bean 임을 알리는 역할을 담당한다.
  • @RequestMapping - @RequestMapping("/spring") 표기는 브라우저에 입력되는 URL 에 "/spring" 으로 시작되는 모든 요청에 대해서 이 클래스에서 해당 메서드가 호출되어야 한다는 것을 스프링 프레임워크에세 알리는 역할을 담당한다.
  • springWebSample() - 이 메서드는 ModelAndVie 개체를 반환하는데 반환되는데 사용하는 ModelAndView 개체는 "spring" 이라는 이름으로 지정된 View 를 찾도록 해 주고, 데이터 모델(모델 이름은 "message" 이고, 데이터는 message 변수에 설정된 값)이 View 로 전달되어 사용할 수 있도록 처리를 해 주는 것이다.

  이제 컨트롤러를 생성하였으므로 JSP 파일을 만들면 된다. 참고로 스프링 프레임워크를 이용하는 JSP 파일은 외부로 부터 접근을 할 수 없는 위치에 존재해야 한다. 일반적으로 사용하는 방법은 WEB-INF 폴더 밑에 위치시키는 것이다. SpringWebSample 밑의 "WebContent/WEB-INF" 를 선택하고 마우스 우측 버튼의 "New > Folder" 를 선택한다.


  "New Folder" 창에서 이름을 "jsp" 라고 지정하고 "Finish" 버튼을 누른다.


  생성된 "jsp" 폴더를 선택하고 마우스 우측 버튼에서 "New > JSP File" 을 선택한다.


  "New JSP File" 창에서 이름을 "spring.jsp" 라고 지정하고 "Finish" 버튼을 누른다. ("Next" 를 눌렀을 때 나오는 JSP 템플릿은 현재는 기본 값을 그대로 사용하는 것이다)


  추가된 spring.jsp 파일을 아래와 같이 소스를 수정하도록 한다.


  위의 코드는 Controller 의 처리에 의해서 "spring" 정보로 대상 View 인 "spring.jsp" 가 선택이 되면 전달되는 데이터 모델 (message) 를 JSP 파일 내에서 사용하는 것을 의미한다. 즉, 전달된 메시지 문자열을 그대로 출력한다는 의미가 된다.

  이제 위에서 만들었던 "index.jsp" 소스를 열고 아래와 같이 수정하여 Controller 가 동작할 수 있도록 링크를 추가해 주도록 한다.


  위의 코드는 일반적이지만 URL 링크 부분의 파일을 "spring.jsp" 가 아니라 "spring.fdt" 라는 이상한 확장자를 지정하였다. 스프링 프레임워크에서는 확장자 처리 매핑을 지원하고 또한 컨트롤러를 구동 시키기위해서 연결하는 설정이 필요하기 때문에 임의로 지정한 것이다.

  매핑 설정은 SpringWebSample 프로젝트 밑의 "WebContent/WEB-INF/web.xml" 파일에 존재한다. 파일을 열면 "" 태그만 존재한다. 따라서 태그 아래에 다음과 같이 Servlet 과 Servlet-mapping 설정을 추가해 주도록 한다.


  위의 내용을 번역해 보면 *.fdt 형식(패턴)을 가지는 모든 요청은 스프링 프레임워크의 DispatchServlet 으로 매핑이 된다는 의미가 된다. 여기서 중요한 부분은 태그로 이 이름을 기준으로 웹 서버가 구동될 때 DispatchServlet 이 로딩되면서 웹 어플리케이션의 하위에 있는 WEB-INF 폴더에서 지정된 이름의 servlet 설정 파일을 찾는다는 것이다. 위의 샘플 기준이라면 spring-servlet.xml 파일을 찾게 된다. 따라서 추가로 이 Servlet 설정 파일을 추가해 주어야 한다.

  "SpringWebSample" 프로젝트 밑에 있는 "WebContent/WEB-INF" 를 선택하고 마우스 우측 버튼의 "New > Other" 를 선택하도록 한다.


  "Select a wizard" 창에서 "XML > XML File" 을 선택하고 "Next" 버튼을 누른다.


  "New XML File" 설정 창에서 파일 이름을 "spring-servlet.xml" 으로 설정하고 "Finish" 버튼을 누른다.


  이클립스에 생성된 "spring-servlet.xml" 파일을 열어서 아래와 같은 내용으로 설정한다.


  위의 파일은 스프링 프레임워크에 대해서 요청을 처리할 때 Controller 를 어떻게 찾을 것인지 (Compoent-Scan) 와 Controller 에서 View 를 어떻게 연계할 것인지 (ViewResolver) 를 설정하는 파일이다. 하나씩 내용을 확인해 보도록 하자.

  • - 이 태그는 net.msfl.controller 패키지 및 그 하위 패키지들에 존재하는 모듈들을 검색하여 로드하라는 의미가 된다. (위에서 Controller 클래스 작성했을 때 사용하였던 @Controller Annotation 을 가진 클래스들)
  • - 이 태그는 "viewResolver" 라는 이름을 가지는 Bean 의 역할을 정의한 것으로 하위에 지정된 태그의 정보를 기준으로 Controller 에서 반환되는 ModelAndView 정보를 가지고 View 를 찾는 물리적인 경로를 구성하라는 의미가 된다.
  위의 설정을 기준으로 ModelAndView 정보를 기준으로 물리적인 View 의 위치를 조립해 보도록 하자. 우선 Controller 에서 반환되는 ModelAndView 는 "spring"  이라는 파라미터가 지정되었다. 그리고 위의 설정 파일에서 태그를 통해서 prefix 는 "/WEB-INF/jsp/" 고, suffix 는 ".jsp" 인 것을 알고 있다. 따라서 이를 연결하면 다음과 같은 경로의 View 가 나오게 된다.


 + Prefix + ModelAndView + suffix == /WEB-INF/jsp/spring.jsp



  이제 작성한 웹 어플리케이션을 배포 (WAR 배포) 한 후에 브라우저에서 실행을 해 보면 아래와 같은 결과가 나오게 된다.


  수정한 index.jsp 파일의 링크를 눌러서 제대로  Controller 가 동작하고 View 가 처리되는지를 확인해 보도록 한다. 정상적으로 배포가 되었다면 아래와 같이 출력이 된다.


  밋밋하게 글을 따라서 구성을 하다보면 너무 쉽게 접근하는 것이 되기 때문에 위의 내용을 그대로 따라해도 제대로 되지 않도록 지뢰를 심어 놓았다. 스프링 프레임워크는 기본적으로 환경 설정에 의존해서 동작을 하기 때문에 설정을 명확하게 이해하는 과정이 필요하다. 따라서 위의 샘플은 거의 대부분 동작하는 것이지만 지뢰를 해결해야 결과를 볼 수 있을 것이다.

  또 하나의 힌트는 나중에 Controller 처리 때문에 거의 문제가 해결되지 않을 것이다. 즉, 설정이 제대로 인식되지 못하고 오류가 발생하는 상황이 존재하는데, 스프링 프레임워크는 계속적으로 버전이 향상되고 있기 때문에 어떤 문제가 있지 않다면 특정 버전에 한정하도록 할 필요가 없다는 것이다. 오류를 구글에서 검색해 보면 쉽게 찾을 수 있다.

  이해를 위한 숙제와 같은 지뢰이므로 찾아서 이해하고 수정해서 결과를 볼 수 있도록 한다. 당연히 힌트를 준다면 톰캣의 로그 파일을 명확하게 확인해 보라는 것이다. ^^

===== 2014.07.16 추가.

숙제를 묻는 분들이 계셔서 허접하지만 테스트했던 프로젝트를 첨부합니다 "여기"에서 확인해 보시기 랍니다.

===== 2014.12.17 추가

많은 분들이 똑같이 작업을 했으나 404 등의 오류가 발생하는 경우가 많다는 댓글들이 많았습니다. 최근 댓글들 중에서 "wooseok Bok" 님이 관련된 관련된 오류를 해결하시고, 설정을 댓글에 올려 놓은 부분이 있으니 참고하시고 해결을 해 보시기 바랍니다. 아래는 "wooseok Bok" 님이 올려주신 내용입니다.

────spring-servlet.xml────


http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:beans="http://www.springframework.org/schema/beans"
xmlns:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/mvc 
   http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context 
http://www.springframework.org/schema/context/spring-context.xsd">





class = "org.springframework.web.servlet.view.UrlBasedViewResolver">









────web.xml────


http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
id="SpringWebSample" 
version="3.0">
  
  SpringWebSample
 
    index.jsp
 

 
  contextConfigLocation
  /WEB-INF/*-servlet.xml
 
 
  spring
  org.springframework.web.servlet.DispatcherServlet
 
  contextConfigLocation
  /WEB-INF/*-servlet.xml
 
  1  
 
  
 
  spring
  *.fdt
 




────SpringWebSampleController.java────

package net.msfl.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

@Controller
public class SpringWebSampleController {
@RequestMapping("/spring.fdt")
public ModelAndView springWebSample(){
String message = "First sample with the Spring Framework!";
return new ModelAndView("spring", "message", message);
}
}

다양한 프로젝트 구성에 따라서 여러 가지 환경적인 설정이 연관되어 있습니다. 저도 초보라 문의에 제대로 답변을 못해드린 것이 많을 수 있으나 여러 분들의 관심과 해결 방법을 댓글로 올려주시고 같이 해결해 나가는 방식을 취할 수 있어서 제게도 많은 도움이 되고 있습니다. ^^ 

관심을 주신 모든 분들께 감사드립니다.
2014년 마무리 잘 하시고, 2015년에도 좋은 한해가 되기길 기원합니다.

댓글

  1. 좋은 글 잘 봤습니다. 아직 초보라 Spring MVC로 프로젝트를 설정하면 자동설정으로 인해(Maven 등..) 오히려 불편한점이 많았는데
    Dynamic Web Project에 Spring Project Nature 적용하니 훨씬 깔끔해졌네요 감사합니다.

    답글삭제
    답글
    1. 도움이 되었다니 다행이네요. ^^
      저도 자바쪽은 초보다 보니.. 좋은 하루 되세요.

      삭제
  2. 자바입문자로서 좋은글 잘봤습니다.
    근데 함정을 찾으려고해도 찾을수가 없네요
    어디에있는거죠?

    답글삭제
  3. 자바초보로서 유익한글 잘봤네요
    근데 함정을 찾을수가 없어서요
    어디가 문제인지 아무리 찾아봐도 제실력으론 나오질 안네요
    도움부탁드립니다.

    답글삭제
    답글
    1. 도움이 되셨다니 다행이네요. ^^
      함정이라는 것은 다른 것은 아니구요. Tomcat 에서 실행을 해 보시면 오류가 나올 겁니다.
      그 오류를 해결해야 하는 것이지요. ^^
      그리고 버전 문제로 컨트롤러가 연결되지 않는 문제는 파일의 xmlns 설정 부분에 존재하는 특정 버전 번호 정보를 제거하시면 됩니다.

      그럼 오늘도 좋은 하루 되세요...

      삭제
  4. 안녕하세요 ! 자세한 설명덕에 좋은 정보 잘 보고 있습니다.
    다름이 아니라 따라하던중..검토를 해도 ㅠㅠ..잘 찾아지지 않아 도움을 요청드립니다.
    spring-servlet.xml 을 작성하던 중 난 에러입니다












    답글삭제
  5. 안녕하세요. 도움이 된다니 다행입니다.
    위에 다른 분에게 답변을 달아놓은 것처럼, 특정 버전을 지정했을 때 나는 오류입니다.
    xmlns 설정 부분에 버전 정보를 제거해서 범용(?)으로 처리하시면 해결이 될 것입니다.

    제가 사용했던 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:context="http://www.springframework.org/schema/context"
    xmlns:tx="http://www.springframework.org/schema/tx"
    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
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx.xsd
    http://www.springframework.org/schema/context
    http://www.springframework.org/schema/context/spring-context.xsd">

    <context:component-scan base-package="net.msfl.controller" />

    <bean id="viewResolver"
    class="org.springframework.web.servlet.view.UrlBasedViewResolver">
    <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />
    <property name="prefix" value="/WEB-INF/jsp/" />
    <property name="suffix" value=".jsp" />
    </bean>
    </beans>

    보시는 것과 같이 xmlns 부분에 버전 (3.0 이라고 지정되어 있던) 을 제거한 것입니다.

    왜 이런 오류가 나는지를 파악하고 싶으시면 XML 관련해서 XSD 와 xmlns 에 대한 내용들을 검토해 보시면 됩니다. 결론적으로는 XSD 에 정의되지 않은 것을 사용하면 찾을 수 없다고 나온다고 생각하시면 됩니다. ^^

    답글삭제
  6. 안녕하세요 ! 저번에 댓글에서 알려주신 사항대로 버전을 삭제해보았는데,,도통 풀리질 않아 다시 문의드립니다 (예전댓글이 왜 안보일까요 ㅠㅠ?)

    오류내용: cannot find declaration of elements beans
    => beans는 제일 마지막줄에 잘 있는거같은데..왜이러나 모르겠습니다....

    spring버전은 4.0.6 으로 쓰고있고 eclipse버전은 luna입니다.











    답글삭제
    답글
    1. 안녕하세요. 아직도 해결이 되지 않으셨군요. ㅠㅠ

      예전 댓글은 제가 구플(Google+) 와 댓글 공유를 설정했더니 보이지 않아서 다시 원복했습니다. ^^

      알려주신 것과 같이 Spring 4.0.6, Eclipse luna 로 맞춰서 해 보아도 저는 잘 동작을 합니다.
      현재 사용중인 JDK 는 jdk1.7.0_65 버전이구요.

      혹시 몰라서 제가 작업한 프로젝트를 압축해서 원문의 제일 아래에 등록하도록 하겠습니다.
      받으셔서 직접 작업하신 부분과 어떤 부분이 다른지를 확인해 보시면 될 듯 합니다.

      거의 대부분의 경력이 .NET 기반이었고 Java 는 저도 초보라서 제대로 도움이 될지 모르겠네요. ㅠㅠ
      그럼 오늘도 좋은 하루 되시구요.. ^^ 홧팅입니다.

      삭제
  7. 덕분에 스프링 구조와 개념에 대한 좋은 실습이 되었습니다.
    4.0.6과 루나에서도 동일한 문제점이 발생해서 버젼제거로 해결이 가능했는데
    다만 수정후 톰캣에서 reflash 될때 까지 약간의 시간텀이 발생하더군요.
    원인은 모르겠지만 xml의 내용이 반영되는 텀이 약간은 필요한 것 같습니다.
    제가 사용한 jdk는 1.8 버젼입니다.

    답글삭제
    답글
    1. 도움이 되셨다니 다행입니다. ^^
      Tomcat Refresh에 Term이 발생한다는 부분에 대한 의견 감사드립니다.
      나중에 시간이 될지는 모르겠지만 검토해 보도록 하겠습니다.
      그럼 오늘도 좋은 하루 되세요.,,

      삭제
  8. http://localhost:8080/SpringWebSample/spring.fdt
    index.jsp에서 a태그 누르면 저 주소로 이동되는데 http status 404 에러가 나네요...ㅠㅠ
    코드는 다 똑같이 썼고 에러도 없는데 어디가 문제인지 못찾겠네요ㅜㅜ
    좋은 글 감사드립니다.

    답글삭제
  9. http://localhost:8080/SpringWebSample/spring.fdt
    index.jsp에서 a태그 누르면 저 주소로 이동되는데 http status 404 에러가 나네요...ㅠㅠ
    코드는 다 똑같이 썼고 에러도 없는데 어디가 문제인지 못찾겠네요ㅜㅜ
    좋은 글 감사드립니다.

    답글삭제
    답글
    1. 안녕하세요. 서동진님.

      웹 어플리케이션의 일반적인 처리 흐름은 Request 수신 -> Controller (Mapped Method) -> View Resolver -> JSP Parsing -> Response 출력 (HTTP Response Stream) 입니다. (자세한 부분은 구글 검색해 보시면 Lifecycle 관련해서 많은 자료들이 존재합니다)

      따라서 404가 발생한다는 의미는 두 가지로 해석할 수 있습니다. 첫 번째는 Mapping 된 Controller Method를 못찾은 경우로 이 경우에는 Request mapping 부분을 확인해 보셔야 합니다. 두 번째는 Controller Method는 실행이 되었는데 View Resolver에서 처리할 View (JSP) 를 찾지 못한 경우입니다.

      SpringWebSampleController.java 에 @RequestMapping("spring") 이 제대로 설정되어 있는지를 확인하시고, 해당 Method에서 반환하고 있는 ModelAndView("spring", "message", message) 에 정의된 "spring" 이 WebContent\WEB-INF\jsp\spring.jsp 파일이 존재하는지를 확인해 보셔야 합니다.

      만일 위의 Controller Method Mapping 설정도 맞고, JSP 파일도 존재한다면 아마도 설정 파일들 (web.xml, spring-servlet.xml)을 면밀하게 다시 검토해 보셔야 할 듯 합니다.

      그리고 본문 가장 아래쪽에 제가 실제 사용했던 샘플이 있습니다. 다운로드 하셔서 Eclipse에 올려 테스트를 해 보시고, 정상적으로 동작한다면 작업하신 소스와 비교해 보셔도 될 듯 합니다.

      답변이 도움이 될지 모르겠습니다.
      그럼 오늘도 좋은 하루 되시기 바랍니다.

      삭제

댓글 쓰기

이 블로그의 인기 게시물

OData 에 대해서 알아보자.

얼마 전에 어떤 회사에 인터뷰를 하러 간 적이 있었다. 당시 그 회사는 자체 솔루션을 개발할 기술인력을 찾고 있었고 내부적으로 OData를 사용한다고 했다. 좀 창피한 이야기일 수도 있지만 나름 기술적인 부분에서는 많은 정보를 가지고 있다고 했던 것이 무색하게 OData란 단어를 그 회사 사장님에게서 처음 들었다. 작고, 단순한 사이트들만을 계속해서 작업을 하다 보니 어느덧 큰 줄기들을 잃어버린 것을 느끼기 시작했다. 명색이 개발이 좋고, 기술적인 기반을 만들려고 하는 인간이 단어조차도 모른다는 것은 있을 수 없는 것이라서 다시 새로운 단어들과 개념들을 알아보는 시간을 가지려고 한다. OData (Open Data Protocol) 란? 간단히 정리하면 웹 상에서 손쉽게 데이터를 조회하거나 수정할 수 있도록 주고 받는 웹(프로토콜)을 말한다. 서비스 제공자 입장에서는 웹으로 데이터를 제공하는 방식으로 각 포탈 사이트들이 제공하는 OPEN API 포맷을 독자적인 형식이 아니라 오픈된 공통규약으로 제공 가능하며, 개발자는 이 정보를 다양한 언어의 클라이언트 라이브러리로 어플리케이션에서 소비할 수 있도록 사용하면 된다. 공식 사이트는 www.odata.org 이며 많은 언어들을 지원하고 있다. 좀더 상세하게 정의를 해 보면 OData는 Atom Publishing Protocol  (RFC4287) 의 확장 형식이고 REST (REpresentational State Transfer) Protocol 이다. 따라서 웹 브라우저에서 OData 서비스로 노출된 데이터를 볼 수 있다. 그리고 AtomPub 의 확장이라고 했듯이 데이터의 조회만으로 한정되는 것이 아니라 CRUD 작업이 모두 가능하다. Example 웹 브라우저에서 http://services.odata.org/website/odata.svc 를 열어 보도록 하자. This XML file does not appear to have any style in...

C# 에서 Timer 사용할 때 주의할 점.

예전에 알고 지내시던 분의 질문을 받았다. Windows Forms 개발을 하는데, 주기적 (대략 1분)으로 데이터 요청을 하는 프로그램을 작성하기 위해서 Timer 를 사용하는데, 어떤 기능을 처리해야 하기 때문에 Sleep 을 같이 사용했다고 한다. 여기서 발생하는 문제는 Sleep 5초를 주었더니, Timer 까지 5초 동안 멈춘다는 것이다. Timer 라는 것은 기본적으로 시간의 흐름을 측정하는 기능이기 때문에 Sleep 을 했다고 해서 Timer 가 멈추는 일은 생겨서는 안된다. 그러나 실제 샘플을 만들어 보면 ... Timer 가 Sleep 만큼 동작이 멈추는 것을 확인할 수 있다. Windows Forms 는 UI Thread 를 사용하는 것으로 최적화 되어 있으며 여기서 Timer 를 쓰면 UI Thread 에 최적화된 System.Windows.Forms.Timer 가 사용된다. 여기서 문제의 발생이 시작되는 것이다. Sleep 을 사용하게 되면 UI Thread 가 Sleep 이 걸리기 때문에 여기에 속한 Timer 까지도 멈추는 것이다. 이런 문제를 해결하기 위해서는 System.Threading.Timer 를 사용해야 한다. 이 Timer 는 별도의 Thread 에서 동작하기 때문에 Sleep 의 영향을 받지 않는다. 언뜻 보면 쉬운 해결 방법인 것 같지만 Thread 가 분리되었기 때문에 Timer 가 돌아가는 Thread 에서 UI Thread 의 메서드나 컨트롤에 접근하기 위해서는 별도의 명령을 사용해야 하는 문제가 존재한다. 자~ 그럼 여기서 Timer 에 대해서 다시 한번 정리해 보도록 하자. .NET 에서 제공하는 Timer 들 .NET 에서는 기본적으로 3가지 Timer를 제공하고 있다. (MSDN) System.Windows.Forms.Timer - 사용자가 지정한 간격마다 이벤트를 발생시키며 Windows Forms 응용 프로그램에서 사용할 수 있도록 최적화 되어 있다. System...

[Logging] NLog 사용법 정리...

SCSF 에는 기본적으로 Enterprise Library가 사용된다. 예전에도 그랬지만 기능은 훌륭하고 많은 부분에서 최적화(?)된 것일지도 모르지만, 역시나 사용하기에는 뭔가 모르게 무겁고, 사용하지 않는 기능이 더 많다라는 느낌을 지울수가 없다. 이번 프로젝트도 SCSF를 기반으로 하고 있지만, Enterprise Library를 걷어내고 각 부분에 전문화된 오픈 소스를 사용하기로 하였다. 예전에는 Log4Net을 사용했지만, 대량 사용자 환경에서는 메모리 누수와 기타 문제점이 존재한다는 MS 컨설턴트(?)의 전해진 말을 들은 후로는 사용하지 않는다. 대안으로 사용하는 것이 NLog 이다. 조금 후에는 3.0 버전도 나온다고 홈 페이지에 기재되어 있지만, 그 때가 되면 프로젝트는 끝나기 때문에 현재 2.1.0 버전을 사용하기로 했다. [원본 출처] http://cloverink.net/most-useful-nlog-configurations-closed/ 위의 참조 자료에는 다양한 정보들이 존재하므로 꼭 링크를 통해서 관련된 정보를 확인하고 이해하는 것이 좋을 듯 하다. 여기서는 당장 필요한 부분만을 정리하도록 한다. [ Logger 찾기 ] 기본적으로 Logger가 존재하는 클래스를 기반으로 Logger 정보를 구성한다. Logger logger = LogManager.GetCurrentClassLogger(); 주로 Namespace 기반으로 Logger를 설정하는 경우에 유연하게 사용할 수 있다. 또 다른 방법으로는 지정한 문자열로 특정 Logger를 직접 선택하는 방법도 제공된다. 이를 혼용해서 Namespace와 직접 지정 방식을 같이 사용할 수도 있다. 물론 Logger 환경 설정에서 Wildcard (*)를 지정할 수도 있다. Logger logger = LogManager.GetLogger("Database.Connect"); Logger logger = LogManager.Get...