>Java >java지도 시간 >SpringMVC 뷰와 REST 스타일의 상세 분석(코드 포함)

SpringMVC 뷰와 REST 스타일의 상세 분석(코드 포함)

不言
不言원래의
2018-09-26 15:26:512252검색

이 기사는 SpringMVC 뷰와 REST 스타일(코드 포함)에 대한 자세한 분석을 제공합니다. 이는 특정 참조 가치가 있으므로 도움이 필요한 친구에게 도움이 되기를 바랍니다.

뷰 리졸버란 무엇인가요?

view를 처리하기 위해 springMVC에서 사용하는 가장 중요한 두 가지 인터페이스는 ViewResolver와 View입니다.

ViewResolver의 주요 기능은 논리적 뷰 이름을 실제 뷰로 확인하는 것입니다. View 개체는 View 개체를 클라이언트에 표시하는 데 사용됩니다. .

View 인터페이스의 주요 기능은 뷰를 처리하여 클라이언트에 반환하는 것입니다.

뷰 파서의 실행 프로세스:

요청 메소드가 실행된 후 결국 ModelAndView 객체가 반환됩니다. String, View, ModelMap 등을 반환하는 유형의 경우 SpingMVC는 결국 이를 조합합니다. 모델 객체의 논리적 이름과 뷰를 포함하는 ModelAndView 객체로 내부적으로. StringMVC는 뷰 파서를 사용하여 최종 뷰 객체를 얻습니다. 최종 뷰는 JSP 또는 기타 파일 형식 뷰일 수 있습니다. 렌더링 프로세서는 최종적으로 어떤 방식을 채택할지 신경쓰지 않고 모델 데이터를 생성하는 작업에만 집중하며 항상 MVC의 완전한 디커플링을 달성해 왔습니다.

View:

뷰의 역할은 모델 데이터를 렌더링하고 모델의 데이터를 어떤 형식으로 사용자에게 제공하는 것입니다. 뷰 모델과 특정 구현 기술의 분리를 달성하기 위해 Sping은 뷰 인터페이스를 정의합니다. 뷰 개체는 뷰 확인자에 의해 인스턴스화되며 뷰는 상태 비저장이므로 스레드 안전 문제가 없습니다.

일반적으로 사용되는 뷰 구현 클래스:

InternalResourceView: JSP 리소스를 뷰로 캡슐화하며 기본적으로 springmvc에서 사용하는 뷰 파서입니다.

JstlView: jstl 패키지 springmvc를 JSP 프로젝트에 도입하면 자동으로 이 파서를 사용합니다.

MapingJackJsonView: Jackson 오픈 소스 프레임워크의 ObjectMapper를 통해 Json 모드에서 모델을 출력합니다.

AbstractExcelView: POI를 기반으로 엑셀 문서를 구성하는 엑셀 문서 뷰의 추상 클래스

AbstractPdfVIew: iText를 기반으로 PDF 문서를 구성하는 PDF 문서 뷰의 추상 클래스

BeanNameViewResolver: 논리 뷰 이름을 Bean으로 해석 , Bean ID는 논리적 뷰 이름과 동일합니다.

뷰 리졸버의 역할은 비교적 간단합니다. 모든 뷰 리졸버는 ViewResolver 인터페이스를 구현해야 합니다.

JSP는 가장 일반적으로 사용되는 뷰 기술입니다. InternalResourceView를 뷰 파서로 사용할 수 있습니다.

JSTL 태그가 프로젝트에 도입되는 한 springmvc는 자동으로 InternalResourceView 뷰를 JstlView로 변환합니다. , JstlView는 해당 하위 클래스입니다.

모든 뷰 파서는 Ordered 인터페이스를 구현하고 파서의 우선 순위를 설정할 수 있는 순서 속성을 개발합니다. 봄 MVC는 구문 분석이 성공하고 뷰 객체가 반환될 때까지 뷰 파서 순서의 우선 순위에 따라 논리적 뷰 이름을 구문 분석합니다. 그렇지 않으면 ServletException이 발생합니다

사용자 정의 뷰:

@Component
public class MyView implements View {

    @Override
    public String getContentType() {
        return "text/html";
    }

    @Override
    public void render(Map<String, ?> model, HttpServletRequest request, HttpServletResponse response) throws Exception {
            response.getWriter().println("<h1>Spring MVC Custom view</h1>");
    }

}

이 사용자 정의 뷰 뷰를 구현해야 합니다. 그런 다음 인터페이스는 인터페이스의 두 가지 메서드를 재정의합니다. 그런 다음 이 클래스를 Bean으로 선언하고 관리를 위해 스프링에 넘겨줍니다. 여기서는 beanName 확인자를 구성합니다.

<!-- 配置BeanName解析器 -->
    <bean id="beanNameViewResolver" class="org.springframework.web.servlet.view.BeanNameViewResolver">
        <property name="order" value="1"/>
    </bean>

