ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2022-05-29 15:02:22  阅读:320  来源: 互联网

标签:进制 配置文件 数据库 连不上 问题 yaml 八进制 SpringBoot


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类型时配上、
    • 恰巧,转化出来的十进制密码跟你数据库当中的密码完全不一样、
    • 恰巧,你连不上数据库

标签:进制,配置文件,数据库,连不上,问题,yaml,八进制,SpringBoot
来源: https://www.cnblogs.com/wavesbright/p/SpringBoot_yaml.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有