Merhaba sayın r10
paytr test modunda hiç bir hata almadan başarılı bir şekilde geçiyorum fakat canlı mod'a geçmeye çalıştığımda
BİLDİRİM URL'DE SORUN VAR: Ödeme sonucu sitenize bildirilemiyor. hatası almaktayım 2. aşamadan.
destek açtım paytr'ye gelen yanıt şu şekilde
İlgili hata PayTR tarafından post edilen hash ile tarafınızca oluşuturulan hash değelerinin tip uyuşmazlığından kaynaklanabilmektedir. Hash değerlerinin aynı tipte olduğunu kontrol etmenizi rica ederiz. (Hataya Sebep Örnek : String hash , Byte hash)
ALTTAKİ KODLARDA EKSİK BİR ŞEY VARMIDIR VEYA SORUN NEDEN KAYNAKLANABİLİR.
paytr-bildirim.php kodlarım şu şekilde.
<?php
include 'panel/db-ayar.php';
if($_POST){
$paytr = $db->query("SELECT * FROM paytr_api LIMIT 1")->fetch(PDO::FETCH_ASSOC);
## 2. ADIM için örnek kodlar ##
## ÖNEMLİ UYARILAR ##
## 1) Bu sayfaya oturum (SESSION) ile veri taşıyamazsınız. Çünkü bu sayfa müşterilerin yönlendirildiği bir sayfa değildir.
## 2) Entegrasyonun 1. ADIM'ında gönderdiğniz merchant_oid değeri bu sayfaya POST ile gelir. Bu değeri kullanarak
## veri tabanınızdan ilgili siparişi tespit edip onaylamalı veya iptal etmelisiniz.
## 3) Aynı sipariş için birden fazla bildirim ulaşabilir (Ağ bağlantı sorunları vb. nedeniyle). Bu nedenle öncelikle
## siparişin durumunu veri tabanınızdan kontrol edin, eğer onaylandıysa tekrar işlem yapmayın. Örneği aşağıda bulunmaktadır.
$post = $_POST;
####################### DÜZENLEMESİ ZORUNLU ALANLAR #######################
#
## API Entegrasyon Bilgileri - Mağaza paneline giriş yaparak BİLGİ sayfasından alabilirsiniz.
$merchant_id = $paytr[*********']; GÜVENLİK AMAÇLI GİZLENMİŞTİR
$merchant_key = $paytr['*************']; GÜVENLİK AMAÇLI GİZLENMİŞTİR
$merchant_salt = $paytr['************']; GÜVENLİK AMAÇLI GİZLENMİŞTİR
###########################################################################
####### Bu kısımda herhangi bir değişiklik yapmanıza gerek yoktur. #######
#
## POST değerleri ile hash oluştur.
$hash = base64_encode( hash_hmac('sha256', $post['merchant_oid'].$merchant_salt.$post['status'].$post['total_amount'], $merchant_key, true) );
#
## Oluşturulan hash'i, paytr'dan gelen post içindeki hash ile karşılaştır (isteğin paytr'dan geldiğine ve değişmediğine emin olmak için)
## Bu işlemi yapmazsanız maddi zarara uğramanız olasıdır.
if( $hash != $post['hash'] )
die('PAYTR notification failed: bad hash');
###########################################################################
## BURADA YAPILMASI GEREKENLER
## 1) Siparişin durumunu $post['merchant_oid'] değerini kullanarak veri tabanınızdan sorgulayın.
## 2) Eğer sipariş zaten daha önceden onaylandıysa veya iptal edildiyse echo "OK"; exit; yaparak sonlandırın.
/* Sipariş durum sorgulama örnek
$durum = SQL
if($durum == "onay" || $durum == "iptal"){
echo "OK";
exit;
}
*/
if( $post['status'] == 'success' ) { ## Ödeme Onaylandı
## BURADA YAPILMASI GEREKENLER
## 1) Siparişi onaylayın.
## 2) Eğer müşterinize mesaj / SMS / e-posta gibi bilgilendirme yapacaksanız bu aşamada yapmalısınız.
## 3) 1. ADIM'da gönderilen payment_amount sipariş tutarı taksitli alışveriş yapılması durumunda
## değişebilir. Güncel tutarı $post['total_amount'] değerinden alarak muhasebe işlemlerinizde kullanabilirsiniz.
$query = $db->prepare("SELECT * FROM siparis where siparis_key=:siparis_key LIMIT 1");
$gel = $query->execute(array(":siparis_key"=>$post['merchant_oid']));
$gel = $query->fetch(PDO::FETCH_ASSOC);
if($gel){
$islem = $db->prepare("UPDATE siparis SET kredi_karti_odendi = ? WHERE id = ?");
$islem = $islem->execute(array(1,$gel['id']));
echo "OK";
}else{
$query = $db->prepare("SELECT * FROM doping_siparis where siparis_key=:siparis_key LIMIT 1");
$gel = $query->execute(array(":siparis_key"=>$post['merchant_oid']));
$gel = $query->fetch(PDO::FETCH_ASSOC);
if($gel){
$islem = $db->prepare("UPDATE doping_siparis SET odendi = ? WHERE id = ?");
$islem = $islem->execute(array(1,$gel['id']));
}
}
} else { ## Ödemeye Onay Verilmedi
## BURADA YAPILMASI GEREKENLER
## 1) Siparişi iptal edin.
## 2) Eğer ödemenin onaylanmama sebebini kayıt edecekseniz aşağıdaki değerleri kullanabilirsiniz.
## $post['failed_reason_code'] - başarısız hata kodu
## $post['failed_reason_msg'] - başarısız hata mesajı
echo "error";
}
exit;
}
?>