昨天一时兴起,打算根据自己的某些想法,业余时间写一个简单的项目,用以巩固那些重要的知识,以及练手一些即将学习的技术。

然而才一开始,便有一盆冷水迎面而来,在搭建整个框架环境的时候竟然就被卡住了!主要是两个问题,第一个还好说,可是第二个,让我抓狂,让我差点怀疑人生!

最终结果是,一个是因为单词拼写错误,一个是因为多余的空格!

拼写错误害死人,空格害死人啊!

这个跟头真是一摔再摔,前赴后继!

这个项目我打算依旧以常规的spring+spring+spring mvc的整体架构来进行,于是便根据自己之前写的一篇框架搭建开始动手:http://blog.csdn.net/tuzongxun/article/details/51153773?locationNum=2&fps=1

原本,对于这个整体框架搭建我是信心满满的,因为之前认真的弄过好久,对于上边这篇文章所写的内容也是相当自信。

虽然我写的那些文章不一定有深度,但是除开一些理论性的,其他都绝对是自己亲自尝试过的,实用性和可行性我敢保证。

然而就在我确认搭建好,该修改的配置也都一一修改完以后,一启动tomcat居然报错了:

org.springframework.beans.factory.parsing.BeanDefinitionParsingException: Configuration problem: Failed to import bean definitions from relative location [spring-MybatisConfig.xml]
Offending resource: class path resource [spring.xml]; nested exception is org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML document from URL [file:/D:/eclipseWorkspace1/.metadata/.plugins/org.eclipse.wst.server.core/tmp2/webapps/myBlog/WEB-INF/classes/spring-MybatisConfig.xml]; nested exception is java.io.FileNotFoundException: D:\eclipseWorkspace1\.metadata\.plugins\org.eclipse.wst.server.core\tmp2\webapps\myBlog\WEB-INF\classes\spring-MybatisConfig.xml (系统找不到指定的文件。)
    at org.springframework.beans.factory.parsing.FailFastProblemReporter.error(FailFastProblemReporter.java:70)
    at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:85)
    at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:76)

好吧,这个提示太直白,系统找不到指定的文件!

根据以往的经验,我略一思索变想到多半是单词拼写错误,于是自然而然的自看了一眼文件名,果不其然,我的这个文件是这样的:



原来是spring打成了srping。

既然找到了问题,解决起来自然不是问题,我一直觉得问题不可怕,可怕的是找不到问题在哪儿!

然而,就在我以为大功告成的时候,再一启动tomcat,居然还是报错了,这次的错是:

十一月 29, 2016 10:29:10 上午 com.alibaba.druid.pool.DruidDataSource error
严重: init datasource error
java.sql.SQLException: Access denied for user 'tzx  '@'tuzongxun' (using password: YES)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:996)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3887)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3823)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:870)
    at com.mysql.jdbc.MysqlIO.proceedHandshakeWithPluggableAuthentication(MysqlIO.java:1659)
    at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1206)

看到这个错,我就有点不淡定了,因为这个错也是似曾相识的啊,如果我没记错,那就是密码错误的问题。

但是!我的密码分明没有问题!config.properties文件相关的内容如下:

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://192.168.0.7:3306/myblog?useUnicode=true&characterEncoding=utf-8
jdbc.username=tzx
useUnicode=true&characterEncoding=utf-8
jdbc.password=123456  

为了验证究竟是不是密码问题,我还特意写了一个jdbc来连接:

