“JSP页面提交后,提交的post中文是正常的,但是到达服务器上,中文就乱码”是怎么回事?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了“JSP页面提交后,提交的post中文是正常的,但是到达服务器上,中文就乱码”是怎么回事?相关的知识,希望对你有一定的参考价值。

参考技术A

有以下几种方法可以解决

1.在jsp 的java代码执行之前写入在 <% response.setContentType("text/html;charset=UTF-8")%> 一定要是之前,因为设了这个下面代码才开始生效。可以写在jsp开头。

2.在在Servlet中service方法开始部分写入  response.setContentType("text/html;charset=UTF-8") 

3.在过滤器中写入在Servlet中  response.setContentType("text/html;charset=UTF-8") 一般都写在过滤器中,可以减少代码重复量

4.对于提交已经编码的数据需要先解码再编码,也就是楼主的方法

new String(str.getBytes("ISO8859-1"),"UTF-8") 这种方法可以解决提交时候的问题,

new String(str.getBytes("UTF-8"),"ISO8859-1") 同样的道理解决已经编码的数据要显示到页面的时候就要反着写

还有就是项目中最好使用统一的编码包括:文件保存的时候使用的编码,jsp文件翻译时使用的编码,服务器响应编码,和提交编码,还有就是数据库的编码。

eclipse下:jsp和class文件保存时使用编码在文件右键的property选项中能找到,

jsp页面编码有两个<%@ page language="java" contentType="text/html; charset=UTF-8"

pageEncoding="UTF-8"%>

pageEncoding是设的是tomcat将jsp文件翻译成servlet程序的时候执行的翻译编码,而charset才是服务器响应编码 也就是servlet中的response.setCharacterEncoding 一般都设置成UTF-8;

提交数据的时候也需要你那样转码,不过转码工作却实是写在过滤器里,可以写代码的减少麻烦

提交参数时候要设置request的编码,也就是你遇到的问题,按照我前四步的说明做就可以了。

JSP(全称JavaServer Pages)是由Sun Microsystems公司倡导和许多公司参与共同创建的一种使软件开发者可以响应客户端请求,而动态生成HTML、XML或其他格式文档的Web网页的技术标准。JSP技术是以Java语言作为脚本语言的,JSP网页为整个服务器端的Java库单元提供了一个接口来服务于HTTP的应用程序。用JSP开发的Web应用是跨平台的,既能在Linux下运行,也能在其他操作系统上运行。

建议收藏!!十分钟带你从零学会最最最常用的SQL语句


在这里插入图片描述

1. 前言

很多时候最简单的东西反而是最容易忘的,特别是当我们在学习新的知识的时候,面对老师总结的密密麻麻的知识点,我们总是无能为力。不得不承认,详细的知识点包含常用和不常用的知识,很全面,这是好的,但作为我们随拿随用的知识总结,则需要最精华,最常用,最通俗易懂的知识。因此我总结了以下SQL语句。

2. 数据库和表的操作

2.1. 连接MySQL:

mysql -h主机地址 -P端口 -u用户名 -p密码

2.2. 查看数据库:

show databases;

2.3. 使用数据库:

use 数据库名;

2.4. 查看表:

show tables;

2.5. 建立表:

create table 表名称(字段名1 int not null primary key, 字段名2 char(20) not null);

2.6. 删除表:

drop table 表名称;

3. 表内容的操作(增删查改)

3.1. 插入:

insert into 表名称 values(字段名1,值1),(字段名2,值2);

3.2. 条件查询:

select * from 表名称 where 字段名 < 20;

3.3. 全查询:

select * from 表名称;

3.4. 多表条件查询

select 表名称1.字段名1,表名称1.字段名2,表名称2.字段名3 from 表名称1,表名称2 where 表名称1.字段名1=表名称2.字段名3;

3.5. 删除:

delete from 表名称 where 字段名 = 4;

3.6. 更新:

update 表名称 set 字段名1 =值1 where 字段名2=值2 ;

4. 函数

求和        sum(字段名)
求平均值     avg(字段名)
计数        count(字段名)
求最大值     max(字段名)
求最小值     min(字段名)

这是一个例子:

select sum(字段名) from 表名称;

5. 修饰符

limit 限制查询结果数量

select * from 表名称 limit 5;

order by 排序(默认是升序)

select * from 表名称 order by 字段名;

desc 降序

select * from 表名称 order by 字段名 desc;

asc 升序

select * from 表名称 order by 字段名 asc;

group by 分组

select 字段名1 from 表名称 group by 字段名2;

以上是关于“JSP页面提交后,提交的post中文是正常的,但是到达服务器上,中文就乱码”是怎么回事?的主要内容,如果未能解决你的问题,请参考以下文章