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日

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?