我有一个使用编译的二进制的设备来生成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'];