跳到主要内容

准备证书

开发者接入华为支付开放API接口,需要通过证书来对请求内容及响应内容做签名和验证签名,以保证请求的安全性和可靠性。

本文将介绍接入过程中相关证书的作用和获取方法。在准备证书前,请在华为支付商户平台入网,具体请参见商户入网

需准备证书:商户证书、华为支付证书(公钥)。

证书说明

证书使用如图所示:

商户证书

商户证书是指由商户自行生成(参见生成商户证书)或申请(可自行选择符合资质的CA认证机构申请证书)的,包含商户公钥和私钥信息的证书。

私钥用于商户在华为支付开放API接口请求过程中的签名,公钥用于提供给华为支付侧进行请求验签。

该证书文件要求为pem格式,支持RSA和SM2两种算法类型的证书。

证书私钥

商户自行生成或申请商户证书时,会配套生成商户私钥。

  • 商户私钥用于商户对华为支付开放API请求中的信息进行签名。
  • 请妥善保管好商户私钥文件,不要把私钥文件暴露在公共场合,如上传到Github,写在客户端代码等。

证书公钥

商户自行生成或申请商户证书时,会配套生成商户公钥。

  • 商户需将生成的证书公钥上传到华为支付商户平台来获取证书ID,证书ID为请求华为支付开放API接口时请求头鉴权信息PayMercAuth对象中的authId字段以及订单信息参数orderStr中的auth_id字段。

  • 证书上传(参见上传商户证书)后,可以在“商户中心 > 证书管理 > 上传商户证书 > 证书ID”处获取。

生成商户证书

方式1:使用JavaScript的库线下生成(生成RSA算法类型证书为例,推荐方法)

  1. 配置Node.js执行环境。下面以Windows开发环境为例:

    登录Node.js官方网站,下载Node.js软件包。请选择LTS版本,并根据电脑操作系统选择对应的软件包。

    双击下载后的软件包进行安装。全部按照默认设置点击“Next”,直至“Finish”。安装过程中,Node.js会自动在系统的path环境变量中配置node.exe的目录路径。

    如果安装Node.js没有选择默认安装目录,则需要在系统变量“path”中手动添加环境变量信息“我的电脑>属性>高级系统设置>环境变量”增加Node.js的安装路径。

    打开命令行工具,输入node -v命令,能正常查询Node.js的版本号,说明Node.js执行环境配置完成。

  2. 使用文本编辑器新建文件(编码为UTF-8),拷贝以下代码到文件中并保存命名为“generateKeyPair.js”。

    const crypto = require('crypto');
    // 生成密钥对
    const { publicKey, privateKey } = crypto.generateKeyPairSync('rsa', {
    modulusLength: 3072, // 密钥长度,不少于3072
    publicKeyEncoding: {
    type: 'spki', // 公钥编码格式
    format: 'pem' // 公钥输出格式
    },
    privateKeyEncoding: {
    type: 'pkcs8', // 私钥编码格式
    format: 'pem' // 私钥输出格式
    }
    });
    console.info('生成的公钥:');
    console.info(publicKey);
    console.info('生成的私钥:');
    console.info(privateKey);
  3. 打开命令行工具,进入generateKeyPair.js所在目录,执行node generateKeyPair.js命令。

  4. 从结果中拷贝生成的公私钥并保存。结果如下图所示:

方式2:使用在线工具生成

开发者可自行搜索使用相关开源的在线工具或网站生成相应证书公私钥对。

生成公私钥为敏感操作,请谨慎使用,建议开发者自行生成密钥对。

上传商户证书

证书公钥生成后须商户手动上传到华为支付商户平台,用于华为支付服务器对支付请求验证签名。

  1. 私钥信息用于对发送请求的内容签名,请妥善保管,请勿公开泄露。
  2. 商户成功登录华为支付商户平台后,须在证书管理中上传商户证书,上传完商户证书后商户方可进行交易。证书必须与商户号相匹配且是有效的。

上传的证书公钥需要满足如下要求:

  • 后缀要求:华为支付商户平台接收的公钥证书格式为“*.pem”。
  • 格式要求:生成RSA公私钥时,密钥长度要求不小于3072,密钥格式为PKCS#8。

请登录华为支付商户平台,在“证书管理 > 上传商户证书”模块进行商户证书公钥上传。

待上传公钥信息示例:

-----BEGIN PUBLIC KEY-----
MIIBIjANBgkq*********************************vW7gQTM8BHFTezQjdRI
A7xka2TaVHt***********************************rOA3P5rew9cO96q/7Z
kQ6lRd3oVsf************************************rGYCrA2RVgr79mRx+
s22qfA5FdTC*************************************i6I2cRVb1grBQphR
yFBxCGC/NeV*************************************K1QM1SC4GCORHocS
MQvApBQwQF9*************************************eEQvwpVfFxg4dGBz
DQIDAQAB
-----END PUBLIC KEY-----

华为支付证书

华为支付证书是指由华为支付提供的,包含华为支付平台标识、公钥信息的证书。该证书算法为SM2。

  • 商户请通过华为支付商户平台下载华为支付证书。
  • 华为支付证书中的公钥用于商户对回调通知中的信息进行验签。

下载华为支付证书

登录华为支付商户平台后,通过“商户中心 > 证书管理 > 华为支付证书”页签进行华为支付证书下载,该证书用于校验华为支付给商户业务系统发送的信息,如支付结果信息等。