Rumah >hujung hadapan web >tutorial js >Daftar dengan Tutorial PayPal (2/3): Daftar Sebenar dengan Projek PayPal
Terangkan bagaimana kerja PayPal (proses IPN dan PDT). Bab Satu
Bab Tiga
Takeaways Key
Bab Dua
Bab ini memperkenalkan projek sebenar: "Pendaftaran dengan pembayaran", dari awal hingga akhir, untuk menerangkan persediaan dan integrasi akaun PayPal dengan borang daftar dan pangkalan data.
senario projek
Pertama, kami mempunyai borang pendaftaran.
Struktur pangkalan data
rajah e-r:
Temp_register Jadual: Akaun pengguna kedai sementara dan kata laluan pengguna, tunggu pembayaran. Jika dibayar, tuple akan dipadam, dan berpindah ke Jadual Pengguna.
Skema pangkalan data:
<span>CREATE TABLE IF NOT EXISTS <span>`payment`</span> (
</span><span><span>`payId`</span> int(11) NOT NULL AUTO_INCREMENT,
</span><span><span>`timestamp`</span> bigint(20) DEFAULT NULL,
</span><span><span>`paid`</span> float DEFAULT NULL COMMENT 'user paid amount returned by paypal',
</span><span><span>`bankFee`</span> float DEFAULT NULL,
</span><span><span>`currency`</span> varchar(4) DEFAULT NULL,
</span><span><span>`txnId`</span> varchar(32) DEFAULT NULL COMMENT 'Transaction ID: specify single unique transaction from paypal. if this field is NOT NULL, means this payment has been process already. So if IPN returns to PHP, we can refuse to update our database.',
</span><span><span>`status`</span> varchar(16) DEFAULT NULL,
</span><span><span>`uid`</span> int(11) DEFAULT NULL COMMENT 'FK to users PK',
</span><span>PRIMARY KEY (<span>`payId`</span>),
</span><span>KEY <span>`uid`</span> (<span>`uid`</span>)
</span><span>) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
</span><span>CREATE TABLE IF NOT EXISTS <span>`temp_register`</span> (
</span><span><span>`tRegId`</span> int(11) NOT NULL AUTO_INCREMENT,
</span><span><span>`fullName`</span> varchar(255) DEFAULT NULL,
</span><span><span>`uAcc`</span> varchar(255) DEFAULT NULL,
</span><span><span>`uPwd`</span> varchar(32) DEFAULT NULL,
</span><span>PRIMARY KEY (<span>`tRegId`</span>)
</span><span>) ENGINE=InnoDB DEFAULT CHARSET=latin1 COMMENT='prevent unpaid user take uAcc(UNIQUE) in our users table' AUTO_INCREMENT=1 ;
</span><span>CREATE TABLE IF NOT EXISTS <span>`users`</span> (
</span><span><span>`uid`</span> int(11) NOT NULL AUTO_INCREMENT,
</span><span><span>`fullName`</span> varchar(255) DEFAULT NULL,
</span><span><span>`uAcc`</span> varchar(255) NOT NULL,
</span><span><span>`uPwd`</span> varchar(32) NOT NULL,
</span><span><span>`token`</span> varchar(32) DEFAULT NULL,
</span><span><span>`verified`</span> tinyint(1) NOT NULL DEFAULT '0',
</span><span><span>`priviledge`</span> enum('delegate','admin','developer') NOT NULL DEFAULT 'delegate',
</span><span>PRIMARY KEY (<span>`uid`</span>)
</span><span>) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
</span><span>ALTER TABLE <span>`payment`</span>
</span><span>ADD CONSTRAINT <span>`payment_ibfk_1`</span> FOREIGN KEY (<span>`uid`</span>) REFERENCES <span>`users`</span> (<span>`uid`</span>);</span>
antara muka pengguna
Aliran Kerja Projek
isi borang, dan semua input disahkan.
Persediaan PayPal Sandbox
Sebelum kita memulakan pengekodan, kita perlu menyiapkan akaun kotak pasir PayPal terlebih dahulu.
Katakan anda telah mendaftarkan akaun pemaju PayPal, dan telah membuat satu akaun pengguna perniagaan dan satu akaun pembeli di Sandbox.
Kemudian pilih akaun perniagaan, dan klik pada butang 'Masukkan Tapak Ujian Sandbox'.
Anda dapat melihat halaman pop-keluar panel utama:
Kemudian anda dapat melihat semua maklumat dan menjual tetapan keutamaan.
Oleh itu, mari kita sediakan semua tiga pilihan satu demi satu.
1. Dayakan PDT dan Tetapan
Persediaan fungsi pengendali PDT anda yang memanggil URL.
2. Dayakan IPN dan Tetapan
Sediakan fungsi pengendali IPN anda yang memanggil URL.
2. Buat butang PayPal dan Tetapan Parameter PayPal
Setelah menjimatkan perubahan anda, anda dapat melihat kod sumber butang PayPal anda:
<span>CREATE TABLE IF NOT EXISTS <span>`payment`</span> (
</span><span><span>`payId`</span> int(11) NOT NULL AUTO_INCREMENT,
</span><span><span>`timestamp`</span> bigint(20) DEFAULT NULL,
</span><span><span>`paid`</span> float DEFAULT NULL COMMENT 'user paid amount returned by paypal',
</span><span><span>`bankFee`</span> float DEFAULT NULL,
</span><span><span>`currency`</span> varchar(4) DEFAULT NULL,
</span><span><span>`txnId`</span> varchar(32) DEFAULT NULL COMMENT 'Transaction ID: specify single unique transaction from paypal. if this field is NOT NULL, means this payment has been process already. So if IPN returns to PHP, we can refuse to update our database.',
</span><span><span>`status`</span> varchar(16) DEFAULT NULL,
</span><span><span>`uid`</span> int(11) DEFAULT NULL COMMENT 'FK to users PK',
</span><span>PRIMARY KEY (<span>`payId`</span>),
</span><span>KEY <span>`uid`</span> (<span>`uid`</span>)
</span><span>) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
</span><span>CREATE TABLE IF NOT EXISTS <span>`temp_register`</span> (
</span><span><span>`tRegId`</span> int(11) NOT NULL AUTO_INCREMENT,
</span><span><span>`fullName`</span> varchar(255) DEFAULT NULL,
</span><span><span>`uAcc`</span> varchar(255) DEFAULT NULL,
</span><span><span>`uPwd`</span> varchar(32) DEFAULT NULL,
</span><span>PRIMARY KEY (<span>`tRegId`</span>)
</span><span>) ENGINE=InnoDB DEFAULT CHARSET=latin1 COMMENT='prevent unpaid user take uAcc(UNIQUE) in our users table' AUTO_INCREMENT=1 ;
</span><span>CREATE TABLE IF NOT EXISTS <span>`users`</span> (
</span><span><span>`uid`</span> int(11) NOT NULL AUTO_INCREMENT,
</span><span><span>`fullName`</span> varchar(255) DEFAULT NULL,
</span><span><span>`uAcc`</span> varchar(255) NOT NULL,
</span><span><span>`uPwd`</span> varchar(32) NOT NULL,
</span><span><span>`token`</span> varchar(32) DEFAULT NULL,
</span><span><span>`verified`</span> tinyint(1) NOT NULL DEFAULT '0',
</span><span><span>`priviledge`</span> enum('delegate','admin','developer') NOT NULL DEFAULT 'delegate',
</span><span>PRIMARY KEY (<span>`uid`</span>)
</span><span>) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
</span><span>ALTER TABLE <span>`payment`</span>
</span><span>ADD CONSTRAINT <span>`payment_ibfk_1`</span> FOREIGN KEY (<span>`uid`</span>) REFERENCES <span>`users`</span> (<span>`uid`</span>);</span>
Adalah mudah untuk mengetahui bahawa butang sebenarnya adalah bentuk, jadi kita perlu menyiarkan data menggunakan inputnya.
Apabila kami menjana butang 'daftar' kami, URL redirect, harus mengandungi '& cmd = _s-xclick' dan '& hosted_button_id = ha9dzbckxkcl2'.
Sekarang, akaun kotak pasir PayPal telah disediakan. Kemudian mula kod pengendali PDT dan IPN anda.
fungsi pengendali PDT
Kod sumber:
Penjelasan:
PayPal Call pdTheHandler () fungsi, maka proses fungsi pengendali ini _pdt (). Seperti yang anda lihat, ia menerima parameter yang disediakan oleh PayPal, dari URL ($ _get). Jadi kami menyiarkan Token dan TX kembali ke PayPal, melalui FSOCK SSL. Kemudian PayPal akan mengembalikan rekod pembayaran, dan hasil pembayaran (kejayaan/gagal). _Pdt () melepasi data tersebut kepada _validatePayPal () yang menjimatkan data ke dalam pangkalan data. Kemudian, halaman mengalihkan mengikut pulangan.
fungsi pengendali ipn
Kod sumber:
<span>/**
</span><span>* PAYPAL: PDT HANDLER:
</span><span>* ====================
</span><span>* called by PayPal, send tokens back
</span><span>* get payment details and payment result
</span><span>* <span>@return $ret array contains result true/false, and user account or error message
</span></span><span>*/
</span><span>private function _PDT()
</span><span>{
</span><span>// some indexes can not be missing:
</span><span>$ruler = array(
</span><span>'tx', // token from paypal
</span><span>);
</span><span>if(count(array_diff($ruler, array_keys($_GET))))
</span><span>{
</span><span>return array('result' => false, 'error' => 'Index missing ... ', 'index' => $_GET, 'missing' => array_diff($ruler, array_keys($_GET)));
</span><span>}
</span><span>// read the post from PayPal system and add 'cmd'
</span><span>$req = 'cmd=_notify-synch';
</span><span>// get token and prepare request url (send back to paypal)
</span><span>$tx_token = $_GET['tx'];$auth_token = "_PJaHiwRfwMmWzW-9nuPuSguYxC-1d9KpxaasaNANtIvyOcmqY6jXNkRmxW";
</span><span>// $auth_token = "OxDenzKmrWPyEXU0YzIg2zs-VAe7ufCADyjbfxF_RpREL4rLEslZrSa21R4";
</span>
<span>$req .= "&tx=<span><span>$tx_token</span>&at=<span>$auth_token</span>"</span>;
</span>
<span>// post back to PayPal system to validate
</span>
<span>$header = "POST /cgi-bin/webscr HTTP/1.0rn";
</span>
<span>$header .= "Host: www.sandbox.paypal.comrn";
</span><span>// $header .= "Host: www.paypal.comrn";
</span>
<span>$header .= "Content-Type: application/x-www-form-urlencodedrn";
</span><span>$header .= "Content-Length: " . strlen($req) . "rnrn";
</span>
<span>$fp = fsockopen ('ssl://www.sandbox.paypal.com', 443, $errno, $errstr, 30); // open socket
</span><span>// $fp = fsockopen ('ssl://www.paypal.com', 443, $errno, $errstr, 30); // open socket
</span>
<span>if (!$fp)
</span><span>{
</span><span>// HTML FAIL
</span><span>return array('result' => false, 'error' => 'HTTP error ... ');
</span><span>}
</span><span>else
</span><span>{
</span><span>fputs ($fp, $header . $req);
</span><span>// read the body data
</span><span>$res = '';
</span><span>$headerdone = false;
</span><span>while (!feof($fp))
</span><span>{
</span><span>$line = fgets ($fp, 1024);
</span><span>if (strcmp($line, "rn") == 0)
</span><span>{
</span><span>$headerdone = true; // read the header
</span><span>}
</span><span>else if ($headerdone)
</span><span>{
</span><span>$res .= $line; // header has been read. now read the contents
</span><span>}
</span><span>}
</span>
<span>// parse the data
</span><span>$lines = explode("n", $res);
</span><span>$keyarray = array();
</span><span>if (strcmp ($lines[0], "SUCCESS") == 0)
</span><span>{
</span><span>for ($i=1; $i_validatePaypal($keyarray);
</span><span>}
</span><span>// log for manual investigation
</span><span>else if (strcmp ($lines[0], "FAIL") == 0)
</span><span>{
</span><span>// skipped
</span><span>return array('result' => false, 'error' => 'Transaction failed ... ');
</span><span>}
</span><span>}
</span><span>fclose ($fp);
</span><span>return $ret;
</span><span>}</span>
Penjelasan:
PayPal Call Ipnhandler () Fungsi, maka proses fungsi pengendali ini _ ipn (). Seperti yang anda lihat, ia menerima data yang disediakan oleh PayPal, dari permintaan ($ _POST). Oleh itu, kami menghantar butiran pembayaran kembali ke PayPal, melalui Curl, ini adalah proses jabat tangan. Kemudian PayPal menghantar hasil pembayaran balik (disahkan/tidak sah). Jika ia disahkan, _ipn () melepasi data tersebut kepada _validatePayPal () yang menjimatkan data ke dalam pangkalan data.
Dalam fail zip, ia mengandungi templat, fail JavaScript, CSS, bootstrap, jQuery, plugin debug dan plugin Smarty, dan semua kod sumber PHP teras.
Muat turun Projek (344KB)Apakah faedah mendaftar untuk akaun perniagaan PayPal melalui akaun peribadi? melalui akaun peribadi. Ini termasuk keupayaan untuk menerima pembayaran daripada pelanggan, akses kepada pinjaman perniagaan dan pendahuluan tunai, dan pilihan untuk membuat dan menghantar invois. Akaun perniagaan juga membolehkan anda beroperasi di bawah nama syarikat atau kumpulan. negara dan kawasan di seluruh dunia. Untuk mendaftar untuk akaun PayPal di luar Amerika Syarikat, lawati laman web PayPal untuk negara atau rantau tertentu anda. Proses pendaftaran adalah serupa dengan yang di Amerika Syarikat. Nama undang -undang, alamat, nombor telefon, dan alamat e -mel anda. Anda juga perlu membuat kata laluan dan memilih dua soalan keselamatan untuk membantu melindungi akaun anda. cepat dan mudah. Ia biasanya mengambil masa beberapa minit untuk disiapkan. Walau bagaimanapun, mungkin mengambil masa beberapa hari untuk PayPal untuk mengesahkan akaun bank atau maklumat kad kredit anda. satu akaun PayPal. Walau bagaimanapun, setiap akaun mesti mempunyai alamat e -mel yang unik dan maklumat kewangan. Anda boleh mempunyai satu akaun peribadi dan satu akaun perniagaan.
Ya, anda boleh menukar maklumat yang anda berikan semasa pendaftaran PayPal. Untuk melakukan ini, log masuk ke akaun PayPal anda, pergi ke profil anda, dan pilih maklumat yang ingin anda ubah. Tiada bayaran untuk mendaftar untuk akaun PayPal. Walau bagaimanapun, PayPal mengenakan yuran untuk urus niaga tertentu, seperti menerima bayaran untuk barangan dan perkhidmatan atau menghantar wang ke negara lain.
Atas ialah kandungan terperinci Daftar dengan Tutorial PayPal (2/3): Daftar Sebenar dengan Projek PayPal. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!