"4012",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "uid100010",
        "VK_REC_ID"      => "SAMPOPANK",
        "VK_NONCE"       => "4",
        "VK_RETURN"      => "http://127.0.0.1:46525/auth/complete/",
        "VK_DATETIME"    => "2021-02-18T08:57:52+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:46525/auth/complete/ */
        str_pad (mb_strlen($fields["VK_DATETIME"], "UTF-8"), 3, "0", STR_PAD_LEFT) . $fields["VK_DATETIME"] .   /* 2021-02-18T08:57:52+0000 */
        str_pad (mb_strlen($fields["VK_RID"], "UTF-8"),     3, "0", STR_PAD_LEFT) . $fields["VK_RID"];         /*  */
/* $data = "0044012003008009uid100010009SAMPOPANK0014037http://127.0.0.1:46525/auth/complete/0242021-02-18T08:57:52+0000000"; */
// STEP 4. Sign the data with RSA-SHA1 to generate MAC code
// ========================================================
openssl_sign ($data, $signature, $private_key, OPENSSL_ALGO_SHA1);
/* e8A8BZV4xZDy6KseYjOVrHJlo8ZDRzP3wD/x3g3Hw5WyQ3bkwHQJHOW66q3tlP7a26le9kapZgYLzmvhlAg5k7KIBWN0/q/pOcTCjRzJlB9oCIncN2mzpLw7KuGbctGzZSPNFRX9RUpSPPHpxGWvYRQ71CktqwPwXDDSfceorV7A8thxo24PoYpJXkg+2g8vvOZW5IwvJG/avHYMTMbvmF8yDkIQJi7y5nHcF7RgLwzICdrfRLuwrIigZz75Zn2+8w5NPHrBMQdp40ImHUursnmMEpYnXf1yUsIUN9Dfb+Ooj6dUq5Sf6UOl6UMcFA5vv13jh0yqVf8Fq8tWObZC5g== */
$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"