Home >Backend Development >PHP Problem >What are the commonly used encryption methods in php?

What are the commonly used encryption methods in php?

青灯夜游
青灯夜游Original
2021-03-26 11:42:266740browse

PHP commonly used encryption methods are: 1. Use the md5() function; 2. Use the crypt() function; 3. Use the sha1() function; 4. Use the urlencode() function; 5. Use base64_encode( ) function; 6. Use the password_hash() function.

What are the commonly used encryption methods in php?

The operating environment of this tutorial: windows7 system, PHP7.1 version, DELL G3 computer

Commonly used PHP encryption method

1. MD5 encryption

string md5 ( string $str [, bool $raw_output = false ] )

Parameters

  • str -- Original string.

  • raw_output -- If the optional raw_output is set to TRUE, the MD5 message digest will be returned in raw binary format with a length of 16 bytes.

2. Crype Encryption

crypt() Returns a Cryptocryption algorithm based on the standard UNIX DES algorithm or other alternative algorithms available on the system. Hash string.

string crypt ( string $str [, string $salt ] )

Parameters

  • str -- The string to be hashed.

  • salt -- Optional salt value string. If not provided, algorithm behavior will be determined by different algorithm implementations and may lead to unpredictable endings.

This is also an irreversible encryption

3. Sha1 encryption

string sha1 ( string $str [, bool $raw_output = false ] )

Parameters

  • str -- Input string.

  • raw_output -- If the optional raw_output parameter is set to TRUE, the sha1 digest will be returned in raw format with a length of 20 characters, otherwise the return value will be a 40-character length sixteen Base numbers.

This is also an irreversible encryption

4. URL encryption

string urlencode ( string $str )

This function facilitates encoding and Use this for the request part of the URL, and it also makes it easy to pass variables to the next page.

Returns a string. All non-alphanumeric characters in this string except -_. will be replaced with a percent sign (%) followed by two hexadecimal digits. Spaces are encoded as plus( ). This encoding is the same as the encoding of WWW form POST data, and the same encoding as the application/x-www-form-urlencoded media type. For historical reasons, this encoding differs from the RFC1738 encoding in encoding spaces as plus signs ( ).

string urldecode ( string $str )

Decode any %## in the given encoded string. The plus sign (' ') is decoded into a space character.

This is a reversible encryption, the urlencode method is used for encryption, and the urldecode method is used for decryption

5. Base64 information encoding encryption

string base64_encode ( string $data )

Use base64 to encode data.

This encoding is designed to enable binary data to be transmitted over non-pure 8-bit transport layers, such as the body of an email.

Base64-encoded data takes up about 33% more space than the original data.

string base64_decode ( string $data [, bool $strict = false ] )

Decode base64 encoded data.

Parameters

  • #data -- Encoded data.

  • strict -- Returns FALSE if the input data exceeds the base64 alphabet.

6.phpass (recommended)

Tested with phpass 0.3, the standard way to protect user passwords by hashing them before storing them in the database. Many commonly used hashing algorithms such as md5 and even sha1 are not secure for password storage because hackers can easily crack passwords using those algorithms.

The most secure way to hash passwords is to use the bcrypt algorithm. The open source phpass library provides this function in an easy-to-use class

7. Personally think a better password encryption method

PHP5.5 introduces the Password Hashing function , the kernel comes with no need to install extensions. It is possible to test it under PHP5.4. It is best to confirm whether your current environment supports these functions before using it.

Password Hashing mainly provides 4 functions

//1.查看哈希值的相关信息
array password_get_info (string $hash)
 
//2.创建hash密码
string password_hash(string $password , integer $algo [, array $options ])

//3.判断hash密码是否特定选项、算法所创建
boolean password_needs_rehash (string $hash , integer $algo [, array $options ] 

//4.验证密码
boolean password_verify (string $password , string $hash)

The following examples:

$password = 'password123456';//原始密码
$hash_password = password_hash($password, PASSWORD_BCRYPT);//使用BCRYPT算法加密密码
if (password_verify($password , $hash_password)){
   echo "密码匹配";
}else{  
   echo "密码错误";
}

Recommended learning: "PHP Video Tutorial"

The above is the detailed content of What are the commonly used encryption methods 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