• freemarker 中文乱码问题解决办法


    解决办法一:通过修改配置文件freemarker.properties,修改默认编码:

    locale=zh_CN
    default_encoding=gbk
    number_format=#
    date_format=yyyy-MM-dd
    time_format=HH:mm:Ss
    datetime_format=yyyy-MM-dd HH:mm:Ss


    还有1个办法 在contentType里设置value为text/html;charset=UTF-8"

    <!-- FreeMarker视图解析器 -->
    	<bean id="viewResolver"
    		class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
    		<property name="viewClass"
    			value="org.springframework.web.servlet.view.freemarker.FreeMarkerView" />
    		<property name="contentType" value="text/html;charset=UTF-8" />
    		<property name="cache" value="false" />
    		<property name="viewNames" value="*.ftl" />
    		<property name="suffix" value="" />
    		<property name="order" value="2" />
    	</bean>

    解决办法二:通过spring或其他第三方工具配置:

    <bean id="freemakerCongfig"
    class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
    <property name="templateLoaderPath">
    <value>/WEB-INF/web/</value>
    </property>
    <property name="freemarkerSettings">
    <props>
    <prop key="defaultEncoding">gbk</prop>
    </props>
    </property>

    </bean>

    注:org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer在spring-webmvc.jar包里面,项目要导入这个jar包才可以,或者会找不到类。

    另外,页面编码和charset要跟上面配置的一致才可以,<meta http-equiv="Content-type" content="text/html; charset=gbk">

    注意:还有一种常见的导致乱码问题:编辑器或文件保存的编码和页面设置的编码不一致会导致乱码,例如文件的编码(用记事本打开,另存为可以看到文件的编码)为UTF-8而页面的charset=gbk就会出现乱码,反之也一样。

  • 相关阅读:
    MYSQL索引
    列表里重复次数最多的元素
    python学习笔记
    Spark 扫描 HDFS lzo/gz/orc异常压缩文件
    Yarn RM写ZNode超数据量限制bug修复
    Spark HistoryServer日志解析&清理异常
    【Yarn源码分析】Container启动流程源码分析
    Yarn NodeManager总体架构
    【Yarn源码分析】ApplicationMaster源码分析
    【Yarn源码分析】FairScheduler资源调度
  • 原文地址:https://www.cnblogs.com/zhousiwei/p/10625903.html
Copyright © 2020-2023  润新知