我正在尝试使用PHP-DKIM发送DKIM签名的电子邮件.它有点旧,所以我不得不更改一些东西,但是这让我感到困惑:
Warning: openssl_sign() [function.openssl-sign]: supplied key param cannot be coerced into a private key in /.../pages/user/dkim.php on line 66
Cannot sign
代码的相关部分(请注意,我已经添加了$pkeyid,最初私钥只是直接传递给了open_ssl函数,该函数也不起作用)
$pkeyid = openssl_get_privatekey($open_SSL_priv);
if (openssl_sign($s, $signature, $pkeyid))
return base64_encode($signature) ;
else
die("Cannot sign") ;
因此,很显然这里确实发生了一些糟糕的事情.但是我知道我的私钥和公钥是有效的.我什至尝试了comments for openssl_sign
中提供的示例键,但该键无效
$open_SSL_pub=<<<EOD
-----BEGIN PUBLIC KEY-----
MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBANDiE2+Xi/WnO+s120NiiJhNyIButVu6
zxqlVzz0wy2j4kQVUC4ZRZD80IY+4wIiX2YxKBZKGnd2TtPkcJ/ljkUCAwEAAQ==
-----END PUBLIC KEY-----
EOD;
$open_SSL_priv=<<<EOD
-----BEGIN RSA PRIVATE KEY-----
MIIBOgIBAAJBANDiE2+Xi/WnO+s120NiiJhNyIButVu6zxqlVzz0wy2j4kQVUC4Z
RZD80IY+4wIiX2YxKBZKGnd2TtPkcJ/ljkUCAwEAAQJAL151ZeMKHEU2c1qdRKS9
sTxCcc2pVwoAGVzRccNX16tfmCf8FjxuM3WmLdsPxYoHrwb1LFNxiNk1MXrxjH3R
6QIhAPB7edmcjH4bhMaJBztcbNE1VRCEi/bisAwiPPMq9/2nAiEA3lyc5+f6DEIJ
h1y6BWkdVULDSM+jpi1XiV/DevxuijMCIQCAEPGqHsF+4v7Jj+3HAgh9PU6otj2n
Y79nJtCYmvhoHwIgNDePaS4inApN7omp7WdXyhPZhBmulnGDYvEoGJN66d0CIHra
I2SvDkQ5CmrzkW5qPaE2oO7BSqAhRZxiYpZFb5CI
-----END RSA PRIVATE KEY-----
EOD;
我不知所措. OpenSSL“ 0.9.8e-fips-rhel5 2008年7月1日”已安装并在PHP中处于活动状态.我生成的密钥和该密钥都可以正常工作.那么,为什么openssl_sign继续失败?
解决方法:
使用PHP-DKIM时发生相同的错误
如果没有看到其余的代码,很难确定是否是出于相同的原因.
但是,我的问题是我将PHP-DKIM脚本包含在一个函数中.
即
function sendEmail(){
require 'dkim.php';
//DO STUFF HERE
}
包括函数外的文件停止了错误.
即
require 'dkim.php';
function sendEmail(){
//DO STUFF HERE
}
我希望这有帮助.