= 4.0.6, PHP 5, PHP 7, PHP 8)openssl_pkcs7_encrypt — 加密一個 S/MIME 消息說明openssl_pkcs7_encrypt( string $infile, string ">

openssl_pkcs7_encrypt

(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)

openssl_pkcs7_encrypt加密一個 S/MIME 消息

說明

openssl_pkcs7_encrypt(
    string $infile,
    string $outfile,
    mixed $recipcerts,
    array $headers,
    int $flags = 0,
    int $cipherid = OPENSSL_CIPHER_RC2_40
): bool

openssl_pkcs7_encrypt() 獲取文件名為infile的文件內(nèi)容并使用 RC2 40位的密碼將之加密,以至于他們只能被預期的名為recipcerts的接收者閱讀。

參數(shù)

infile

outfile

recipcerts

一個單獨的X.509證書,或者一個X.509證書的數(shù)組。

headers

headers 是包含頭信息的數(shù)組,在被加密后將對數(shù)據(jù)進行預處理。

headers 可以是以頭名為鍵值的關聯(lián)數(shù)組,也可以是一個索引數(shù)組,其中每個元素都包含一個單獨的標題行

flags

flags用來指定影響編碼過程的選項 - 參見 PKCS7 常量.

cipherid

密碼常量之一。

返回值

成功時返回 true, 或者在失敗時返回 false。

范例

示例 #1 openssl_pkcs7_encrypt() 范例

<?php
// the message you want to encrypt and send to your secret agent
// in the field, known as nighthawk.  You have his certificate
// in the file nighthawk.pem
$data = <<<EOD
Nighthawk,

Top secret, for your eyes only!

The enemy is closing in! Meet me at the cafe at 8.30am
to collect your forged passport!

HQ
EOD;

// load key
$key file_get_contents("nighthawk.pem");

// save message to file
$fp fopen("msg.txt""w");
fwrite($fp$data);
fclose($fp);

// encrypt it
if (openssl_pkcs7_encrypt("msg.txt""enc.txt"$key,
    array(
"To" => "nighthawk@example.com"// keyed syntax
          
"From: HQ <hq@example.com>"// indexed syntax
          
"Subject" => "Eyes only"))) {
    
// message encrypted - send it!
    
exec(ini_get("sendmail_path") . " < enc.txt");
}
?>