1부에서 작업한 코드로는 웹 프로젝트를 실행할 수 없습니다.
추가 작업을 하겠습니다.
Java Resources -> src 우클릭 합니다.
Name에 "spring.home.controller"를 입력 후 "Finish"를 누릅니다.
생성된 패키지에 HomeController 클래스를 생성합니다. 그러면 servlet.xml 파일의 에러가 사라집니다.
에러간 난 이유는 <bean>태그에 선언된 class가 존재하지 않기 때문입니다.
이제 HomeController를 코딩해야 합니다.
"@"는 어노테이션이라고 불리며, 위와 같은 아키텍쳐는 Spring MVC RESTful API입니다.
제가 배운 REST는 Spring 3 MVC RESTful API입니다.
설명은 아래와 같습니다.
@Controller : 해당 클래스가 Controller라고 지정합니다.
@RequestMapping : 웹 브라우저의 요청 url을 메소드 단위로 처리하여 해결합니다.
* 아키텍쳐란?
http://blog.naver.com/p1ngp1ng/120064645546
import는 코딩 후에 Ctrl+Shift+O를 누르면 자동으로 됩니다.
ModelAndView 클래스는 서버단에서 view페이지로 request객체를 넘겨줄 때 사용하는 클래스입니다.
생성자의 매개변수로 view페이지 이름을 입력할 수 있습니다.
"home"만 입력된 것은 servlet.xml에서 입력된 ViewResolver 때문입니다.
* InternalResourceViewResolver란?
prefix, suffix를 지정하여 Controller에서 view page로 이동하는 경로를 간편하게 만들어주는 클래스입니다.
view page로 이동시 기본 경로는 WebContent로 지정되어 있습니다.
하지만 WebContent 하위의 view page가 저장이 되면 로그인 등의 절차 후에 접속해야 되는 페이지도 url만 알면 접근이 가능합니다.
WEB-INF 밑에 view page를 생성하면 직접적인 접근을 할 수 없습니다.
new ModelAndView("home");이라고 객체를 생성한다면 실제로 경로는 prefix+"home"+suffix형태가 됩니다.
그래서 실제 경로는 WEB-INF/spring/home.jsp가 됩니다.
이제 home.jsp를 만들겠습니다.
위와 같이 spring 폴더와 home.jsp를 생성합니다.
home.jsp는 위와 같이 코딩합니다.
그리고 프로젝트 우클릭 후 Run As -> Run on Server를 클릭하시면 home.jsp 화면이 웹 페이지에 표시가 됩니다.
위의 화면은 실행된 결과입니다.
프로젝트 실행 시 home.jsp화면이 웹 페이지에 나오는 이유는 web.xml에서 설정한 <welcome-flie-list> 때문입니다.
<welcome-file>home.do</welcome-file>을 지정하면 웹 프로젝트 실행시에 저 경로를 통해 웹 페이지가 보여집니다.
그리고 웹 브라우저에서 톰캣이 실행된 후에 "localhost:8080/프로젝트명/"으로 입력하시면 home.jsp가 실행된 화면이 보입니다.
이상으로 (2)부를 마칩니다.
더 많은 내용을 보시려면 아래를 참고하세요.
블로그의 다른 글
'[개발] 프레임워크 > Spring' 카테고리의 다른 글
maven없이 스프링(Spring) 프로젝트 만들기 (4) - Ajax 설명 (0) | 2017.11.08 |
---|---|
maven없이 스프링(Spring) 프로젝트 만들기 (3) - 디비(DB, Database) 연동하기 #3 (0) | 2017.11.08 |
maven없이 스프링(Spring) 프로젝트 만들기 (3) - 디비(DB, Database) 연동하기 #2 (0) | 2017.11.08 |
maven없이 스프링(Spring) 프로젝트 만들기 (3) - 디비(DB, Database) 연동하기 #1 (0) | 2017.11.07 |
maven없이 스프링(Spring) 프로젝트 만들기 (1) - 프로젝트 생성하기 (0) | 2017.11.06 |