"4012",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "uid100010",
        "VK_REC_ID"      => "SAMPOPANK",
        "VK_NONCE"       => "4",
        "VK_RETURN"      => "http://127.0.0.1:58865/auth/complete/",
        "VK_DATETIME"    => "2021-02-18T09:07:41+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:58865/auth/complete/ */
        str_pad (mb_strlen($fields["VK_DATETIME"], "UTF-8"), 3, "0", STR_PAD_LEFT) . $fields["VK_DATETIME"] .   /* 2021-02-18T09:07:41+0000 */
        str_pad (mb_strlen($fields["VK_RID"], "UTF-8"),     3, "0", STR_PAD_LEFT) . $fields["VK_RID"];         /*  */
/* $data = "0044012003008009uid100010009SAMPOPANK0014037http://127.0.0.1:58865/auth/complete/0242021-02-18T09:07:41+0000000"; */
// STEP 4. Sign the data with RSA-SHA1 to generate MAC code
// ========================================================
openssl_sign ($data, $signature, $private_key, OPENSSL_ALGO_SHA1);
/* iKx7ObGlZxDbVB5p5o43S2pfJK2B8/wPcvuAvxvW7NJfpHSLGY9XRGXO1fJ0a1FvTjWVHh8GRWoiOmVFy3etKkhwwe0Et4WG+PxW8SfC23NtPfw6+juMzab3cpgjQAyQJUBI18i473K7wB/ZCv6WCSC8ptt9THO/0mkExeA7DGhxRS1UvYkQ7I3ah6N8iJSQWxw/CDtbDbrsjgRALK+gScCL9UA51Dg7Ce/y6AdfkDscR5yZeVGZYCblJVxUqpJRQrpILy43++BNDcXuNZOW1XVLHCS/NV8ZSJfHOCQDRtftmgdFGjnG+w7H9A9DqJ09AuZ6uzy2vG4tshU1n40vzA== */
$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"