springmvc如何配置html页面的视图解析器

本文探讨了为何现代开发中,纯HTML页面逐渐取代JSP页面成为主流,特别是在SpringMVC框架下。分析了使用HTML模板提高前后端协作效率,以及如何通过配置Freemarker来优化视图解析,提升开发速度。

为什么现在不流行jsp页面,而流行纯html页面?

首先,前端开发人员将开发好的html模板交给后端人员开发,手后端人员要先将html页面转化为jsp页面,此过程容易出错。然后就是jsp页面发布后,解析器要又要将jsp页面转化为html页面,造成效率不高。

pom.xml添加的依赖

<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-core</artifactId>
	    <version>4.3.7.RELEASE</version>
	</dependency>

  <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>4.1.6.RELEASE</version>
    </dependency>
    <dependency>
       <groupId>org.freemarker</groupId>
       <artifactId>freemarker</artifactId>
       <version>2.3.22</version>
    </dependency>

applicationContext-spring.xml中配置freemarkerConfig

    <bean id="freemarkerConfig"
          class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
        <property name="templateLoaderPath" value="/WEB-INF/views/" />
        <property name="freemarkerSettings">
            <props>
                <prop key="template_update_delay">0</prop>
                <prop key="default_encoding">UTF-8</prop>
                <prop key="number_format">0.##########</prop>
                <prop key="datetime_format">yyyy-MM-dd HH:mm:ss</prop>
                <prop key="classic_compatible">true</prop>
                <prop key="template_exception_handler">ignore</prop>
            </props>
        </property>
    </bean>

springmvc-servlet.xml中配置视图解析器

 <!-- 设置freeMarker的配置文件路径 -->
	    <bean id="freemarkerConfiguration"
	          class="org.springframework.beans.factory.config.PropertiesFactoryBean">
	        <!--注释掉的下方代码是指引freemarker的基本信息的配置位置,因为我已经将配置信息移到了applicationContext文件下,所以这里就没必要存在了,不注释也不会有问题的 -->
	        <!--<property name="location" value="classpath:/WEB-INF/config/freemarker.properties" />-->
	    </bean>
    
        <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
        <property name="exposeRequestAttributes" value="true" />
        <property name="exposeSessionAttributes" value="true" />
        <property name="viewClass">
            <value>org.springframework.web.servlet.view.freemarker.FreeMarkerView</value>
        </property>
        <property name="cache"><value>true</value></property>
        <!--这里需要注意一下,我注释了下面这样一行代码,这行代码的意思就是指引freemarker需要解析的文件的位置。注释掉原因是因为
         applicationContext.xml里有这样一行代码:<property name="templateLoaderPath" value="/WEB-INF/views/" /> 已经指定了视图位置。如果我们这里依然保留下方代码,页面回报406的找不到的错误 -->
        <!--<property name="prefix"><value>/WEB-INF/views/</value></property>-->
        <property name="suffix"><value>.html</value></property>
        <property name="contentType">
            <value>text/html; charset=UTF-8</value>
        </property>
    </bean>

注意

配置jsp页面需要用到的视图解析器是org.springframework.web.servlet.view.InternalResourceViewResolver。然而html页面用的是org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver

另外,如果字符编码出错的话,可以在web.xml中配置下字符编码过滤器:

	<!-- 字符编码过滤器 -->
   	<!-- 3、字符编码过滤器,一定要放在所有过滤器之前 -->
   <filter>
   	<filter-name>CharacterEncodingFilter</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>
   	<init-param>
   		<param-name>forceRequestEncoding</param-name>
   		<param-value>true</param-value>
   	</init-param>
   	<init-param>
   		<param-name>forceResponseEncoding</param-name>
   		<param-value>true</param-value>
   	</init-param>
   </filter>
   <filter-mapping>
   	<filter-name>CharacterEncodingFilter</filter-name>
   	<url-pattern>/*</url-pattern>
   </filter-mapping>
### 关于Spring MVC中配置视图解析器的方法 在Spring MVC应用程序中,视图解析器负责将逻辑视图名称映射到实际的物理资源文件。这使得控制器可以返回简单的字符串作为视图名称,而不需要知道具体的面位置或扩展名。 #### 使用`InternalResourceViewResolver` 最常用的内置视图解析器之一是`InternalResourceViewResolver`,它用于处理JSP或其他位于WEB-INF目录下的模板文件。可以通过XML配置或者Java Config方式定义此组件: 通过XML配置如下所示[^2]: ```xml <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> ``` 这段代码指定了所有视图都将被前缀`/WEB-INF/views/`和后缀`.jsp`所包围,意味着如果控制器返回名为`home`的视图,则最终会渲染`/WEB-INF/views/home.jsp`这个文件。 #### Java Config 方式 对于基于注解驱动的应用程序来说,更推荐采用Java Config的方式来进行配置。下面是一个例子: ```java @Configuration @EnableWebMvc public class WebConfig implements WebMvcConfigurer { @Bean public ViewResolver viewResolver() { InternalResourceViewResolver resolver = new InternalResourceViewResolver(); resolver.setPrefix("/WEB-INF/views/"); resolver.setSuffix(".jsp"); return resolver; } } ``` 上述两种方法都可以有效地帮助开发者简化视图管理流程,并提高开发效率。当涉及到更多复杂的场景时,还可以考虑其他类型的视图解析器如Thymeleaf、FreeMarker等。 #### Thymeleaf 视图解析器示例 为了展示如何集成不同的模板引擎,在这里提供了一个使用Thymeleaf的例子。首先需要引入依赖项(如果是Maven项目),接着创建相应的配置类: POM 文件中的依赖声明: ```xml <!-- pom.xml --> <dependency> <groupId>org.thymeleaf</groupId> <artifactId>thymeleaf-spring5</artifactId> <version>${thymeleaf.version}</version> </dependency> ``` 然后编写配置类: ```java @Configuration public class TemplateConfig { @Bean public SpringTemplateEngine templateEngine(TemplateResolver templateResolver){ SpringTemplateEngine engine=new SpringTemplateEngine(); engine.setTemplateResolver(templateResolver); return engine; } @Bean public ITemplateResolver templateResolver(){ ClassLoaderTemplateResolver resolver= new ClassLoaderTemplateResolver(); resolver.setCharacterEncoding("UTF-8"); resolver.setPrefix("/templates/"); resolver.setSuffix(".html"); resolver.setTemplateMode(TemplateMode.HTML); return resolver; } @Bean public ThymeleafViewResolver thymeleafViewResolver(SpringTemplateEngine templateEngine){ ThymeleafViewResolver resolver =new ThymeleafViewResolver(); resolver.setTemplateEngine(templateEngine); resolver.setCharacterEncoding("UTF-8"); return resolver; } } ``` 以上就是有关Spring MVC中配置视图解析器的一些基本介绍以及具体实例说明。希望这些信息能够满足需求并有助于理解该主题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值