public static void mysqlTest() {
        String driver = "com.mysql.jdbc.Driver";// 数据库驱动
        String url = "jdbc:mysql://192.168.0.7:3306/myblog";// **指的是数据库名称
        String username = "tuzongxun";// 数据库用户名
        String password = "123456";// 数据库密码
        Connection conn = null;
        Statement stat = null;
        ResultSet rs = null;
        try {
            Class.forName(driver);// 加载数据库驱动
            conn = DriverManager.getConnection(url, username, password);// 连接Connection对象
            stat = conn.createStatement();// 创建Statement对象
            String sql = "select * from emlog_ad";
            rs = stat.executeQuery(sql);// 执行sql语句返回结果集
            while (rs.next()) {
                System.out.println(rs.getInt("id"));
                System.out.println(rs.getInt("status"));
                System.out.println(rs.getInt("position"));
                System.out.println(rs.getString("title"));
                System.out.println(rs.getInt("weight"));
                System.out.println(rs.getString("content"));
            }
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

结果自然是正常连接的。

这下我就蒙圈了:用户名和密码一模一样,框架和之前的也几乎没有差别,难道是见鬼了?难道是我之前的文章有问题么?

可是,我每次发出去的,分明都是一而再再而三的验证过的,不该如此啊!

万般无奈之下,我清了tomcat缓存,我清了eclispe缓存,甚至我重启了eclipse,我重启了电脑。

然而,问题他依旧在那里静静的看着我,仿佛在说“啊哈,你找不到我,你找不到我!”

这下我有点从蒙圈进入抓狂的状态了,根据经验实在无法定位问题所在了,只好上网搜索。

经过一顿百度,答案是如此的千篇一律,不是说用户名密码错误的问题,就是说需要新建用户。

好吧,不管怎样,先试试再说。

于是,我重新创建了一个用户,重新启动了mysql。甚至由于之前写那个框架搭建时用的是mysql5.5,而我现在用的是mysql5.6,所以我又弄了个mysql5.5。

结果呢。。。有点不想说话!

该试的都试了,不该试的我也试了,怀疑人生模式正式开启。。。

于是,我开始漫无目的的一行行代码、一个个字符的开始了光标的漫长旅行。

令我意外的是,山重水复疑无路,柳暗花明又一村,问题竟然就这样突如其来的被窝寻到了踪迹!

在光标一个字符一个字符的移动中,我发现我的config.properties文件居然是这样的:





明眼人大概已经看到了问题所在,正是我的用户名和密码后边多出了两个空格,当我把这两个空格干掉之后,再次启动tomcat,那个异常终于乖乖的溜之大吉了!

如此没有技术含量的两个错,我已犯了多次,粗心大意犯的错,空格字符太坑人,说多了都是泪啊!

Access denied for user(这个几乎让我怀疑人生的异常)的更多相关文章

  1. MySql Access denied for user 'root'@'localhost' (using password:YES) 解决方案

    关于昨天下午说的MySQL服务无法启动的问题,解决之后没有进入数据库,就直接关闭了电脑. 今早打开电脑,开始-运行 输入"mysql -uroot -pmyadmin"后出现以下错 ...

  2. phpmyadmin #1045 - Access denied for user 'root'@'localhost' (using password: NO)

    phpmyadmin访问遇到1045问题 #1045 - Access denied for user 'root'@'localhost' (using password: NO) 解决办法 找到p ...

  3. Windows mysql提示:1045 access denied for user 'root'@'localhost' using password yes

    Windows mysql提示:1045 access denied for user 'root'@'localhost' using password yes http://blog.csdn.n ...

  4. Laravel [1045] 解决方法 Access denied for user 'homestead'@'localhost'

    这几天学习Laravel框架遇到了数据库方面的问题. PDOException in Connector.php line 55:SQLSTATE[HY000] [1045] Access denie ...

  5. Linux mysql 5.6: ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

    案例环境: 操作系统 :Red Hat Enterprise Linux Server release 5.7 (Tikanga) 64 bit 数据库版本 : Mysql 5.6.19 64 bit ...

  6. MySQL ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)的真正原因

    在博客Linux mysql 5.6: ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: N ...

  7. mac 安装mysql + 修改root用户密码 + 及报Access denied for user 'root'@'localhost' (using password:YES)解决办法

    1.下载MySQL 到mysql的官网http://dev.mysql.com/downloads/mysql/然后在页面中会看到“MySQL Community Server”下方有一个“downl ...

  8. MySql access denied for user错误

    MySql access denied for user错误 | 浏览:2812 | 更新:2014-11-27 11:16 MySql access denied for user错误 方法/步骤 ...

  9. 升级到macOS 10.12 mysqlb报错ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

    系统升级到macOS 10.12后启动mysql后,在终端输入mysql 报错ERROR 1045 (28000): Access denied for user 'root'@'localhost' ...

随机推荐

  1. raid制作(转载)

    Dell r710服务器,有4块450G硬盘,默认做的RAID5.我们的目的是取其中3块硬盘做RAID5,留一块硬盘做热备. 在这里,我具体解释一下 ①4块硬盘做成RAID5 ②3块硬盘做RAID5, ...

  2. Nginx几种负载均衡算法及配置实例

    本文装载自: https://yq.aliyun.com/articles/114683 Nginx负载均衡(工作在七层"应用层")功能主要是通过upstream模块实现,Ngin ...

  3. xBIM WeXplorer

    目录 基础 xBIM WeXplorer 简要介绍 xBIM WeXplorer xViewer 基本应用 xBIM WeXplorer xViewer 浏览器检查 xBIM WeXplorer xV ...

  4. xBIM IFC 输出 Excel 报表

    目录 xBIM 应用与学习 (一) xBIM 应用与学习 (二) xBIM 基本的模型操作 xBIM 日志操作 XBIM 3D 墙壁案例 xBIM 格式之间转换 xBIM 使用Linq 来优化查询 x ...

  5. 分组密码的工作模式--wiki

    密码学中,块密码的工作模式允许使用同一个块密码密钥对多于一块的数据进行加密,并保证其安全性.[1][2] 块密码自身只能加密长度等于密码块长度的单块数据,若要加密变长数据,则数据必须先被划分为一些单独 ...

  6. 洛谷 [P1020] 导弹拦截 (N*logN)

    首先此一眼就能看出来是一个非常基础的最长不下降子序列(LIS),其朴素的 N^2做法很简单,但如何将其优化成为N*logN? 我们不妨换一个思路,维护一个f数组,f[x]表示长度为x的LIS的最大的最 ...

  7. 几个重要的shell命令:diff patch tar find grep

    diff diir_1.0/ dir_2.0/ -urNB > dir_2.0.patch u:union以合并的格式来输出文件的差异信息 r:递归的对比所有的子目录下的文件 U:将不存在的文件 ...

  8. ubuntu16.04安装ftp服务器

    参考文章: http://www.linuxidc.com/Linux/2017-01/139233.htm 1.检查是否安装vsftpd,如果安装了跳过第二步 vsftpd -v 2.安装vsftp ...

  9. Win7 64位操作系统中搭建C/C++的编译环境

    通常使用IDE工具为 VS2010 .但是如果仅仅只是想在Windows中使用命令行对C/C++源码进行编译和运行.则需要使用 CL 命令方式或另外安装 Cygwin / MinWin 命令行编译器. ...

  10. centos6下从源码安装setuptools和pip

    1. 下载setuptools及pip的源码包 setuptools与pip都是python的模块 setuptools源码包: https://pypi.python.org/pypi/setupt ...