"4012",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "uid100010",
        "VK_REC_ID"      => "SAMPOPANK",
        "VK_NONCE"       => "4",
        "VK_RETURN"      => "http://127.0.0.1:58351/auth/complete/",
        "VK_DATETIME"    => "2021-02-18T08:24:38+0000",
        "VK_ENCODING"    => "UTF-8",
);
// STEP 3. Generate data to be signed
// ==================================
// Data to be signed is in the form of XXXYYYYY where XXX is 3 char
// zero padded length of the value and YYY the value itself
// NB! Danske expects symbol count, not byte count with UTF-8,
// so use `mb_strlen` instead of `strlen` to detect the length of a string
$data = str_pad (mb_strlen($fields["VK_SERVICE"], "UTF-8"), 3, "0", STR_PAD_LEFT) . $fields["VK_SERVICE"] .    /* 4012 */
        str_pad (mb_strlen($fields["VK_VERSION"], "UTF-8"), 3, "0", STR_PAD_LEFT) . $fields["VK_VERSION"] .    /* 008 */
        str_pad (mb_strlen($fields["VK_SND_ID"], "UTF-8"),  3, "0", STR_PAD_LEFT) . $fields["VK_SND_ID"] .     /* uid100010 */
        str_pad (mb_strlen($fields["VK_REC_ID"], "UTF-8"),  3, "0", STR_PAD_LEFT) . $fields["VK_REC_ID"] .     /* SAMPOPANK */
        str_pad (mb_strlen($fields["VK_NONCE"], "UTF-8"),   3, "0", STR_PAD_LEFT) . $fields["VK_NONCE"] .      /* 4 */
        str_pad (mb_strlen($fields["VK_RETURN"], "UTF-8"),  3, "0", STR_PAD_LEFT) . $fields["VK_RETURN"] .     /* http://127.0.0.1:58351/auth/complete/ */
        str_pad (mb_strlen($fields["VK_DATETIME"], "UTF-8"), 3, "0", STR_PAD_LEFT) . $fields["VK_DATETIME"] .   /* 2021-02-18T08:24:38+0000 */
        str_pad (mb_strlen($fields["VK_RID"], "UTF-8"),     3, "0", STR_PAD_LEFT) . $fields["VK_RID"];         /*  */
/* $data = "0044012003008009uid100010009SAMPOPANK0014037http://127.0.0.1:58351/auth/complete/0242021-02-18T08:24:38+0000000"; */
// STEP 4. Sign the data with RSA-SHA1 to generate MAC code
// ========================================================
openssl_sign ($data, $signature, $private_key, OPENSSL_ALGO_SHA1);
/* VGEDxww8J9iGuMLYhAkzsPf4Rr/NsStp7gBU3XazvLL3gbqTxEmB1PQqllhpyXia3NkQVRraoz9wUaIYVr3Wgw0glQT4cnp3qxEfqXYcnr70+JYyHuqm5VU46CCPgbt8uks0aLzv8mp30Yb3t76lvW1liiPE5Cb6yhzfewTJKTuzKIGD1ToDbxC/9Hp9m17gxrwTKDe/l08L+L3ygUacNzqem72OH7im0ifF0PVAsK0tPnFFrqAmpVondkn6q+GGx1ugdF1+EQeQuoV9bxHAlAEajz7dZ/8Q4ZcZ04YIWr9nv6ggUwYo7P38Z7heUdbkLLoWJap5G+Ry9DDAGlEm6w== */
$fields["VK_MAC"] = base64_encode($signature);
// STEP 5. Generate POST form with payment data that will be sent to the bank
// ==========================================================================
?>
        
        Autentimise näidisrakendus "Danske"