qq_40619811 2022-01-05 15:42 采纳率: 89.8%
浏览 59
已结题

为什么数据库里的数据输入中文时是乱码啊?要么就是问号,为什么呢?

            request.setCharacterEncoding("utf-8");
            response.setHeader("Content-Type","text/html;charset=UTF-8");
            response.setCharacterEncoding("UTF-8");
            String username=request.getParameter("username");
            String flag=new String(username.getBytes("utf-8"),"ISO-8859-1");
            String password=request.getParameter("password");
            JDBCConnection.connect(flag, password);
            response.sendRedirect("/theta/delta.jsp");

大家好,这是我写的一个Servlet的Post方法,username是用户名,password是密码,flag是username经转换后的结果,目的是将用户名和密码插入到mysql数据库里,mysql里直接插入中文是没有问题的,说明不是数据库的问题,而且jsp页面的代码已经全部改成了utf-8了。
我用的是post方法。
为什么这段代码出来,当用户名是中文时,插入的数据却是乱码?
如果我将字符串username插进去时,数据库显示的却是问号。
如果我将字符串flag插进去时,数据库显示的是一堆乱码。
这是为什么呢?怎么办?我试了很多方法,都不行,怎么办?
提示一下,我用的是MyEclipse,而且用的Tomcat是MyEclipse自带的Tomcat,而且JRE也是MyEclipse自带的,并不是我电脑里的。

  • 写回答

2条回答 默认 最新

  • 日落西风又在吹 2022-01-05 16:10
    关注
    1. 不需要将参数进行编码,按照原始编码即可。
    2. 检查数据库字符配置show create table 表名是否CHARSET=latin1如果是则需要将表编码修改为utf8
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月16日
  • 已采纳回答 1月8日
  • 创建了问题 1月5日

悬赏问题

  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 关于#java#的问题:找一份能快速看完mooc视频的代码
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题