"4012",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "uid100010",
        "VK_REC_ID"      => "SAMPOPANK",
        "VK_NONCE"       => "4",
        "VK_RETURN"      => "http://127.0.0.1:51139/auth/complete/",
        "VK_DATETIME"    => "2020-12-29T13:44:56+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:51139/auth/complete/ */
        str_pad (mb_strlen($fields["VK_DATETIME"], "UTF-8"), 3, "0", STR_PAD_LEFT) . $fields["VK_DATETIME"] .   /* 2020-12-29T13:44:56+0000 */
        str_pad (mb_strlen($fields["VK_RID"], "UTF-8"),     3, "0", STR_PAD_LEFT) . $fields["VK_RID"];         /*  */
/* $data = "0044012003008009uid100010009SAMPOPANK0014037http://127.0.0.1:51139/auth/complete/0242020-12-29T13:44:56+0000000"; */
// STEP 4. Sign the data with RSA-SHA1 to generate MAC code
// ========================================================
openssl_sign ($data, $signature, $private_key, OPENSSL_ALGO_SHA1);
/* 4i4o9eiRpgEJ5NypbzdyXBoFPGiudCvqBr3fTv+f5UgiFdNFaMh/Za3JO71OhAWeP+87BAFhfPO158Ewxw7XF2tev6uDGkh5ieGWfV6sazqAWcKx/SSHYr9YepmiLha+ZjJQM9/JkPHErBSCKOKQPvAAj4yLFz70mMMnBNCQbPOIOUpSC8qjaIcHlizzAuvgO5Em3NaNQqe9GzhST5OeA7fgndyyiTk6JjARrOe8AX0rfI/NoKhWF8oduSjZRut1R/XTs3hT1jLDCZTnroFlHNXp9+IMhBSYVy4g6OmTj9+quOSU2h/P/PqgUdAklh7gHMTTBQOIjsom2h3cq8S/xQ== */
$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"