Spring MVC 多视图协商配置(json、xml、freemarker)

2024-09-03 01:18

本文主要是介绍Spring MVC 多视图协商配置(json、xml、freemarker),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Spring mvc可以配置多种视图,比如json、xml、ftl等等(REST内容协商)。
RESTful服务中很重要的一个特性是对于同一资源,可以有多种表述形式。
既然是协商视图,那么Spring MVC REST改如何决定采用何种方式(视图)展示内容呢?
第一种:根据http request header中的Accept


Accept: text/css,*/*;q=0.1               //返回css格式数据
Accept: application/xml                  //返回xml格式数据
Accept: application/json                 //返回json格式数据
缺点:
chrome:
Accept:application/xml,application/xhtml+xml,textml;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5
 
firefox:
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8


IE8:
Accept:image/gif, image/jpeg, image/pjpeg, image/pjpeg, application/x-shockwave-flash, application/x-silverlight, application/x-ms-application, application/x-ms-xbap, application/vnd.ms-xpsdocument, application/xaml+xml, */*
用户直接通过浏览器访问,由于各个浏览器发送的Accept的不一致,将导致服务器不知要返回什么格式的数据。
第二种:根据扩展名
http://www.sxrczx.com/rest.xml           //将返回xml格式数据
http://www.sxrczx.com/rest.json          //将返回json格式数据
http://www.sxrczx.com/rest.htm           //将返回html格式数据
缺点:
不能统一通过同一URL实现多种展示视图。
第三种:根据format参数
http://www.sxrczx.com/rest?format=xml    //将返回xml格式数据
http://www.sxrczx.com/rest?format=json   //将返回json格式数据
http://www.sxrczx.com/rest?format=htm    //将返回html格式数据
缺点:
需要额外的传递format参数,URL变得冗余,繁琐,缺少了REST的简洁风范。
配置:web.xml,显示Spring的配置文件位置
...
<!-- spring mvc -->
<servlet>
    <servlet-name>SpringMvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
       <param-name>contextConfigLocation</param-name>
         <param-value>/WEB-INF/config/spring/appContext.xml</param-value>
      </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
<servlet-mapping>
    <servlet-name>SpringMvc</servlet-name>
    <url-pattern>*.htm</url-pattern>
    <url-pattern>*.json</url-pattern>
    <!-- <url-pattern>*.xml</url-pattern> -->
</servlet-mapping>
...
==========================================================================================================================
Spring配置appContext.xml(无扩展名(jsp作为视图)/json/xml)
<!-- 根据客户端的不同的请求决定不同的view进行响应, 如 http://www.sxrczx.com/rest.json http://www.sxrczx.com/rest.xml -->
<bean class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">  
<!-- 设置为true以忽略对Accept Header的支持-->
<property name="ignoreAcceptHeader" value="true"/>  
<!-- 在没有扩展名时即: "http://www.sxrczx.com/rest" 时的默认展现形式 -->
<property name="defaultContentType" value="text/html"/>  
<!-- 扩展名至mimeType的映射,即 http://www.sxrczx.com/rest.json 映射为 application/json -->
<property name="mediaTypes">  
<map>  
<entry key="json" value="application/json" />  
<entry key="xml" value="application/xml" />  
</map>  
</property>  
<!-- 用于开启 http://www.sxrczx.com/rest?format=json 的支持 -->
<property name="favorParameter" value="false"/>  
<property name="viewResolvers">  
<list>  
<bean class="org.springframework.web.servlet.view.BeanNameViewResolver" />  
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>  
<property name="prefix" value="/pages"/>  
<property name="suffix" value=".jsp"></property>  
</bean>  
</list>  
</property>  


<property name="defaultViews">  
<list>  
<!-- for application/json -->
<bean class="org.springframework.web.servlet.view.json.MappingJacksonJsonView" />  
<!-- for application/xml -->
<!--   
<bean class="org.springframework.web.servlet.view.xml.MarshallingView" >  
<property name="marshaller">  
<bean class="org.springframework.oxm.xstream.XStreamMarshaller"/>  
</property>  
</bean> 
-->
</list>  
</property>  
</bean>
=======================================================================================================================
Spring配置appContext.xml(freemarker/json)
<bean class="org.springframework.web.servlet.view.ContentNegotiatingViewResolver">
<property name="order" value="1" />
<property name="favorParameter" value="false" />
<property name="ignoreAcceptHeader" value="true" />
<property name="defaultContentType" value="application/json" />
<property name="mediaTypes">
<map>
<entry key="json" value="application/json" />
</map>
</property>
<property name="viewResolvers">
<list>
<!--  配置freemarker作为视图层 -->
<bean id="freeMarkerViewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
<property name="cache" value="true" />
<property name="order" value="0" />
<property name="prefix" value="" />
<property name="suffix" value=".htm" />
<property name="contentType" value="text/html;charset=utf-8" />
<!--  把contextPath暴露给freemaker,前端可以通过${request.getContextPath()} 来获取上下文路径 
<property name="requestContextAttribute" value="request"/>
-->
<property name="viewClass" value="org.springframework.web.servlet.view.freemarker.FreeMarkerView"/>
</bean>
</list>
</property>
<property name="defaultViews">
<list>
<bean class="org.springframework.web.servlet.view.json.MappingJacksonJsonView" />
</list>
</property>
</bean>
     
<!-- Freemarker -->
<bean id="freeMarkerViewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
<property name="cache" value="true" />
<property name="order" value="0" />
<property name="prefix" value="" />
<property name="suffix" value=".htm" />
<property name="contentType" value="text/html;charset=utf-8" />
<!-- 把contextPath暴露给freemaker,前端可以通过¥{request.getContextPath()} 来获取上下文路径 
<property name="requestContextAttribute" value="request"/>
-->
<property name="viewClass" value="org.springframework.web.servlet.view.freemarker.FreeMarkerView" />
</bean>


<!-- ftl参数配置 -->
<bean id="freemarkerConfiguration" class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="location" value="/WEB-INF/config/ftl/freemarker.properties"/>
</bean>
<bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
<property name="defaultEncoding" value="utf-8"/>
<property name="templateLoaderPath" value="/WEB-INF/template"/>
<property name="freemarkerSettings" ref="freemarkerConfiguration"/>
</bean>
freemarker.properties
datetime_format=yyyy-MM-dd HH:mm:ss
date_format=yyyy-MM-dd
time_format=HH:mm:ss
number_format=0.######;
boolean_format=true,false
#auto_import="/common/index.ftl" as ui
whitespace_stripping=true
default_encoding=UTF-8
tag_syntax=square_bracket
url_escaping_charset=UTF-8
#开启默认容错,既null时,默认使用""代替
classic_compatible=true

这篇关于Spring MVC 多视图协商配置(json、xml、freemarker)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131615

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。