2、yaml配置文件当中的坑(数字的定义和支持进制书写格式)

6、进制数的转换

6.1、问题回顾

  1. 我记得我刚刚开始使用SpringBoot的时候,有一天在做到SpringBoot整合第三方技术的时候
  2. 我刚好在那天学习到整合Mybatis,做Web项目嘛,不连数据库怎么行?
  3. 在yml配置文件当中配置数据源--datasource的时候,我遇见了一个问题
    • 我个人有做笔记的习惯嘛,我喜欢写一步做一步,在那天这个错误的信息被我留存下来了
    • image-20220529133843980
  4. 这就是我当时配置数据源的配置,我遇到了一个问题,我死活都连不上数据库
    • 我通过cmd终端连接我的数据库,没问题
    • 通过图形界面化工具Navicat连接也没问题
    • 但是就是使用SpringBoot配置我的数据库连接的时候,连不上,密码是错的
  5. 我很郁闷,但是那天我也找到了问题的所在,只是我不明白为什么会出现这个问题

6.2、问题复盘

  1. 将原先的demo给大家来复个盘
    • image-20220529134718689
    • 这是咱的yml配置文件,我现在将它(password)设置为int类型
    • 同时,这里有个实体test,我让他来读取我这个配置文件当中的值
    • image-20220529143222539
  2. 接下来,咱们开始打印输出测试一下结果,看看发生了什么事情?
    • image-20220529134951952
  3. 我明明写的是 010115,为什么打印出来是4173呢?

6.3、问题出现的原因

上述这种情况,其实任何开发人员都有可能遇见的,所以这里需要提一下

  • 在我们学习yaml语法规则的时候
  • 信息量不大,但是有几个信息容易忽略
  • int值支持,二进制,八进制,十六进制
    • 二进制是什么:0b1010_0111_1010_1110,这种类型的
    • 八进制的语法:以0开头,后面跟上(0-7)=>0 (0-7)=>0(10115)
    • 十六进制呢:0x开,(0-9,a-f)跟

image-20220529140751183

我们打开计算器,测试一下,为什么010115 会变成 4173呢?

image-20220529142827507

  • 现在明白了吧,我的密码刚好是以0开头的,然后又恰好后面的数字都只包含0-7,他是一个标准的八进制,才会在八转十的时候遇见这个问题
  • 只能说太倒霉加上太巧了,但凡密码不是以0开头的都不至于这样,当然,如果是0x开的那遇到了也没辙对吧
  • 那么他的隐藏性主要在哪里

6.4、问题的隐藏性

  • 我们后台接受数据的时候,password是按照字符串来接收的
  • 他识别到了0开的数据(0(010115))以后,并且又是一个纯数字,他默认把它按照数值进行解析=>八进制转十进制
  • 转换完毕得到结果了=>4175,那直接将其转换为字符串即可,从而注入到我们的实体类配置项当中
  • 最终就出现了我们这么一个问题

6.5、总结

  • 像我们这个问题最终引发的后果就是,连不上数据库,其实和连数据库有关系吗?没有关系?
  • 就是因为这个地方的格式转化问题,你能赖别人吗?
    • image-20220529143811595
  • 人家SpringBoot都推荐了,如果是纯数字结构的,那么你用字符串给他包上就行了
  • 我们这里
    • 恰巧没用字符串包上、
    • 恰巧又刚好是一个八进制,这个八进制被转换成十进制了、
    • 恰巧,转化出来的密码又刚好可以和String类型时配上、
    • 恰巧,转化出来的十进制密码跟你数据库当中的密码完全不一样、
    • 恰巧,你连不上数据库
posted @ 2022-05-29 14:46  澜璨  阅读(2079)  评论(0编辑  收藏  举报