Я очень много пытался создать подпись для доступа к одному веб-сервису.
Они требовали, чтобы я генерировал подпись с каждым запросом.
Для генерации подписи у меня есть одно сообщение «abc» и один секретный ключ «xyz». Согласно им моя подпись должна быть обработана как следующий код рубина
require 'base64'
require 'openssl'
secret = "xyz"
request = "abc"
digest = OpenSSL::Digest::Digest.new('sha256')
signature = Base64.encode64(OpenSSL::HMAC.digest(digest, secret, request)).chomp
signature
должно быть 9ZjsfVB3k5nPNLf5he+gfyYaxNWCIJ6J8YcRpxW5GG0=
, но я не получаю это, используя Java-код, как показано ниже:
SecretKey secretKey = null;
byte[] keyBytes = keyString.getBytes("UTF-8");
Mac mac = Mac.getInstance("HMACHSA256");
secretKey = new SecretKeySpec(keyBytes,mac.getAlgorithm());
mac.init(secretKey);
byte[] text = baseString.getBytes("UTF-8");
//mac.update(digest.digest());
byte[] encodedText = mac.doFinal(text);
return new String(Base64.encodeBase64(encodedText)).trim();
Пожалуйста, помогите мне в этом.