This is a pure 1C implementation of RFC 2104 https://www.ietf.org/rfc/rfc2104.txt and RFC 7519 https://tools.ietf.org/html/rfc7519
This implementation works only on 1C:Enterprise platform version 8.3.10.2168 or above. The platform you may download here: https://1c-dn.com/user/updates/1c_enterprise_platform_training_version/ For JWT supported algorithm HS256 only. HMAC function supports algorithms: MD5, SHA1, SHA256
Download modules Cryptography.bsl and JWT.bsl. Put modules into the 1C application.
// HMAC
SecretKey = "key";
StringToSign = "The quick brown fox jumps over the lazy dog";
Signature = Cryptography.HMAC(
GetBinaryDataFromString(SecretKey),
GetBinaryDataFromString(StringToSign),
HashFunction.SHA256);
// JWT
SecretKey = "secret";
Payload = New Structure;
Payload.Insert("sub", "1234567890");
Payload.Insert("name", "John Doe");
Payload.Insert("admin", True);
Token = JWT.Encode(SecretKey, Payload);
DecodedPayload = JWT.Decode(Token, SecretKey);
Author: Vasily Pintov vasily@pintov.ru
License: MIT