0

0

Realex集成SHA1哈希不匹配问题解析与修复

花韻仙語

花韻仙語

发布时间:2025-11-19 13:54:06

|

882人浏览过

|

来源于php中文网

原创

realex集成sha1哈希不匹配问题解析与修复

本文旨在解决Realex/Global Payments支付网关集成中常见的“SHA1哈希不正确”(错误代码505)问题。通过分析问题根源,我们发现该错误通常源于payer-new请求类型在计算SHA1哈希时错误地包含了金额和货信息。教程将详细阐述正确的哈希计算方法,并提供示例代码,帮助开发者确保数据完整性与交易安全性,顺利完成Realex支付集成。

理解Realex支付网关的SHA1哈希机制

Realex(现为Global Payments的一部分)支付网关在处理交易请求时,为了确保数据的完整性和安全性,广泛采用了SHA1哈希算法。每次向Realex发送请求时,都需要根据特定的参数组合生成一个SHA1哈希值,并将其包含在请求中。Realex服务器会使用相同的逻辑重新计算哈希值,如果客户端发送的哈希值与服务器计算的不匹配,便会返回“SHA1哈希不正确”的错误(通常是错误代码505)。

Realex的哈希计算通常涉及两个步骤:

  1. 数据哈希(Data Hash):将一系列核心交易参数按照特定顺序拼接成一个字符串,然后计算其SHA1哈希值。
  2. 秘密哈希(Secret Hash):将上一步生成的数据哈希值与商户的共享秘密(Secret)拼接,再次计算SHA1哈希值。最终将这个二次哈希值发送给Realex。

这种双重哈希机制旨在防止数据在传输过程中被篡改,并验证请求的真实性。

“SHA1哈希不正确”错误(505)的常见原因

当收到以下错误响应时:


    OUR MERCHANT ID IS INSERTED HERE
    website
    scsi45880
    505
    sha1hash incorrect - check your code and the Developers Documentation

这明确指示了SHA1哈希计算存在问题。根据我们的经验,此问题通常发生在以下情境:

  • 参数顺序错误:拼接哈希字符串时,参数的顺序与Realex文档要求不符。
  • 参数缺失或多余:在特定请求类型中,包含了不应包含的参数,或遗漏了必需的参数。
  • 秘密密钥不匹配:使用了错误的商户秘密密钥。
  • 数据格式问题:某些参数(如金额)的格式不正确,导致拼接后的字符串与Realex预期不符。

针对payer-new请求的SHA1哈希修复

在Realex集成中,不同的请求类型(例如auth授权请求、payer-new创建付款人请求)对SHA1哈希的参数要求是不同的。问题中描述的错误发生在尝试发送客户名称、客户编号等数据时,这通常与payer-new(或类似的客户信息注册)请求相关。

CG Faces
CG Faces

免费的 AI 人物图像素材网站

下载

通过分析发现,在处理payer-new请求时,原始代码错误地将pay_amount(支付金额)和currency(货币)包含在了SHA1哈希的计算字符串中。然而,payer-new请求的主要目的是注册付款人信息,它本身并不直接涉及具体的交易金额。因此,在生成此类型的哈希时,不应包含金额和货币参数。

错误的哈希计算(示例,应避免):

// 错误的payer-new哈希计算示例
// $payer_temp_var = "$timestamp.$merchantid.$rlx_orderid.$pay_amount.$currency.$payer_ref";
// $payersha1hash = sha1($payer_temp_var);
// $payertmp = "$payersha1hash.$payer_secret";
// $payersha1hash = sha1($payertmp);

正确的哈希计算方法:

对于payer-new请求,SHA1哈希计算的参数应仅包括时间戳、商户ID、订单ID和付款人引用(Payer Reference)。


    
      $merchantid
      $account
      $rlx_orderid
      
        
      
      $payersha1hash
    ";

// ... cURL请求发送 ...
?>

注意事项:

  1. 区分请求类型:务必根据Realex文档,针对不同的请求类型(如auth、payer-new、settle等)采用不同的哈希计算参数和顺序。例如,auth(授权)请求的哈希计算通常会包含金额和货币信息,因为它是一个具体的交易请求。
  2. 秘密密钥:确保您使用的payer_secret是Realex为您提供的、用于Payer操作的正确秘密密钥。Realex可能为不同类型的操作提供不同的秘密密钥。
  3. 参数顺序:即使参数正确,其拼接顺序也至关重要。任何顺序的改变都会导致哈希值不匹配。
  4. 错误日志:在开发和调试阶段,充分利用错误日志(如error_log)来打印拼接前的哈希字符串和最终的哈希值,以便与Realex文档进行比对。
  5. 官方文档:Realex的文档虽然有时不够清晰,但仍然是最终的权威参考。在遇到问题时,应仔细核对相关请求类型的哈希生成章节。

总结

解决Realex集成中“SHA1哈希不正确”的错误,核心在于严格遵循Realex文档中对每种请求类型所规定的哈希计算规则。对于payer-new请求,关键在于不将交易金额和货币包含在哈希字符串中。通过修正这一细节,并确保其他参数的正确性和顺序,可以有效解决505错误,确保支付网关通信的顺畅和安全。在处理其他Realex请求时,也应采用同样的严谨态度,对照文档,确保哈希计算的准确无误。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

254

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1463

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

617

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

548

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

543

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

159

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

77

2025.08.07

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

4

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号