Home  >  Article  >  Backend Development  >  Signing and verification in PHP

Signing and verification in PHP

WBOY
WBOYOriginal
2023-05-23 16:10:521702browse

With the development of Internet technology, security has become an increasingly important issue, especially the security of data transmitted in Internet applications. Signature and signature verification technology has become an important means to ensure data security. PHP, as a popular Internet programming language, also provides related functions for signature and signature verification. This article will introduce signature and signature verification in PHP.

1. The concept of signature and signature verification

Signature refers to encrypting data to generate a specific string based on the digital signature algorithm. This string can be used to verify the integrity and authenticity of the data and prevent data from being tampered with or counterfeited. Signature verification refers to decrypting the signed string to verify the authenticity and integrity of the decrypted data.

2. Signature functions in PHP

In PHP, signature functions mainly include hash_hmac and openssl_sign functions.

  1. hash_hmac function

hash_hmac function is a hash encryption function that comes with PHP and supports multiple hash algorithms, such as MD5, SHA-1, SHA-256 wait. The steps to use this function to sign are as follows:

$algorithm = "sha256"; // 签名算法
$key = "abcdefg"; // 签名的密钥
$data = "hello world"; // 待签名的数据
$signature = hash_hmac($algorithm, $data, $key); // 签名结果

In the above code, $algorithm specifies the algorithm type, $key is the key for signing, $data is the data to be signed, and $signature is the value obtained after signing. String.

  1. openssl_sign function

openssl_sign function is the openssl extension function in PHP. It supports multiple encryption algorithms. The steps to use this function for signing are as follows:

$algorithm = "sha256"; // 签名算法
$key = "abcdefg"; // 签名的密钥
$data = "hello world"; // 待签名的数据
openssl_sign($data, $signature, $key, $algorithm); // 签名结果

In the above code, $algorithm specifies the algorithm type, $key is the signature key, $data is the data to be signed, and $signature is the string obtained after signing.

3. Signature verification function in PHP

In PHP, the signature verification function mainly includes hash_hmac and openssl_verify functions.

  1. hash_hmac function

For data signed using the hash_hmac function, the steps for using it for signature verification are as follows:

$algorithm = "sha256"; // 签名算法
$key = "abcdefg"; // 签名的密钥
$data = "hello world"; // 待签名的数据
$signature = hash_hmac($algorithm, $data, $key); // 签名结果

// 验证签名
if (hash_equals($signature, hash_hmac($algorithm, $data, $key))) {
    echo "验签成功!";
} else {
    echo "验签失败!";
}

In the above code, First use the hash_hmac function to sign the data to get the signature string. Then use the hash_equals function to determine whether the signature results are the same, and then determine whether the signature verification is successful.

  1. openssl_verify function

For data signed using openssl_sign function, the steps to use it for signature verification are as follows:

$algorithm = "sha256"; // 签名算法
$key = "abcdefg"; // 签名的密钥
$data = "hello world"; // 待签名的数据
openssl_sign($data, $signature, $key, $algorithm); // 签名结果

// 验证签名
if (openssl_verify($data, $signature, $key, $algorithm) === 1) {
    echo "验签成功!";
} else {
    echo "验签失败!";
}

In the above code, First use the openssl_sign function to sign the data and obtain the signature string. Then use the openssl_verify function to determine whether the signature result is correct, and then determine whether the signature verification is successful.

4. Summary

Through the introduction of this article, we have learned about the basic concepts of signature and signature verification in PHP and how to use related functions. In actual Internet applications, signature and signature verification technology have become important means to ensure data security. Being familiar with the signature and signature verification technology in PHP can help us better ensure data security.

The above is the detailed content of Signing and verification in PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn