您现在的位置是: 首页 > 个人博客 > 关于查询或者添加中文乱码问题 个人博客
关于查询或者添加中文乱码问题
2019-6-03 18:18:28
【工具】2060人已围观
简介 如果你的项目在使用过程中:1.遇到输入中文无法查询(有记录,但是查询无结果)2.添加中文,保存之后页面显示乱码(比如号?????乱码)。 请检查如下两个配置,并作修改: 1.检查数据库链接地址,是否有如下标红配置,没有请加上,示例: jdbc.driver=com.mysq......
如果你的项目在使用过程中:
1.遇到输入中文无法查询(有记录,但是查询无结果)
2.添加中文,保存之后页面显示乱码(比如号?????乱码)。
请检查如下两个配置,并作修改:
1.检查数据库链接地址,是否有如下标红配置,没有请加上,示例:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/driving?useUnicode=true&characterEncoding=UTF-8
jdbc.user=root
jdbc.password=root
以上配置可以在数据库配置文件中找到,比如.properties文件,有的是直接写在代码中。具体改动点在程序包中的详细配置文件中会有说明。
2.检查tomcat配置,找到apache-tomcat-7.0.70\conf\server.xml文件,如果不存在如下标红配置,请加上。
<Connector URIEncoding="UTF-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
注意:是8080端口的这个,添加完成之后,请重启tomcat;tomcat重启之后,该配置会被刷掉,所有要不时的检查改配置是否存在。
3.如果以上两种方法还没有解决问题, 那就可能就是数据库编码问题了。
参考如下解决方法:http://www.xiaoniucr.com/article/view/12.html
注意:一般第三种情况可以直接解决问题。
Tags: 乱码
上一篇: jdk详细安装步骤图解
随机图文
Java毕业设计选题分享
毕业设计,大学的最后一道坎。 对于这道坎,说难也难,毕竟很多同学在大学期间没有系统的学习过如何去开发一套系统;说不难其实也不难,毕竟一个毕设,不可能像公司企业级开发一样,要求太复杂的技术,所以一般只要掌握一些开发基础和技巧,是可以独立完成一套设计的。 毕业设计,首先是选题,也就是大家说的开题,这是关键。一般来说,一个同学都是独立完成一个课题,当然也有团队开发的,即几个同学共同分工完成一个课题,这个除外。使用java语言做毕业设计,可选性还是比较多的。 比如通常的一些后台管理系统,比如酒店管理系统、学籍管理系统、图书管理系统等等,这是都偏后台的一些管理系统,功能和页面布局也比较简单,一般菜单+表格就可以完成了,如果对毕设要求不高的同学可以选择这一类的系统。 如果在想将系统或者网站做的花哨一点,除了后台管理外,我们还可以做个前台界面。比如商城,前台是商品展示,用户挑选商品加入购物车,后台主要是商品管理、订单管理等。或者新闻网站,前台主要针对用户新闻浏览器,收藏,点赞等,后台主要是管理进行新闻类比、新闻的管理。前后台的系统不但功能会显得多一点,网站页面也会内容丰富饱满一点。 当然如果你还想将毕设做的更好一点,拿个高分或者整个优秀毕业设计啥的,你就需要在系统中整合一些比较新颖的功能,也就是你的系统有什么亮点?比如商城,你可以整合个性化推荐,加个协同过滤推荐算法。新闻网站你可以加个爬虫,抓取其他网站的新闻为己使用,然后再整合个推荐算法,个性化推荐用户比较感兴趣的新闻。除此之外,这些年,随着移动网页、大数据、机器学习、深度学习等快速发展,你也可以选择这一方面的课题。 题目选好之后,接下来就是技术定型了,开发这个系统你准备使用哪些技术?前后台分别什么框架?后台有:纯jsp,简单一点的servlet框架,稍微难点的ssh(struts2+spring+hibernate),目前比较流行的ssm(springmvc+spring+mybatis),springboot,springcloud等框架。前台页面有H5、Vue、Angularjs、React、JQuery等,大家可以根据自己的需要,选择自己比较喜欢或者擅长的。 总的来说,适合自己的就是好的,也不要一味的去追求高难度,毕竟贪多嚼不烂这点想必大家都清楚。 最后我这里列出一些毕业设计选题,方便大家参考。 Servlet框架: SpringBoot框架: SSH框架: SSM框架: 其他框架整合: 最新定制项目: 以下是课程设计:javase+sqlserver部署项目教程
很多刚接触编程的同学,还不清楚如何使用eclipse部署javase+sqlserver项目,这里作一个简单的介绍:##软件安装1.jdk配置 首先安装好jdk,我一般使用1.8版本的jdk。配置好JDK环境变量。 jdk下载,包含jdk1.7和jdk1.8,32位(i586)和64位(x64),请看清楚再下载,下载地址如下: 百度网盘下载链接:https://pan.baidu.com/s/1O2eHQ83LB4SmDI7ivTKApA 提取码:0cdj 或者官网下载: jdk1.7下载,下载需要登录oracle账户,地址如下: https://www.oracle.com/technetwork/java/javase/downloads/java-archive-downloads-javase7-521261.html jdk1.8下载,地址如下 https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 安装参考文档如下: http://www.xiaoniucr.com/article/view/9.html2.安装eclipse 我一般使用mar2版本。请自行选择32位或者64位下载。 百度网盘下载链接:https://pan.baidu.com/s/14Fo2b4znVPF6JrEmcZyc1Q 提取码:cwoc 官网下载地址如下: http://www.eclipse.org/downloads/packages/release/mars/2/eclipse-ide-java-ee-developers eclipse为免安装软件,下载到某个目录,解压就好了,发送快捷方式到桌面。 注意eclipse的版本必须和JDK版本一致,即eclipse必须保持和JDK同时是 32位或者64位,否则会打不开或者报错。3.sqlserver安装 sqlserver一般安装sqlserver2008-r2版本的。 sqlserver2008-r2百度网盘下载链接:https://pan.baidu.com/s/1fo261JzvkbFbu75KI3ahBA 提取码:g9hw sqlserver2008-r2安装参考如下:http://www.xiaoniucr.com/article/view/15.html 由于sqlserver的安装步骤比较多,安装过程中容易出现失误,导致安装失败,下面提供卸载步骤: 步骤参考:http://www.xiaoniucr.com/article/view/14.html##项目导入 eclipse点击File→Import弹出如下选择框 点击next进行项目选择导入 选择完项目之后,最后点击Finish,项目就导入进了eclipse。 ##项目jdk配置 仅仅将项目导入到eclipse还不够,要运行这个项目,还必须为项目设置jdk环境,操作如下: 鼠标选中项目,右键Properties,跳出如下窗体: 点击edit跳出如下窗体,进行jre环境的选择: 选择完jdk之后,点击Apply应用,最后点击[OK]按钮,进行确认,这样jdk就设置好了,如下: ##数据库配置1.首先,导入数据库,步骤参考如下:http://www.xiaoniucr.com/article/view/18.html2.要想正确的连接sqlserver数据库,必须在代码中将数据库的用户名和密码配置,改为你的电脑安装的sqlserver的用户名和密码, 其中,用户名一般都为sa,不需要更改,密码为学生自己安装sqlserver时设置的密码。 具体如何操作,在项目源码包中【配置】文件夹下都会包含一份【详细配置.docx】文件,参照里面的数据库配置进行配置即可。 这里需要注意的是,数据库有两种连接方式,一种是在Windows系统上用windows身份登录, 另外一种是用sa身份登录,在程序中我们使用sa账户连接数据库。 ##项目启动 以上步骤都完成之后,就可以启动项目了,javase项目的启动,一般都是使用Run as Java Application的形式,操纵如下: 找到项目main方法所在的java类,然后右键Run as,选择Java Application的形式启动,即可。 详细操作见:【详细配置.docx】文件中的项目部署,里面都会详细告知。关于Access denied问题的解决办法
再启动javaweb项目的时候,我们不经意间会遇到一个如下问题:造成这种问题的原因有很多种,比如,账户密码错误,或者数据库权限设置问题。首先确认自己项目配置文件的数据库名和密码是否配置正确,这个原因也可能导致。如果配置文件中你的数据库账户和密码确认无误,但依然出现以上错误,请按照如下步骤操作:1.登录mysql cd D:\mysql-5.6.24-win32.1432006610\mysql-5.6.24-win32\bin mysql -u root -p 输入你的数据库密码,按enter确定登录。 2.修改数据库密码 切换到mysql自带库:use mysql; 如果你的mysql版本是5.7以下(不包括5.7),请使用如下sql命令修改密码: update user set Password = password ('123456') where User = 'root'; 如果你的mysql版本是5.7及以上,请使用如下sql命令修改密码: update user set authentication_string=password('123456') where user='root';3.刷新权限 flush privileges;4.退出数据库 quit;5.重启数据库 net stop mysql net start mysq具体演示操作如下:最后在使用navicat for mysql测试一下是否可以登录。如果可以,在eclipse重启项目,使用浏览器访问页面,如果不在报错,那么恭喜你,问题解决了。如果你不记得你的数据库密码了,你可以通过在数据库安装目录bin下,添加配置skip-grant-tables添加这个配置的作用是为了使用cmd控制台登录数据库时,跳过密码验证,不必输入密码,直接enter即可进入数据库。然后重启mysql服务器。据说是一道华为Java面试题
请问下面程序将会输出什么?程序如下:public class Test { class A{ private static final int m = 10; public A(){ change(); } public void change(){ System.out.println(m); } } class B extends A{ private static final int num = 20; public void change(){ System.out.println(num); } }}输出测试:public class Test2 { public static void main(String[] args) { new Test().new B(); }}结果公布,最终会输出:20,为什么?分析一下继承的初始化顺序。继承的初始化顺序一般如下:父类的静态变量-->父类的静态代码块-->子类的静态变量-->子类的静态代码快-->父类的非静态变量(父类的非静态代码块)-->父类的构造函数-->子类的非静态变量(子类的非静态代码块)-->子类的构造函数值得注意的是:父类的非静态变量(父类的非静态代码块)是同一级的,看哪个部分写在类的最前面谁就先被执行,子类的非静态变量(子类的非静态代码块)也是一样。所以这道题,实例化一个子类,首先会去执行父类的构造方法,执行构造方法中的函数change,但是由于change函数被子类重写了,所以执行的将是子类的change,所以会输出20;但是,如果我们把子类的中的private static final int num = 20;改为private int m = 20;那么结果又会输出什么呢?结果是0,因为在父类的构造方法中调用子类的change方法输出num的时候,num作为一个实例变量,这时候还没有被实例化赋值,所以取得是初始值0。
点击排行
