Я пытаюсь использовать API-интерфейс Sinch REST в С# для проверки смс, и у меня возникают проблемы с кодированием строк, необходимых для авторизации. Я использую APPLICATION SIGNED REQUEST для Auth, и я хотел бы знать, какие функции С# использовать для создания содержимого-Md5 и stringtoSign. Для контента MD-5 вот фрагмент кода, который у меня есть
var body = JsonConvert.SerializeObject(smsRequest);
var hs = System.Security.Cryptography.MD5.Create();
var db = hs.ComputeHash(Encoding.UTF8.GetBytes(body));
var stringToSign = Convert.ToBase64String(db);
public class SmsRequest
{
[JsonProperty("identity")]
public Identity Identity;
[JsonProperty("method")]
public string Method;
[JsonProperty("metadata")]
public Metadata Metadata;
}
public class Metadata
{
[JsonProperty("os")]
public string Os;
[JsonProperty("platform")]
public string Platform;
}
public class Identity
{
[JsonProperty("type")]
public string Type;
[JsonProperty("endpoint")]
public string Endpoint;
}
Теперь для создания stringtoSign я использую следующий код
var stringToSign = "POST" + Environment.NewLine + "jANzQ+rgAHyf1MWQFSwvYw==" + Environment.NewLine +
"application/json" + Environment.NewLine + "x-timestamp:2014-06-04T13:41:58Z" +
Environment.NewLine + "/v1/sms/+46700000000";//used for signing
var secret = "JViE5vDor0Sw3WllZka15Q=="; // this needs to be signed
var encoding = new System.Text.UTF8Encoding();
byte[] keyByte = encoding.GetBytes(stringToSign);
var hmacsha256 = new HMACSHA256(keyByte);
byte[] messageBytes = Encoding.UTF8.GetBytes(secret);
byte[] hashmessage = hmacsha256.ComputeHash(messageBytes);
var res = Convert.ToBase64String(hashmessage);
Я использую значения из примера здесь https://www.sinch.com/using-rest/ и я ожидаю, что результатом будет "qDXMwzfaxCRS849c/2R0hg0nphgdHciTo7OdM6MsdnM=", а с помощью моего метода я получаю "2/8KqdiC2708EC84vTinPchiATRJiZU4Mgfpykb4F40=".
Что я здесь делаю неправильно?