在这个问题中,Erik 需要在 Node.js 中生成一个安全的随机令牌。有crypto.randomBytes生成随机缓冲区的方法。但是,node 中的 base64 编码不是 url 安全的,它包含/and+而不是-and _。因此,我发现生成此类令牌的最简单方法是
crypto.randomBytes
/
+
-
_
require('crypto').randomBytes(48, function(ex, buf) { token = buf.toString('base64').replace(/\//g,'_').replace(/\+/g,'-'); });
有没有更优雅的方式?
尝试crypto.randomBytes():
require('crypto').randomBytes(48, function(err, buffer) { var token = buffer.toString('hex'); });
“十六进制”编码适用于节点 v0.6.x 或更高版本。