祭出两个相同(其实不同)的字符串

  1. $strA = '8888‬';
  2. $strB = '8888';

我们肉眼看到的这两个字符串是绝对相同的, 对的, 他是一个’8888’, 让我们用 php (世界上最好的语言) 输出下两个字串的长度

  1. # code
  2. var_dump($strA);
  3. var_dump($strB);
  4. # result
  5. string(7) "8888‬"
  6. string(4) "8888"

我滴妈呀, 怎么会不同呢, 纳闷..

让我们撕下她的伪装

  1. for ($i = 0, $iMax = strlen($strA); $i < $iMax; $i++) {
  2. var_dump($strA[$i]);
  3. }
  1. string(1) "8"
  2. string(1) "8"
  3. string(1) "8"
  4. string(1) "8"
  5. string(1) "�"
  6. string(1) "�"
  7. string(1) "�"

咦, 这是个什么鬼. 不像是正常字符啊. 哦, 对了, 我们是用的Utf-8 字符集, 这三个应该是一个字符, 我们把它组合起来
获取到 ASCII 码值

  1. for ($i = 0, $iMax = strlen($strA); $i < $iMax; $i++) {
  2. var_dump(ord($strA[$i]));
  3. }
  1. int(56)
  2. int(56)
  3. int(56)
  4. int(56)
  5. int(226)
  6. int(128)
  7. int(172)

这个编码值是 [226 128 172], 让我们找到它.
看, 在这里

来自于这个网站, 好像是输出格式化标识符. 以上.