java web自学的难点,javaweb学习遇到的问题

更改MySQL数据库的编码为utf8mb4

创建表格设置表格的编码为utf8mb4,示例:

create table student(NO char(20),name varchar(20),primary key(NO))ENGINE=InnoDB DEFAULT CHARSET=utf8mb4

Eclipse创建web在tomcat上不能发布

Javaweb开发中响应乱码和请求乱码

解决方法:

//=======================

//tomcat6,7默认编码为iso8859-1

//========================

1.post请求

/*

* 这个方法只对请求的实体内容起作用,因GET提交的请求参数在地址

* 栏 后,并不在实体内容中,所以这个方法对于GET提交无效

*/

request.setCharacterEncoding("utf-8");

//设置编码后,通过该方法取参数

request.getParameter("key");

2.get请求

/*

服务器用iso8859-1来解析,造成了乱码,由于iso8859-1无法正确

显示这些字符,所以显示为了“?”,但是底层的编码仍然是正确的。所

以,我们可以通过如下方式解决:

*/

addr=request.getParameter("key");

byte[] bs = addr.getBytes(“iso8859-1”);//将乱码解析回二进制数据

addr = new String(bs,”utf-8”);//按照正确的utf-8解码得到正确的字符

//*******************************************

备注:当我们通过request.getInputStream()或request.getReader()方

法获取参数时,由于表单提交的参数都会先进行UrlEncoding编码,所以

在获取时,要进行UrlEncode解码 。而且以上两个方法只能获取到请求

的实体的内容,所以对get请求是无用的。

//以下示例代码是在post请求下测试的,有效

String line;

BufferedReader reader=request.getReader();

while((line=reader.readLine())!=null){

System.out.println(URLDecoder.decode(line));

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值