V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Tuy
V2EX  ›  问与答

遇到了一个奇怪的 bug 前端传的*存入数据库变成了#42

  •  
  •   Tuy · 2021-06-04 15:37:23 +08:00 · 1123 次点击
    这是一个创建于 1298 天前的主题,其中的信息可能已经有所发展或是发生改变。

    非常神奇的问题,查过了编码 也没有*和#42 对应的哇, 在多次测试后发现&会转成 amp 除此之外就没有其他转码问题了,

    目前处理就是直接#42 替换成*,但是想不明白是什么原因

    7 条回复    2021-06-04 15:54:36 +08:00
    hahastudio
        1
    hahastudio  
       2021-06-04 15:41:28 +08:00
    * 就是 42 (十进制)啊
    limuyan44
        2
    limuyan44  
       2021-06-04 15:43:20 +08:00
    先看看后端收到的是什么,插入的 sql 又是什么,sql 拿到命令行执行结果又是什么,不是什么复杂的情况很好排查。
    AoEiuV020
        3
    AoEiuV020  
       2021-06-04 15:43:22 +08:00
    星号*的 ascii 十进制就是 42,
    adeweb
        4
    adeweb  
       2021-06-04 15:44:10 +08:00
    "*".codePointAt() // 42
    Tuy
        5
    Tuy  
    OP
       2021-06-04 15:46:03 +08:00
    对 *的 ascii 码确实是 42 但是这个没法解释&
    Tuy
        6
    Tuy  
    OP
       2021-06-04 15:46:34 +08:00
    @limuyan44 这个我没表述清楚 后端接受到请求之后数据就变成了了#42
    BreadKiller
        7
    BreadKiller  
       2021-06-04 15:54:36 +08:00
    https://dev.w3.org/html5/html-author/charref
    虽然有*和#42 对应,但是按理&转成& *应该是转成* 才对吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1856 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 16:16 · PVG 00:16 · LAX 08:16 · JFK 11:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.