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 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同