그런 다음 요청을 작성하세요. 이 요청은 기본적으로 첫 번째 문자가 소문자이며 카멜 케이스로 표시됩니다.

@RequestMapping("myView")    public String myView(){
        System.out.println("myView load ...");        
        return "myView";
    }

이로 사용자 정의 보기가 완성됩니다.

닫기 및 리디렉션:

반환 문자열에 "redirect:" 또는 "forward:"이 포함되어 있으면 SpringMvc가 특수 처리를 수행합니다.

뷰에 직접 액세스해야 하는 경우 다음과 같이 구성할 수 있습니다

<!– 直接配置对应的视图访问路径 -->
<mvc:view-controller path="/hello" view-name="hello.jsp" />
<!-- 如果配置了mvc-controller会导致其它页面没法正常访问,还需要添加一个标签 -->
<mvc:annotation-driven />

REST Chapter

REST(Representational State Transfer): 즉, (리소스) 프레젠테이션 계층 상태 이전.
리소스: 네트워크의 개체 또는 네트워크의 정보입니다. 텍스트, 노래, 사진 등이 될 수 있습니다. URL을 사용하여 이를 가리킬 수 있습니다. 각 리소스에는 특정 고유 URL이 있습니다. 이 리소스에 액세스하려면 URI에 직접 액세스하면 됩니다.
표현 레이어: 리소스가 표시되는 형식입니다.
상태 전송: 요청이 발행될 때마다 클라이언트와 서버 간의 상호 작용을 나타냅니다. HTTP 프로토콜은 상태 비저장 프로토콜입니다. 즉, 모든 상태가 서버 측에 저장됩니다. 클라이언트가 서버를 작동하려면 어떤 수단을 사용하여 서버가 상태 변환을 거쳐야 하며 이 변환은 프리젠테이션 계층을 기반으로 하므로 프리젠테이션 계층 상태 변환입니다.

在我们的SpringMVC之中支持HTTP四种请求状态,REST规定的HTTP协议中四种表示操作方式的动词

GET请求:获取资源

POST请求:新建资源

PUT:更新资源

DELETE:删除资源

我们需要在WEB.xml中配置实现PUT,DELETE请求方式,大家都知道在我们传统的HTML中只有GET,POST两种请求方式。

<!-- 配置HiddenHttpMethodFilter过滤器实现PUT,DELETE请求 -->
<filter>
    <filter-name>HiddenHttpMethodFilter</filter-name>
    <filter-class>
        org.springframework.web.filter.HiddenHttpMethodFilter
    </filter-class>
</filter>
<filter-mapping>
    <filter-name>HiddenHttpMethodFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

GET请求

GET请求:
<a href="rest/testRest/10">test RestGet请求</a><br><br>

@RequestMapping(value="/testRest/{id}",method=RequestMethod.GET)
public String testRestGet(@PathVariable Integer id){
    System.out.println("GET请求,获取id为:" + id + "的对象!");
    return SUCCESS;
}

Post请求

POST请求:
<form action="rest/testRest" method="post">
    <input type="submit" value="post请求" />
</form>

@RequestMapping(value="/testRest",method=RequestMethod.POST)
public String testRestPost(){
    System.out.println("POST请求,添加新的对象!");
    return SUCCESS;
}

PUT和DELETE请求想要使用必须添加上面的过滤器,并且在Post请求中加上隐藏域name="_method",value="PUT/DELETE"。

PUT,请求其实是由POST请求转换而来的。

PUT请求:
<form action="rest/testRest" method="post">
    <!-- 添加隐藏域,名称为_method,value为请求方式 -->
    <input type="hidden" name="_method" value="PUT" />
    <input type="submit" value="put请求" />
</form>

@RequestMapping(value="/testRest",method=RequestMethod.PUT)
public String testRestPut(){
    System.out.println("PUT请求,更新操作!");
    return SUCCESS;
}

DELETE请求

DELETE请求:
<form action="rest/testRest/10000" method="post">
    <!-- 添加隐藏域,名称为_method,value为请求方式 -->
    <input type="hidden" name="_method" value="DELETE" />
    <input type="submit" value="delete请求" />
</form>

@RequestMapping(value="/testRest/{id}",method=RequestMethod.DELETE)
public String testRestDelete(@PathVariable Integer id){
    System.out.println("DELETE请求,删除操作!" + id);
    return SUCCESS;
}

重复一次第一章的内容在我们springmvc拦截所有请求会导致css,js,图片等不能引入我们可以这样解决:

<!--将非mapping配置下的请求交给默认的Servlet来处理-->
<mvc:default-servlet-handler/>
<!--如果添加了默认servlet,mvc请求将无效,需要添加annotation-driven-->
<mvc:annotation-driven></mvc:annotation-driven>

위 내용은 SpringMVC 뷰와 REST 스타일의 상세 분석(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.