UPDATE (SOLUTION)Since this post seems to get decent amount of attention, I'd like to let you know that the solution ended up being to provide a proper \[code\]enctype\[/code\] (content type) parameter in the \[code\]<FORM>\[/code\] declaration. You must set the value to \[code\]multipart/form-data\[/code\] to prevent encoding that would otherwise take place using the default enctype of \[code\]application/x-www-form-urlencoded\[/code\]. A small excerpt below from Forms in HTML Documents at w3.org:\[quote\] The content type "application/x-www-form-urlencoded" is inefficient for sending large quantities of binary data or text containing non-ASCII characters. The content type "multipart/form-data" should be used for submitting forms that contain files, non-ASCII data, and binary data.\[/quote\]And here is the proper FORM declaration:\[code\]<FORM method="POST" action="/path/to/file/" name="encryptedForm" enctype="multipart/form-data">\[/code\]INITIAL QUESTIONI am working on a form spam protection class which essentially replaces form field names with an encrypted value using mcrypt. The problem with this is that mcrypt encryption is not limited to only alphanumeric characters which would invalidate form fields. Given the code below, can you think of any reason why I'd be having problems decrypting the values of the already encrypted array?\[code\]/** * Two way encryption function to encrypt/decrypt keys with * the DES encryption algorithm. */public static function encryption($text, $encrypt = true){ $encrypted_datahttp://stackoverflow.com/questions/2023109/= ''; $td = mcrypt_module_open('des', '', 'ecb', ''); $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND); if (mcrypt_generic_init($td, substr(self::$randomizer, 16, 8), $iv) != -1) { if ($encrypt) { // attempt to sanitize encryption for use as a form element name $encrypted_data = mcrypt_generic($td, $text); $encrypted_data = base64_encode($encrypted_data); $encrypted_datahttp://stackoverflow.com/questions/2023109/= 'i' . strtr($encrypted_data, '+/=', '-_.'); self::$encrypted[] = $encrypted_data; } else { // reverse form element name sanitization and decrypt $text = substr($text, 1); $text = strtr($text, '-_.', '+/='); $text = base64_decode($text); $encrypted_data = http://stackoverflow.com/questions/2023109/mdecrypt_generic($td, $text); } mcrypt_generic_deinit($td); mcrypt_module_close($td); } return $encrypted_data;}\[/code\]I later make a call setting a hidden form element's value using:\[code\]base64_encode(serialize(self::$encrypted))\[/code\]Essentially the hidden field contains an array of all form fields which were encrypted with their encrypted value. This is so I know which fields need to be decrypted on the backend. Upon form submission this field gets parsed on the backend with the following code:\[code\] // load the mapping entry $encrypted_fields = $input->post('encrypted', ''); if (empty($encrypted_fields)) { throw new AppException('The encrypted form field was empty.'); } // decompress array of encrypted fields $encrypted_fields = @unserialize(base64_decode($encrypted_fields)); if ($encrypted_fields === false) { throw new AppException('The encrypted form field was not valid.'); } // get the mapping of encrypted keys to key $data = http://stackoverflow.com/questions/2023109/array(); foreach ($_POST as $key => $val) { // if the key is encrypted, add to data array decrypted if (in_array($key, $encrypted_fields)) { $decrypted = self::encryption($key, false); $data[$decrypted] = $val; unset($_POST[$key]); } else { $data[$key] = $val; } } // merge $_POST array with decrypted key array $_POST += $data;\[/code\]My attempts to decrypt the encrypted form field keys are failing. It's simply creating a new garbled key in the \[code\]$_POST\[/code\] array. My guess is that either \[code\]base64_encoding\[/code\] or \[code\]serialization\[/code\] is stripping chars from the \[code\]$encrypted_data\[/code\]. Could somebody verify if this is the culprit and whether there are any alternative methods for encoding form keys?