https://docs.payfort.com/docs/in-common/build/index.html#create-signature-value
我需要一些有关生成PayFort令牌化SHA256签名的帮助。链接中的示例为您提供了有关如何标记请求的基本指南,但我需要的是有关如何使用密钥生成SHA256签名以及如何使用密钥解密响应签名的信息。我拥有请求和响应短语密钥所需的所有数据。我不完全了解如何使用C#中的密钥生成正确的SHA256签名。我尝试了其他示例来生成SHA256签名,但它返回的签名不匹配。
PayFort文档中的示例:
PropertyChanged
如何在C#中正确加密和解密它。
感谢您的帮助。
编辑:
我在盲目射击,熟悉C#的PayFort集成的任何人都可以指导我
SHA Request Phrase: PASS
SHA-Type: SHA-256
PASSaccess_code=SILgpo7pWbmzuURp2qrilanguage=enmerchant_identifier=MxvOupuGmerchant_reference=MyReference0001service_command=TOKENIZATIONPASS
答案 0 :(得分:0)
首先,您需要将签名生成为字符串。签名包括访问码,语言等。然后将该签名转换为字节。然后初始化一个sha256Managed对象。 将字节参数传递给该对象,这将返回另一个字节,但具有sha256Managed格式。现在您需要在foreach中设置其格式。
请找到以下代码,这将对您有所帮助。
byte[] bytes = Encoding.UTF8.GetBytes(signature);
SHA256Managed hashstring = new SHA256Managed();
byte[] hash = hashstring.ComputeHash(bytes);
string hashString = string.Empty;
foreach (byte x in hash)
{
hashString += String.Format("{0:x2}", x);
}