


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)soalan yang sering ditanya mengenai mendaftar untuk paypal
Bagaimana saya boleh memastikan akaun PayPal saya selamat semasa pendaftaran? Untuk memastikan akaun anda selamat, gunakan kata laluan yang kuat dan unik yang merangkumi campuran huruf, nombor, dan aksara khas. Juga, pastikan untuk memberikan maklumat peribadi yang tepat semasa pendaftaran. PayPal menggunakan maklumat ini untuk mengesahkan identiti anda dan melindungi akaun anda dari aktiviti penipuan. kad kredit. Semasa proses pendaftaran, anda boleh memilih untuk menghubungkan akaun bank dan bukannya kad kredit. Walau bagaimanapun, menghubungkan kad kredit boleh memberikan pilihan pembayaran tambahan dan ciri keselamatan.
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.
Apa yang berlaku jika saya lupa kata laluan paypal saya semasa pendaftaran? "Lupa kata laluan anda?" pautan pada halaman log masuk. Anda kemudiannya akan diminta untuk memasukkan alamat e -mel anda, dan PayPal akan menghantar e -mel kepada anda dengan arahan mengenai cara menetapkan semula kata laluan anda.
Bolehkah saya menukar maklumat yang saya berikan semasa pendaftaran PayPal?
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!

JavaScript adalah di tengah -tengah laman web moden kerana ia meningkatkan interaktiviti dan dinamik laman web. 1) Ia membolehkan untuk menukar kandungan tanpa menyegarkan halaman, 2) memanipulasi laman web melalui Domapi, 3) menyokong kesan interaktif kompleks seperti animasi dan drag-and-drop, 4) mengoptimumkan prestasi dan amalan terbaik untuk meningkatkan pengalaman pengguna.

C dan JavaScript mencapai interoperabilitas melalui webassembly. 1) Kod C disusun ke dalam modul WebAssembly dan diperkenalkan ke dalam persekitaran JavaScript untuk meningkatkan kuasa pengkomputeran. 2) Dalam pembangunan permainan, C mengendalikan enjin fizik dan rendering grafik, dan JavaScript bertanggungjawab untuk logik permainan dan antara muka pengguna.

JavaScript digunakan secara meluas di laman web, aplikasi mudah alih, aplikasi desktop dan pengaturcaraan sisi pelayan. 1) Dalam pembangunan laman web, JavaScript mengendalikan DOM bersama -sama dengan HTML dan CSS untuk mencapai kesan dinamik dan menyokong rangka kerja seperti JQuery dan React. 2) Melalui reaktnatif dan ionik, JavaScript digunakan untuk membangunkan aplikasi mudah alih rentas platform. 3) Rangka kerja elektron membolehkan JavaScript membina aplikasi desktop. 4) Node.js membolehkan JavaScript berjalan di sisi pelayan dan menyokong permintaan serentak yang tinggi.

Python lebih sesuai untuk sains data dan automasi, manakala JavaScript lebih sesuai untuk pembangunan front-end dan penuh. 1. Python berfungsi dengan baik dalam sains data dan pembelajaran mesin, menggunakan perpustakaan seperti numpy dan panda untuk pemprosesan data dan pemodelan. 2. Python adalah ringkas dan cekap dalam automasi dan skrip. 3. JavaScript sangat diperlukan dalam pembangunan front-end dan digunakan untuk membina laman web dinamik dan aplikasi satu halaman. 4. JavaScript memainkan peranan dalam pembangunan back-end melalui Node.js dan menyokong pembangunan stack penuh.

C dan C memainkan peranan penting dalam enjin JavaScript, terutamanya digunakan untuk melaksanakan jurubahasa dan penyusun JIT. 1) C digunakan untuk menghuraikan kod sumber JavaScript dan menghasilkan pokok sintaks abstrak. 2) C bertanggungjawab untuk menjana dan melaksanakan bytecode. 3) C melaksanakan pengkompil JIT, mengoptimumkan dan menyusun kod hot-spot semasa runtime, dan dengan ketara meningkatkan kecekapan pelaksanaan JavaScript.

Aplikasi JavaScript di dunia nyata termasuk pembangunan depan dan back-end. 1) Memaparkan aplikasi front-end dengan membina aplikasi senarai TODO, yang melibatkan operasi DOM dan pemprosesan acara. 2) Membina Restfulapi melalui Node.js dan menyatakan untuk menunjukkan aplikasi back-end.

Penggunaan utama JavaScript dalam pembangunan web termasuk interaksi klien, pengesahan bentuk dan komunikasi tak segerak. 1) kemas kini kandungan dinamik dan interaksi pengguna melalui operasi DOM; 2) pengesahan pelanggan dijalankan sebelum pengguna mengemukakan data untuk meningkatkan pengalaman pengguna; 3) Komunikasi yang tidak bersesuaian dengan pelayan dicapai melalui teknologi Ajax.

Memahami bagaimana enjin JavaScript berfungsi secara dalaman adalah penting kepada pemaju kerana ia membantu menulis kod yang lebih cekap dan memahami kesesakan prestasi dan strategi pengoptimuman. 1) aliran kerja enjin termasuk tiga peringkat: parsing, penyusun dan pelaksanaan; 2) Semasa proses pelaksanaan, enjin akan melakukan pengoptimuman dinamik, seperti cache dalam talian dan kelas tersembunyi; 3) Amalan terbaik termasuk mengelakkan pembolehubah global, mengoptimumkan gelung, menggunakan const dan membiarkan, dan mengelakkan penggunaan penutupan yang berlebihan.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini
