jsp页面向action传值乱码的问题

本文介绍了如何避免在jsp页面向action传递中文值时出现乱码的情况。通过在页面设置编码以及数据库连接字符串配置,可以确保中文数据在传输和存储过程中不出现乱码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        JSP页面向action传值时中文乱码的问题,记得以前做项目的时候出现过,后来我到网上搜索了一系列的资料,把所有别人说要加的条件都加上去,稀里糊涂就解决了。最近做一个项目,又遇到这个问题,我决定试一试究竟需要注意哪几点就可以解决乱码的问题。下面是我的结论。
        1> 在页面首行<%@ page langusge=”java” import=”java.util.*” pageEncoding=”UTF-8”>
        2> 将此句加上<meta http-equiv=”Content-Type” content=”text/html; charset=UTF-8” />。这句的意思是文档类型为html,  我试过,如果这句不加,有时候没问题,有时候只要打开这个页面,上面的中文直接乱码,还没等到传值给action。

        只要在页面上加上上面两条,传值给action是没有中文乱码的问题的。而且我在web.xml特意将

<filter>
		<filter-name>Spring character encoding filter</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>
	</filter>
	<filter-mapping>
		<filter-name>Spring character encoding filter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>


        注释掉,依然没有乱码。网上有人说还需要在struts.xml中加上<constantname=”struts.i18n.encoding” value=”UTF-8”></constant>,我试过将此句注释,也没有乱码的问题。

        如果要将数据存入MySql数据库,保证存入的中文没有问题,那么需要在数据库连接字符串里这样写

<property name="connection.url">jdbc:mysql://localhost:3306/数据库名?useUnicode=true&amp;characterEncoding=UTF-8

         如果你的MySql默认的字符编码就是utf8,那么这个链接字符串后面的?useUnicode=true&amp;characterEncoding=UTF-8也可以不写。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值