这恐怕是目前最臭的 CheckSum 算法。

342 天前
 ShikiSuen

这恐怕是目前最臭的 CheckSum 算法。现在 Xcode 用 MD5 或 SHA-1 都会跳警告,真的很烦人,非得逼着你用 SHA-256 ;但是 CryptoKit 的 SHA-256 要求 target 得至少 macOS 10.15 才可以,就很头痛。所以就自己弄了这么一个 CheckSum 算法(用 CRC32 改的),反正不是用于资安用途,就不要紧。

// MARK: - YJSNPI Hash Calculation Method
public enum YJSNPI {
  private static let table: [UInt32] = (0 ... 255).map { i -> UInt32 in
    (0 ..< 8).reduce(UInt32(i)) { c, _ in
      ((c % 2) * 0xE114_D514) ^ (c >> 1)
    }
  }
  public static func checksum(bytes: [UInt8]) -> UInt32 {
    ~(bytes.reduce(~UInt32(0)) { crc, byte in
      (crc >> 8) ^ table[(Int(crc) ^ Int(byte)) & 0xFF]
    })
  }
}
3071 次点击
所在节点    程序员
9 条回复
msg7086
342 天前
这么臭的哈希不要也罢(
MrKrabs
342 天前
Al0rid4l
342 天前
点进来发现不是我想的那个臭
ShikiSuen
342 天前
@Al0rid4l 难道你预想的臭与 YJSNPI 无关?
Al0rid4l
342 天前
@ShikiSuen 啊, 没注意看代码, 不好意思, 现在是我想的那个了(满意离开
ShikiSuen
342 天前
@Al0rid4l 0xE114_D514
Mimei
342 天前
臭啊,真太臭了(雾
JackyCDK
342 天前
臭啊,太臭了(捂鼻
newmlp
342 天前
我一般用这种加密算法都是从 mbedtls 里面抠出来模块。。。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/941677

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX