"1911",
        "VK_VERSION"     => "008",
        "VK_SND_ID"      => "HP",
        "VK_REC_ID"      => "uid100052",
        "VK_STAMP"       => "2908910",
        "VK_REF"         => "29089109",
        "VK_MSG"         => "Pangalink: 2908910",
        "VK_ENCODING"    => "UTF-8",
        "VK_LANG"        => "EST",
        "VK_MAC"         => "t+1ABe5mfz2KAYMFu/p3nwzCD9seUql7rB4g5w6QdS0z2+d5W+87e/KMedjunVvgdGnCZlc3mClLYTrJqVzQqlQ5KDe1N6gm3FZlvsV9zA85m3zUebrrup1XGB0J5fzeOjtWBkhIgd+q37rROkirJbV+Y2YF9IpHtTbyleyruY4so4cAdn+SOfAggP3OHnOfNed42pFDxS4NA13fSiUMHYtsbFN8fGfkM73WXfk8M386UeYmJteh591mERJoDncVxXZaOR9Zuyhly49NHUhtbhvObsqBRwj62N4Pd3rGrKt6IKeNJDlyeGQ36YbIA0umoSbH7/znyT7hagO5bCIK7w==",
        "VK_AUTO"        => "N"
);
// STEP 3. Generate data to be verified
// ====================================
// Data to be verified is in the form of XXXYYYYY where XXX is 3 char
// zero padded length of the value and YYY the value itself
// NB! Swedbank 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"] .    /* 1911 */
        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"] .     /* HP */
        str_pad (mb_strlen($fields["VK_REC_ID"], "UTF-8"),    3, "0", STR_PAD_LEFT) . $fields["VK_REC_ID"] .     /* uid100052 */
        str_pad (mb_strlen($fields["VK_STAMP"], "UTF-8"),     3, "0", STR_PAD_LEFT) . $fields["VK_STAMP"] .      /* 2908910 */
        str_pad (mb_strlen($fields["VK_REF"], "UTF-8"),       3, "0", STR_PAD_LEFT) . $fields["VK_REF"] .        /* 29089109 */
        str_pad (mb_strlen($fields["VK_MSG"], "UTF-8"),       3, "0", STR_PAD_LEFT) . $fields["VK_MSG"];         /* Pangalink: 2908910 */
/* $data = "0041911003008002HP009uid100052007290891000829089109018Pangalink: 2908910"; */
// STEP 4. Verify the data with RSA-SHA1
// =====================================
if (openssl_verify ($data, base64_decode($fields["VK_MAC"]), $public_key) !== 1) {
    $signatureVerified = false;
}else{
    $signatureVerified = true;
}
// STEP 5. Display output of the received payment
// ==============================================
?>
    Payment results
    Payment: 
    Signature: