Mfarhanonline Dev & Design: I had received a comment on my previous post Payment system with Paypal about injecting wrong product price values via third party site using FORM, this is a valid point. So that I had updated my previous post code "success.php" re-confirming the product price details before payment success message and added new field class 'currecy type' on "products" table.
I received a tutorial requests from my reader that asked to me how to implement payment gateway system with Paypal API. In this post I want to explain how to work with Paypal Sandbox test accounts for payment system development and sending arguments while click buy now button. It's simple and very easy to integrate in your web projects.
Sample database design for Payment system. Contains there table users, products and sales.
Users
CREATE TABLE `users` (
`uid` int(11) AUTO_INCREMENT PRIMARY KEY,
`username` varchar(255) UNIQUE KEY,
`password` varchar(255),
`email` varchar(255) UNIQUE KEY,
)
Products
CREATE TABLE `products`
(
`pid` int(11) AUTO_INCREMENT PRIMARY KEY,
`product` varchar(255),
‘product_img` varchar(100),
`price` int(11),
`currency` varchar(10),
)
Sales
CREATE TABLE `sales`
(
`sid` int(11) AUTO_INCREMENT PRIMARY KEY,
`pid` int(11),
`uid` int(11),
`saledate` date,
`transactionid` varchar(125),
FOREIGN KEY(uid) REFERENCES users(uid),
FOREIGN KEY(pid) REFERENCES products(pid)
)
Create a Paypal Sandbox account at https://developer.paypal.com/
Now create test accounts for payment system. Take a look at Sandbox menu left-side top Sandbox->Test Accounts
Here I have created two accounts Buyer (personal) and Seller (merchant/business)
products.php
Contains PHP code. Displaying records from products table product image, product name and product price. Here you have to give your business(seller) $paypal_id id. Modify paypal button form return and cancel_return URLs.
<?php
session_start();
require ‘db_config.php‘;
$uid=$_SESSION['uid'];
$username=$_SESSION['username'];
$paypal_url=’https://www.sandbox.paypal.com/cgi-bin/webscr‘; // Test Paypal API URL
$paypal_id=’your_seller_id‘; // Business email ID
?>
<body>
<h2>Welcome, <?php echo $username;?></h2>
<?php
$result = mysql_query(“SELECT * from products“);
while($row = mysql_fetch_array($result))
{
?>
<img src=”images/<?php echo $row['product_img'];?>” />
Name: <?php echo $row['product'];?>
Price: <?php echo $row['price'];?>$
// Paypal Button
<form action=’<?php echo $paypal_url; ?>‘ method=’post‘ name=’form<?php echo $row['pid']; ?>’>
<input type=’hidden‘ name=’business‘ value=’<?php echo $paypal_id; ?>‘>
<input type=’hidden‘ name=’cmd‘ value=’_xclick‘>
<input type=’hidden‘ name=’item_name‘ value=’<?php echo $row['product'];?>‘>
<input type=’hidden‘ name=’item_number‘ value=’<?php echo $row['pid'];?>‘>
<input type=’hidden‘ name=’amount‘ value=’<?php echo $row['price'];?>‘>
<input type=’hidden‘ name=’no_shipping‘ value=’1‘>
<input type=’hidden‘ name=’currency_code‘ value=’USD‘>
<input type=’hidden‘ name=’cancel_return‘ value=’http://yoursite.com/cancel.php‘>
<input type=’hidden‘ name=’return‘ value=’http://yoursite.com/success.php‘>
<input type=”image” src=”https://paypal.com/en_US/i/btn/btn_buynowCC_LG.gif” name=”submit“>
</form>
<?php
}
?>
</body>
success.php
Paypal payment success return file. Getting Paypal argument like item_number. Paypal data success.php?tx=270233304D340491B&st=Completed&amt=22.00&cc=USD&cm=&item_number=1
<?php
session_start();
require ‘db_config.php‘;
$uid = $_SESSION['uid'];
$username=$_SESSION['username'];
$item_no = $_GET['item_number'];
$item_transaction = $_GET['tx']; // Paypal transaction ID
$item_price = $_GET['amt']; // Paypal received amount
$item_currency = $_GET['cc']; // Paypal received currency type
//Getting product details
$sql=mysql_query(“select product,price,currency from producst where pid=’$item_no’“);
$row=mysql_fetch_array($sql);
$price=$row['price'];
$currency=$row['currency'];
//Rechecking the product price and currency details
if($item_price==$price && item_currency==$currency)
{
$result = mysql_query(“INSERT INTO sales(pid, uid, saledate,transactionid) VALUES(‘$item_no’, ‘$uid’, NOW(),’$item_transaction’)“);
if($result)
{
echo “<h1>Welcome, $username</h1>“;
echo “<h1>Payment Successful</h1>“;
}
}
else
{
echo “Payment Failed”;
}
?>
cancel.php
Paypal API cancel_return file.
<?php
session_start();
$username=$_SESSION['username'];
echo “<h1>Welcome, $username</h1>“;
echo “<h1>Payment Canceled</h1>“;
?>
When your web application test payment system workflow is completed. Change the form action development API URLs to original API URLs and give valid $paypal_id seller email id.
$paypal_url=’https://www.sandbox.paypal.com/cgi-bin/webscr‘;
to
$paypal_url=’https://www.paypal.com/cgi-bin/webscr‘;
data:image/s3,"s3://crabby-images/ef686/ef6865f989667801ea8f38d72e1efcc35c413cbb" alt="Print Print"
data:image/s3,"s3://crabby-images/ff490/ff490c0d9095fb26e0338a6f94d1404eb23a710e" alt="Digg Digg"
data:image/s3,"s3://crabby-images/f94c1/f94c155f7fb96704fddf385b8c78ec1d794853e7" alt="Sphinn Sphinn"
data:image/s3,"s3://crabby-images/e8f27/e8f2703684fdffafdc0befa58bfb41102d6d8a08" alt="del.icio.us del.icio.us"
data:image/s3,"s3://crabby-images/1809c/1809cd4de0dc4f03bae79c9187218a558d8afa3d" alt="Facebook Facebook"
data:image/s3,"s3://crabby-images/845ba/845ba76ae30a636f79c9f50c892d1ab7bdcc8e19" alt="Mixx Mixx"
data:image/s3,"s3://crabby-images/75693/756939dc737482cb76f901e1c3a68513a05f5ef7" alt="Google Bookmarks Google Bookmarks"
data:image/s3,"s3://crabby-images/86169/861694018004c4727549a0138f397665c452e10b" alt="Blogplay Blogplay"
data:image/s3,"s3://crabby-images/96729/967290b2d89a6d9e0744058d91a2628fdb17f18d" alt="Add to favorites Add to favorites"
data:image/s3,"s3://crabby-images/663bb/663bb825b107fef5c9c6eb598347ea490c22266d" alt="BarraPunto BarraPunto"
data:image/s3,"s3://crabby-images/a5701/a5701bb0226e8c30def0715b271bec4cefd31ede" alt="Bitacoras.com Bitacoras.com"
data:image/s3,"s3://crabby-images/807ca/807ca5335269bdcb5c28531b53e29661b89faaf3" alt="BlinkList BlinkList"
data:image/s3,"s3://crabby-images/b2225/b222588757922f318199adb28372cc29f023ddef" alt="blogmarks blogmarks"
data:image/s3,"s3://crabby-images/5d467/5d467c950c3a4be6e8f21516eb7a57399589ba26" alt="Blogosphere News Blogosphere News"
data:image/s3,"s3://crabby-images/68a40/68a40f6c1cb17f96b053ec5f15a8b4a77f64b207" alt="blogtercimlap blogtercimlap"
data:image/s3,"s3://crabby-images/8baea/8baea6d263302a23698fd5fa5406cc0dc3dfda41" alt="connotea connotea"
data:image/s3,"s3://crabby-images/8d834/8d834bf1f6cb6e165ac076721a9c43da3741c59e" alt="Current Current"
data:image/s3,"s3://crabby-images/4b584/4b584e86ad003189d4e09a46e4f98ab29bd08532" alt="Design Float Design Float"
data:image/s3,"s3://crabby-images/c80c7/c80c7d0c8257818346ccdaf931ae32d8ae8018fb" alt="Diggita Diggita"
data:image/s3,"s3://crabby-images/d76ba/d76ba73977fef1bb9d0c6ff5a30de337f4fbd8cc" alt="Diigo Diigo"
data:image/s3,"s3://crabby-images/15050/150503d6f9f550efac425f747c91be52db6689ac" alt="DotNetKicks DotNetKicks"
data:image/s3,"s3://crabby-images/90b33/90b33642a5940e251c30eef3b964abeb6e7afa4d" alt="DZone DZone"
data:image/s3,"s3://crabby-images/3b35a/3b35a55e2abcc9d9af3019d3e167fe99f3ac70e7" alt="eKudos eKudos"
data:image/s3,"s3://crabby-images/116a1/116a1755662d312705a51a68b5966d1c2b6d15a7" alt="email email"
data:image/s3,"s3://crabby-images/3734d/3734db5272ea3a1cdfb9d3b3eca5867aaa9a1a08" alt="Fark Fark"
data:image/s3,"s3://crabby-images/fd1f0/fd1f0088443d609e85da0204cd9962ab88b05d21" alt="Faves Faves"
data:image/s3,"s3://crabby-images/d6be5/d6be5d856b8f62cb388e89d13edbcb36b2b435c8" alt="Fleck Fleck"
data:image/s3,"s3://crabby-images/2a024/2a02464e0c762794aaa1979014ea03c1b34c1249" alt="FriendFeed FriendFeed"
data:image/s3,"s3://crabby-images/bcd27/bcd27b0ed00be6758b449fd44250fd229d956d90" alt="FSDaily FSDaily"
data:image/s3,"s3://crabby-images/84ab6/84ab6d3abcf521ab314d407e1f4faed693d15ca7" alt="Global Grind Global Grind"
data:image/s3,"s3://crabby-images/af078/af078f2fdf0064a30cfd09e7de59cc199881d86c" alt="Gwar Gwar"
data:image/s3,"s3://crabby-images/6fa98/6fa98612a025141572d8eb0a0a8f0a48b9fb9310" alt="HackerNews HackerNews"
data:image/s3,"s3://crabby-images/f8c9e/f8c9e0bd4ac7ae164037ceffec9b4acbe4e06361" alt="Haohao Haohao"
data:image/s3,"s3://crabby-images/20a80/20a8054cc8fb92a82843011c4e578bf97e957187" alt="HealthRanker HealthRanker"
data:image/s3,"s3://crabby-images/c5b64/c5b64b0b0979e31f1c1fbd9268d85452a5958868" alt="HelloTxt HelloTxt"
data:image/s3,"s3://crabby-images/99bd3/99bd3b73263bd355a82251fb746886322fd1fa3a" alt="Hemidemi Hemidemi"
data:image/s3,"s3://crabby-images/ca35b/ca35b6bdd40e27fb5840974698f5d6d501e07c60" alt="Hyves Hyves"
data:image/s3,"s3://crabby-images/37276/3727616c5b218aeb0166e3ca431cec81e204e0ca" alt="Identi.ca Identi.ca"
data:image/s3,"s3://crabby-images/8a734/8a734339714a656d008576101f50ed92e8ee8c81" alt="IndianPad IndianPad"
data:image/s3,"s3://crabby-images/4b713/4b71390f10c65aaeafe30b5d0569314968ca12f4" alt="Internetmedia Internetmedia"
data:image/s3,"s3://crabby-images/a17f6/a17f65561401f496d897fb128bc18840cf297a39" alt="Kirtsy Kirtsy"
data:image/s3,"s3://crabby-images/a10d2/a10d2118fb3c3a0e050d99b2a010555d79111453" alt="laaik.it laaik.it"
data:image/s3,"s3://crabby-images/1ba53/1ba53399c614397b799d04e929a35e0a94f6c627" alt="LaTafanera LaTafanera"
data:image/s3,"s3://crabby-images/cd04b/cd04bbd11d70c64fb419b8e32e0c5c161d528b10" alt="LinkaGoGo LinkaGoGo"
data:image/s3,"s3://crabby-images/d9760/d9760cba54211b735a5e1f00ab7da8b94bfe3f8e" alt="LinkArena LinkArena"
data:image/s3,"s3://crabby-images/d778f/d778f338740b06fd90be064ff3ea9caf9d251653" alt="LinkedIn LinkedIn"
data:image/s3,"s3://crabby-images/4c45e/4c45ecbc57e777d09373d88996e3c9ede0ad4eed" alt="Linkter Linkter"
data:image/s3,"s3://crabby-images/b4551/b45519bfc35bd7bf6c623de2cc77207f16bb5273" alt="Live Live"
data:image/s3,"s3://crabby-images/2664d/2664d1a1166121050e73c0fc986591deb99bad01" alt="Meneame Meneame"
data:image/s3,"s3://crabby-images/f7917/f79170d3218c1698da8296551b5f4a87005bde7c" alt="MisterWong MisterWong"
data:image/s3,"s3://crabby-images/f7917/f79170d3218c1698da8296551b5f4a87005bde7c" alt="MisterWong.DE MisterWong.DE"
data:image/s3,"s3://crabby-images/9b4b5/9b4b5dcdb017a7a2fa4edc0627bc3893b494c642" alt="MOB MOB"
data:image/s3,"s3://crabby-images/7a096/7a0965a8be00dd650740945b4d56b2aa8e872e3f" alt="MSN Reporter MSN Reporter"
data:image/s3,"s3://crabby-images/cb7cd/cb7cde8b2577c9b33f2a8b1f647891813f3ba297" alt="muti muti"
data:image/s3,"s3://crabby-images/84c1f/84c1f844d0a52bfc7e8c1c93b3e093e3b5b93976" alt="MyShare MyShare"
data:image/s3,"s3://crabby-images/ca847/ca8470b5af723cf408b21ebd47cbfce687b9d4ef" alt="MySpace MySpace"
data:image/s3,"s3://crabby-images/3f78c/3f78c83cd018338e84d7abc99ea87f3765a867a3" alt="N4G N4G"
data:image/s3,"s3://crabby-images/55412/5541265456f5a7e46a27f1b404fbf42b302e6cbf" alt="Netvibes Netvibes"
data:image/s3,"s3://crabby-images/bb695/bb6951e12f5ac5bbc18a7d08e3b843efd3799b4a" alt="Netvouz Netvouz"
data:image/s3,"s3://crabby-images/cce0d/cce0dd5ac47ff1781a07a742d4a32c15a764d390" alt="NewsVine NewsVine"
data:image/s3,"s3://crabby-images/37ef1/37ef102b0bfca1e69e10dff8471e2c28ceb67680" alt="NuJIJ NuJIJ"
data:image/s3,"s3://crabby-images/bc620/bc6200fc8e9bd5ea1fa9bfc580be59b71ef315d0" alt="PDF PDF"
data:image/s3,"s3://crabby-images/aacc4/aacc4696f0f468f7dc3f5608587b706f4cc3931d" alt="Ping.fm Ping.fm"
data:image/s3,"s3://crabby-images/d6181/d61816396be2eb709f80bb34c7bbbcff155f1373" alt="Posterous Posterous"
data:image/s3,"s3://crabby-images/fec05/fec051a07ae7123374ea4256f934f66c2cc76836" alt="Propeller Propeller"
data:image/s3,"s3://crabby-images/ab247/ab247a7231888eea879a5ec7034a2eb6209f31d5" alt="QQ书签 QQ书签"
data:image/s3,"s3://crabby-images/d1bca/d1bca39af7916d4cb70be0828a26dd4d7a7a8b02" alt="Ratimarks Ratimarks"
data:image/s3,"s3://crabby-images/3ac76/3ac7657fc57c8787d0f70f889ea3f973eb428cb0" alt="Rec6 Rec6"
data:image/s3,"s3://crabby-images/92021/92021b257e175f2aa5833e1aed14e2e6b089872f" alt="Reddit Reddit"
data:image/s3,"s3://crabby-images/1412a/1412aaa1a352bf1c5baf01d56d51e1a218c3a4dc" alt="RSS RSS"
data:image/s3,"s3://crabby-images/dd9d6/dd9d69bd3cf639c3d11ce8b0ad51523cebe36e40" alt="Scoopeo Scoopeo"
data:image/s3,"s3://crabby-images/b003a/b003a294d993bdbf409be4586a47a6c6b0164c2b" alt="Segnalo Segnalo"
data:image/s3,"s3://crabby-images/1b734/1b734156840ce029c1513e2712f0a85910378bc5" alt="SheToldMe SheToldMe"
data:image/s3,"s3://crabby-images/59b14/59b14d7e2e8caf31effc282aea975aefdaaabc49" alt="Simpy Simpy"
data:image/s3,"s3://crabby-images/08f37/08f37a5919d84c42bd409329e5675ab8d1e4c1b0" alt="Slashdot Slashdot"
data:image/s3,"s3://crabby-images/96391/96391e812911f4cd577e3dec5b522cd8b54fd2b8" alt="Socialogs Socialogs"
data:image/s3,"s3://crabby-images/59c60/59c60822d1dc8f550ec929ad8758ffa640b716a7" alt="SphereIt SphereIt"
data:image/s3,"s3://crabby-images/10532/10532c12685e325baeb9535c1a8611f3c5136140" alt="StumbleUpon StumbleUpon"
data:image/s3,"s3://crabby-images/4b083/4b0830d6dfa14135820ba02d9bbf0cd905a03407" alt="Suggest to Techmeme via Twitter Suggest to Techmeme via Twitter"
data:image/s3,"s3://crabby-images/97ab3/97ab356d8df69659664884df82db4377ce712537" alt="Technorati Technorati"
data:image/s3,"s3://crabby-images/a1457/a1457dbfeeeb08c3165735a805e6152164c7d552" alt="ThisNext ThisNext"
data:image/s3,"s3://crabby-images/59bd3/59bd3fc7328ba95c5904cb3b2ab985dc0651a88c" alt="Tipd Tipd"
data:image/s3,"s3://crabby-images/c0179/c017902ca4a0b9ef59936017b7f189009563ec2d" alt="Tumblr Tumblr"
data:image/s3,"s3://crabby-images/57322/573227d383015982b113bdbc28eb629e84010aa0" alt="Twitter Twitter"
data:image/s3,"s3://crabby-images/d1701/d1701f3c9292e61d68f69badca307620d5f31062" alt="Upnews Upnews"
data:image/s3,"s3://crabby-images/ef8ae/ef8ae311981104f7d3806aba3e217ce964208778" alt="viadeo FR viadeo FR"
data:image/s3,"s3://crabby-images/75778/75778e60d149f316e648d30f05ea0e476d9263db" alt="Webnews.de Webnews.de"
data:image/s3,"s3://crabby-images/a0165/a01654f131204d92dd978be9df53ff7f3a8509ff" alt="Webride Webride"
data:image/s3,"s3://crabby-images/6ac96/6ac963554149a916d749006b8a886af9f6ef3216" alt="Wikio Wikio"
data:image/s3,"s3://crabby-images/6ac96/6ac963554149a916d749006b8a886af9f6ef3216" alt="Wikio FR Wikio FR"
data:image/s3,"s3://crabby-images/6ac96/6ac963554149a916d749006b8a886af9f6ef3216" alt="Wikio IT Wikio IT"
data:image/s3,"s3://crabby-images/572d4/572d4c96700bbdd724aa68cbf75dc1230af382f5" alt="Wists Wists"
data:image/s3,"s3://crabby-images/e3642/e3642cf911b45ff4f9a3bdda2120ccb22958a628" alt="Wykop Wykop"
data:image/s3,"s3://crabby-images/93286/932862dfd3b48248a32e41e1667f9a57bbe90937" alt="Xerpi Xerpi"
data:image/s3,"s3://crabby-images/1ae0a/1ae0a6f4fb8f593d598a7de0b4e39c41069ae372" alt="Yahoo! Bookmarks Yahoo! Bookmarks"
data:image/s3,"s3://crabby-images/48a27/48a27d4869e0d45789bce1b24158a5c29797458d" alt="Yahoo! Buzz Yahoo! Buzz"
data:image/s3,"s3://crabby-images/79909/79909aad1aa0986796774f567808f2cff346f878" alt="Yigg Yigg"
data:image/s3,"s3://crabby-images/706c6/706c6ef1bb77ebae5b754b4f025f089fecd52618" alt="豆瓣 豆瓣"
data:image/s3,"s3://crabby-images/6bcf6/6bcf6c4ca732b8f193fca703b55e1c0e43c37ea2" alt="豆瓣九点 豆瓣九点"
0 comments :
Post a Comment