Secure authentication with UserSig
This document focuses on UserSig—a security signature designed by Tencent Cloud to prevent malicious attackers from stealing cloud service usage rights. When using basic cloud services, provide SDKAppID, UserID, and UserSig during SDK initialization or login. 
SDKAppID is used to identify your application. 
UserID is used to identify your user. 
UserSig is a security signature calculated based on the first two using the HMAC SHA256 encryption algorithm. As long as attackers cannot forge UserSig, they cannot steal your cloud service traffic. 
Obtaining a Key
1. Log in to the Chat console.
Note: 
2. Click the target app card to go to its basic configuration page.
3. In the Basic Information section, click Display key to the right of SecretKey.

4. Click Copy to copy and save the key information.
Calculating UserSig on the Client
The 
GenerateTestUserSig open-source module provided in the sample code of the Chat SDK can help you quickly generate a UserSig. You only need to configure three member variables, including SDKAppID (SDKAppID of the app), EXPIRETIME (UserSig expiration time), and SecretKey (key information), and then call the genTestUserSig() function to quickly obtain a UserSig.To simplify this process, we provide the source code for computing a UserSig for the following languages and platforms. You can directly download and integrate the source code into your client.
| Programing Language | Platform | GenerateTestUserSig Source Code | 
| Java | Android | |
| Objective-C | iOS | |
| Objective-C | Mac | |
| C++ | Windows | |
| Dart | Flutter | 
Note: 
In this method, the 
SecretKey is vulnerable to decompilation and reverse engineering. Once your SecretKey is disclosed, attackers can steal your Tencent Cloud traffic. Therefore, this method is only suitable for locally running a demo project and feature debugging.The correct way to issue a UserSig is to integrate the UserSig computing code into your server and provide app-oriented APIs. When UserSig is needed, your app will send a request to the business server to obtain a dynamic UserSig. For more information, see Server-side UserSig Generation.
Calculating UserSig on the Server
Generating a UserSig on the server provides maximum protection against the disclosure of the key used for calculating the UserSig. You only need to deploy the code for calculating the UserSig on your server and provide an app-oriented API. When a UserSig is needed, your app will send a request to the business server to obtain a dynamic UserSig.
To simplify this process, we provide the source code for calculating a UserSig for the following languages and platforms. You can directly download and integrate the source code into your server.
Key fields in a UserSig calculation function include the SDKAppID, UserID, and UserSig validity period, as described in the following table.
Note: 
The following table uses the field names in the Java source code as an example. The field names may be different in other languages.
| Field Name (Example) | Description | 
| sdkappid | |
| userId | User ID (former name:  Identifier). | 
| expire | UserSig validity period, in seconds. | 
| userbuf | This field is set to  nullby default because APIs without UserBuf are used in Chat by default.APIs with UserBuf may be required in some TRTC use cases, for example, when entering a room. For more information, see Enabling Advanced Permission Control. | 
| key | Key. You can obtain a key on the app details page in the Chat console. For more information, see Obtaining a Key. | 
Old Version of Algorithm
To simplify the difficulty of signature calculation so that customers can conveniently and quickly use Tencent Cloud services, the signature algorithm of the Chat service has been upgraded from ECDSA-SHA256 to HMAC-SHA256 since July 19, 2019. This means that all SDKAppIDs created after July 19, 2019 will use the new HMAC-SHA256 algorithm.
If your SDKAppID was created before July 19, 2019, we recommend that you upgrade the signature algorithm to HMAC-SHA256. The upgrade will not affect your live network operations. Alternatively, you can still use the signature algorithm of an earlier version. The URLs for downloading the source code for the ECDSA-SHA256 algorithm are as follows:
Get UserSig from the console
Log in to Tencent-RTC Console, navigate to Development Tools > UserSig Tools.
Under the UserSig Generation Tool, select the corresponding SDKAppID and UserID.
Click the Generate button to compute the corresponding UserSig.
