使用SHA256的PayFort签名

时间:2018-09-10 07:24:47

标签: c# integration payfort

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

1 个答案:

答案 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);
            }