I ve been stuck trying to arrive at a best solution for this for a while. I know that an initialization vector has to be unique for each item being encrypted. So if I m encrypting an address and I have it stored all in a single field, I need a single iv for this. But if I have the address spread over multiple fields, I need several ivs, one for each field. This is a problem.
Is there a way to encrypt multiple fields (all in the same row/record) with a single iv, while maintaining the individuality of the fields? The goal is to have a single iv per record.
What I was thinking about doing was something like this
//get input for fields 1-5
//encrypt them, so that each one has its iv appended to it
$field1_enc = encr($field1);
$field2_enc = encr($field2);
$field3_enc = encr($field3);
$field4_enc = encr($field4);
$field5_enc = encr($field5);
//then store them individually in the database
How do I encrypt all fields with a single key? Then what happens when I want to edit any of those fields? (my guess is I d have to un-ecrypt, then re-encrypt with a new iv). But the main question is aside from the concept, I don t understand how to programmatically get this done, i.e. encrypting all fields with a single iv