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

为什么现在不流行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>
  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1. 首先,在Spring配置文件中添加Thymeleaf依赖: ```xml <dependency> <groupId>org.thymeleaf</groupId> <artifactId>thymeleaf-spring5</artifactId> <version>3.0.11.RELEASE</version> </dependency> ``` 2. 然后,在Spring MVC配置文件中配置Thymeleaf视图解析器: ```xml <!-- 配置Thymeleaf视图解析器 --> <bean id="templateResolver" class="org.thymeleaf.spring5.templateresolver.SpringResourceTemplateResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".html" /> <property name="templateMode" value="HTML" /> </bean> <bean id="templateEngine" class="org.thymeleaf.spring5.SpringTemplateEngine"> <property name="templateResolver" ref="templateResolver" /> <property name="enableSpringELCompiler" value="true" /> </bean> <bean class="org.thymeleaf.spring5.view.ThymeleafViewResolver"> <property name="templateEngine" ref="templateEngine" /> <property name="characterEncoding" value="UTF-8" /> </bean> ``` 在上面的配置中,我们定义了一个Thymeleaf的模板解析器(templateResolver),用于解析模板文件。我们指定了模板文件的前缀和后缀,以及模板文件的类型(HTML)。接着,我们创建一个Thymeleaf的模板引擎(templateEngine),并将模板解析器注入到该引擎中。最后,我们定义了一个Thymeleaf的视图解析器(ThymeleafViewResolver),并将模板引擎注入到该解析器中。 3. 在Controller中返回Thymeleaf视图: ```java @RequestMapping("/hello") public String hello(Model model) { model.addAttribute("name", "Thymeleaf"); return "hello"; } ``` 在上面的Controller中,我们使用Model对象将一个名为“name”的属性值设置为“Thymeleaf”,并将视图名设置为“hello”。由于我们在Spring MVC配置文件中配置了Thymeleaf视图解析器,因此,Spring会自动将该视图解析成“/WEB-INF/views/hello.html”文件,并将模板文件中的变量替换成具体的值,最终生成HTML页面。 4. 在Thymeleaf模板文件中使用变量: ```html <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>Hello Thymeleaf</title> </head> <body> <h1>Hello, <span th:text="${name}"></span>!</h1> </body> </html> ``` 在上面的模板文件中,我们使用了Thymeleaf的语法,在页面中输出了变量“name”的值。在Thymeleaf中,我们可以使用“${变量名}”的语法来输出变量的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值