GenerateTestUserSig.js 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*eslint-disable*/
  2. /*
  3. * Module: GenerateTestUserSig
  4. *
  5. * Function: 用于生成测试用的 UserSig,UserSig 是腾讯云为其云服务设计的一种安全保护签名。
  6. * 其计算方法是对 SDKAppID、UserID 和 EXPIRETIME 进行加密,加密算法为 HMAC-SHA256。
  7. *
  8. * Attention: 请不要将如下代码发布到您的线上正式版本的 App 中,原因如下:
  9. *
  10. * 本文件中的代码虽然能够正确计算出 UserSig,但仅适合快速调通 SDK 的基本功能,不适合线上产品,
  11. * 这是因为客户端代码中的 SECRETKEY 很容易被反编译逆向破解,尤其是 Web 端的代码被破解的难度几乎为零。
  12. * 一旦您的密钥泄露,攻击者就可以计算出正确的 UserSig 来盗用您的腾讯云流量。
  13. *
  14. * 正确的做法是将 UserSig 的计算代码和加密密钥放在您的业务服务器上,然后由 App 按需向您的服务器获取实时算出的 UserSig。
  15. * 由于破解服务器的成本要高于破解客户端 App,所以服务器计算的方案能够更好地保护您的加密密钥。
  16. *
  17. * Reference:https://cloud.tencent.com/document/product/647/17275#Server
  18. */
  19. function genTestUserSig(userID) {
  20. /**
  21. * 腾讯云 SDKAppId,需要替换为您自己账号下的 SDKAppId。
  22. *
  23. * 进入腾讯云实时音视频[控制台](https://console.cloud.tencent.com/rav ) 创建应用,即可看到 SDKAppId,
  24. * 它是腾讯云用于区分客户的唯一标识。
  25. */
  26. // var SDKAPPID = 1400361531;
  27. var SDKAPPID = 1400361531;
  28. /**
  29. * 签名过期时间,建议不要设置的过短
  30. * <p>
  31. * 时间单位:秒
  32. * 默认时间:7 x 24 x 60 x 60 = 604800 = 7 天
  33. */
  34. var EXPIRETIME = 604800;
  35. /**
  36. * 计算签名用的加密密钥,获取步骤如下:
  37. *
  38. * step1. 进入腾讯云实时音视频[控制台](https://console.cloud.tencent.com/rav ),如果还没有应用就创建一个,
  39. * step2. 单击“应用配置”进入基础配置页面,并进一步找到“帐号体系集成”部分。
  40. * step3. 点击“查看密钥”按钮,就可以看到计算 UserSig 使用的加密的密钥了,请将其拷贝并复制到如下的变量中
  41. *
  42. * 注意:该方案仅适用于调试Demo,正式上线前请将 UserSig 计算代码和密钥迁移到您的后台服务器上,以避免加密密钥泄露导致的流量盗用。
  43. * 文档:https://cloud.tencent.com/document/product/647/17275#Server
  44. */
  45. // var SECRETKEY = '91dda672fb1d4a9e28cbb19c1bc12ef080783fd81b9d5a11bb74306c62d16e91';
  46. var SECRETKEY = '91dda672fb1d4a9e28cbb19c1bc12ef080783fd81b9d5a11bb74306c62d16e91';
  47. var generator = new window.LibGenerateTestUserSig(SDKAPPID, SECRETKEY, EXPIRETIME);
  48. var userSig = generator.genTestUserSig(userID);
  49. return {
  50. SDKAppID: SDKAPPID,
  51. userSig: userSig
  52. };
  53. }