如何匹配SHA256输出



我有一个使用编译的二进制的设备来生成sha256键,该键需要在使用PHP(7.3(的服务器上进行身份验证,并且使用相同的数据,所得密钥在它们时是不同的应该匹配。

二进制文件与此处发布的.sh文件相同。

我缺少什么?

这是.sh代码

#!/bin/sh
SEC="xyxyxyxyxyxyxyxyxyxyxyxyxyxyxy"
if [ -z $1 ]
then
    PROD=$(cat prod.txt)
else
    PROD=$1
    EXPIRE=$2
fi
SDATA="${PROD}$${SEC}$${EXPIRE}"
KEY=$(echo -n ${SDATA} | openssl sha256 -binary | base64)
echo "ABC TXYZ Gen"
echo "Code: ${PROD}"
[ ! -z "${EXPIRE}" ] && echo "Expire date : ${EXPIRE}"
echo "Activate code:"
echo ${KEY%%=} | tee activate.txt

这是php

public function generateActivate($params = [])
{
    if (!isset($params['Mod'])) {
        return false;
    }
    if (!isset($params['Prod'])) {
        return false;
    }
    if (!isset($params['Vers'])) {
        return false;
    }
    $sec="xyxyxyxyxyxyxyxyxyxyxyxyxyxyxy
    $data = $params['Prod'].$sec;
    $params['Activate'] = base64_encode(hash('sha256', $data, true));

不幸的是,我无法在服务器上运行编译的二进制文件,因为它要求服务器上没有glib2.28版本(CentOS 7(。

您的外壳代码

SDATA="${PROD}$${SEC}$${EXPIRE}"

您的PHP具有:

$data = $params['Prod'].$sec;

从外壳代码中删除美元和到期:

SDATA="${PROD}${SEC}"

或将它们添加到PHP:

$data = $params['Prod'] . '$' . $sec . '$' . $params['Expire'];

最新更新