


How does PHP implement AES encryption and decryption consistent with Java?
Apr 01, 2025 am 07:15 AMHow to implement AES encryption and decryption in php?
In daily development, we often need to implement consistent encryption and decryption functions among different programming languages. Recently, a developer shared a piece of AES encryption and decryption code implemented in Java, and hopes to achieve the same effect in php. Below we will discuss in detail how to use php to achieve AES encryption and decryption consistent with Java code.
First, we need to understand the implementation details of aes encryption and decryption in Java code. The aes algorithm is used in the java code, and the keygenerator and secureriandom are generated. When encrypted, the data is converted into a hexadecimal string, and when decrypted, the hexadecimal string is converted back to binary data for decryption.
Next, let's look at how to implement similar functions in php. The openssl extension of php provides powerful encryption functions, which we can use to implement AES encryption and decryption. The following is the reference code:
class AESUtil { private static $key = "test"; // Default key/** * Encryption function* * @param string $content data to be encrypted* @param string|null $key The key used to encrypt, if not specified, uses the default key* @return string Encrypted hexadecimal string*/ public static function encrypt($content, $key = null) { if (is_null($key)) { // If no key is specified, use the default key $key = self::$key; } // Generate random initialization vector (IV) $iv_size = openssl_cipher_iv_length('AES-128-CBC'); $iv = openssl_random_pseudo_bytes($iv_size); // Encrypt the data $encrypted_data = openssl_encrypt($content, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); // Connect the IV and the encrypted data as the result of the output $data_with_iv = $iv . $encrypted_data; return strtoupper(bin2hex($data_with_iv)); // Convert the result to a hexadecimal string and return } /** * Decrypt function* * @param string $content data to decrypt (hexadecimal string) * @param string|null $key The key used to decrypt, if not specified, the default key is used * @return string The decrypted data*/ public static function decrypt($content, $key = null) { if (is_null($key)) { // If no key is specified, use the default key $key = self::$key; } // Convert the input hexadecimal string into binary data $data_with_iv = hex2bin($content); // Extract IV and encrypted data from the data $iv_size = openssl_cipher_iv_length('AES-128-CBC'); $iv = substr($data_with_iv, 0, $iv_size); $encrypted_data = substr($data_with_iv, $iv_size); // Decrypt the data $decrypted_data = openssl_decrypt($encrypted_data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); return $decrypted_data; // Return decrypted data} } // Use example $plaintext = "Hello, World!"; $encrypted_text = AESUtil::encrypt($plaintext); $decrypted_text = AESUtil::decrypt($encrypted_text); echo "Original text: " . $plaintext . PHP_EOL; echo "After encryption: " . $encrypted_text . PHP_EOL; echo "After decrypted: " . $decrypted_text . PHP_EOL;
This php code uses aes-128-cbc encryption mode and generates a random iv vector passed as a parameter to the encryption and decryption function. During encryption, the iv vector and the encrypted data are encoded together. When decrypting, the encoded string is first decoded into the iv vector and the ciphertext, and then decrypted. This method ensures that the AES encryption and decryption implemented by PHP is consistent with the Java code.
Through the above method, we can achieve aes encryption and decryption effect consistent with Java code. If you have any further questions or need additional help, please continue to ask questions.
The above is the detailed content of How does PHP implement AES encryption and decryption consistent with Java?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Contents 1. What is ICN? 2. ICNT latest updates 3. Comparison and economic model between ICN and other DePIN projects and economic models 4. Conclusion of the next stage of the DePIN track At the end of May, ICN (ImpossibleCloudNetwork) @ICN_Protocol announced that it had received strategic investment in NGPCapital with a valuation of US$470 million. Many people's first reaction was: "Has Xiaomi invested in Web3?" Although this was not Lei Jun's direct move, the one who had bet on Xiaomi, Helium, and WorkFusion

As July 2025 approaches, the crypto market is hotly discussing which tokens may bring high returns. Are names like Pi, PEPE and FloppyPepe really worth the risky investment? Potential cryptocurrencies worth paying attention to in July 2025: virtual fire or real gold? As mid-2025, the heat of discussions on high-yield crypto assets continues to heat up. Bitcoin trends and "altcoin season" expectations have attracted investors' attention. Do tokens like PiNetwork, PEPE and FloppyPepe have the potential to bring considerable investment returns? Let's analyze its prospects one by one. Altcoin Market: Can July get what it wants? Against the backdrop of Bitcoin’s expected record of historical highs, the “altcoin season” seems to be brewing. Back

BNB is a platform token issued by Binance and has now become a native functional token of the BNB Chain ecosystem. Its main uses include 1. Transaction fee discounts; 2. BNB Chain fuel fee; 3. Participate in the Launchpad project; 4. Payment and consumption. The recommended orders of top exchanges are: 1. Binance, providing the deepest BNB liquidity; 2. Ouyi, comprehensive product line; 3. Huobi, stable and safe operation; 4. Gate.io, rich currency selection; 5. KuCoin, many emerging projects; 6. Kraken, famous for its safety and compliance.

In today's era of rapid development of technology, the integration of artificial intelligence and blockchain is gradually becoming a new trend. The Sahara AI (SAHARA) project came into being, and it is committed to creating the first full-stack AI native blockchain platform, making the future of artificial intelligence more accessible, fair and just, and open to everyone.

How do novice users choose a safe and reliable stablecoin platform? This article recommends the Top 10 stablecoin platforms in 2025, including Binance, OKX, Bybit, Gate.io, HTX, KuCoin, MEXC, Bitget, CoinEx and ProBit, and compares and analyzes them from dimensions such as security, stablecoin types, liquidity, user experience, fee structure and additional functions. The data comes from CoinGecko, DefiLlama and community evaluation. It is recommended that novices choose platforms that are highly compliant, easy to operate and support Chinese, such as KuCoin and CoinEx, and gradually build confidence through a small number of tests.

Against the backdrop of violent fluctuations in the cryptocurrency market, investors' demand for asset preservation is becoming increasingly prominent. This article aims to answer how to effectively hedge risks in the turbulent currency circle. It will introduce in detail the concept of stablecoin, a core hedge tool, and provide a list of TOP3 stablecoins by analyzing the current highly recognized options in the market. The article will explain how to select and use these stablecoins according to their own needs, so as to better manage risks in an uncertain market environment.

This article will discuss the world's mainstream stablecoins and analyze which stablecoins have the risk aversion attribute of "gold substitute" in the market downward cycle (bear market). We will explain how to judge and choose a relatively stable value storage tool in a bear market by comparing the market value, endorsement mechanism, transparency, and comprehensively combining common views on the Internet, and explain this analysis process.

Robinhood launched OpenAI and SpaceX tokenized stocks caused controversy, with Elon Musk and Sam Altman fighting each other over the nature of the so-called "fake equity". Recently, the intersection of Elon Musk, Sam Altman and Robinhood has become the focus of public attention, all of which stems from tokenized equity. Robinhood's launch of tokenized stocks in private companies such as OpenAI and SpaceX to European users has sparked heated debate and accompanied by clarification and criticism from all parties. Robinhood's tokenized equity: A bold attempt? Robin, led by CEO Vlad Tenev
