در قسمت قبل، تقریبا نیمه ای از کارهای لازم برای فعال کردن گزینه ی "مشاهده تمامی سفارش ها " را با هم دیگر انجام دادیم، در این قسمت قرار است، قدری پا را فراتر بگذاریم و مباحثی مطرح کنیم که گزینه ی "مشاهده تمامی سفارش ها" تکمیل تر گردد.
اگر به یاد داشته باشید در قسمت گذشته، ما فایل index.php را اصلاح و یک فایل تحت عنوان view_orders.php نیز ایجاد کردیم. البته، نا گفته نماند که کدهای فایل payment.php هم متناسب با شرایط جدید، تغییر دادیم.
در ادامه جدول داده ایی cart قبلی را حذف کردیم و جدول cart جدیدی، متناسب با نیازهای جدید، ایجاد کردیم. در ضمن یک جدول جدید به نام pay_cart نیز به جدول های موجود در پایگاه داده اضافه شد.
در همان قسمت قبل، قرار شد برای شما توضیح دهم که، چرا این دو جدول را ایجاد کردم؟ و چگونه بین این دو جدول و گزینه ی "مشاهده ی تمامی سفارشها"، ارتباط برقرار می شود؟
اگر به فیلدهای جدول cart و pay_cart دقت کرده باشید، من در جدول داده ی pay_cart، تمامی فیلد های جدول داده ایی cart را قرار دادم. به تصویر زیر نگاه کنید.
دقت نمایید که هر مشتری که وارد سایت می شود، یک سری از محصولات را انتخاب می کند و وارد سبد خرید خودش می کند (یعنی در واقع اطلاعات محصول و مشتری هم زمان در جدول داده ایی cart، به عنوان یک رکورد از این جدول ثبت می شود)، زمانی که مشتری تبدیل به خریدار شد (یعنی به درگاه پرداخت مراجعه و پول محصولات را پرداخت کرد) ما باید سبد خریدش را، از جدول داده ایی cart به جدول داده ایی pay_cart کپی کنیم و بعد از کپی کردن، اطلاعات او را از جدول داده ایی cart حذف کنیم.
این کار 2 مزیت دارد، یکی اینکه مشتریانی که پول محصولات خودشان را داده اند، از سایر مشتریان تفکیک می شوند، ثانیا، اگر همین مشتری، قصد داشته باشد، مجددا محصولاتی را خریداری کند، بین خریدهایش (یا فاکتور های خریدش) می توان تمایز قائل شد (دقت کنید که من در جدول داده ایی pay_cart از فیلد order_id برای تمایز بین خریدها، استفاده کرده ام و خواهم گفت که چگونه قرار است آن را مقدار دهی کنیم).
پس به طور خلاصه، جدول داده ایی cart، اطلاعات سبد خرید مشتریانی را در خود نگهداری می کند که، پول خریدهای خود را نپرداخته اند و به جای آن جدول داده ای pay_cart، اطلاعات خرید مشتریانی را در خود نگهداری می کند که، هزینه ی محصولاتشان را پرداخته اند. به تصویر زیر نگاه کنید تا بهتر متوجه این امر شوید.
حالا که به طور کامل، لزوم ایجاد این دو جدول را متوجه شدید، یک سوال مطرح می شود و آن اینکه:
جواب بسیار ساده است، زمانی که بانک به ما ok داد و گفت فلان مشتری پول را پرداخت کرده، زمانی است که ما باید، این انتقال اطلاعات از جدول داده ی cart به جدول داده ایی pay_cart را انجام دهیم. حالا به نظر شما کدام فایل بهترین مکان برای ایجاد تغییرات جدید است؟
آفرین، درست حدس زدید، فایل verify.php بهترین گزینه است. حالا به آدرس C:\wamp\www\ecommerce مراجعه کنید و فایل verify.php را با استفاده از Notepad++ باز کنید و کدهای زیر را در آن پیدا کنید.
echo "<p style='background:green; padding: 27px; font-size: 20px; border-radius: 15px;border: 5px dashed white;'>از خرید شما متشکریم کد RefID برای پیگیری های بعدی شما :".$result->RefID."می باشد.</p>"; $RefID=$result->RefID; mysqli_query($con,"UPDATE `order` SET `order_is_verified`='true', `refid`=$RefID WHERE `order_id`=$order_id ");
آنها را حذف کنید و کدهای زیر را به جای آنها قرار دهید.
echo "<p style='background:green; padding: 27px; font-size: 20px; border-radius: 15px;border: 5px dashed white;'>از خرید شما متشکریم کد RefID برای پیگیری های بعدی شما :".$result->RefID."می باشد.</p>"; $RefID=$result->RefID; mysqli_query($con,"UPDATE `order` SET `order_is_verified`='true', `refid`=$RefID WHERE `order_id`=$order_id "); //creating or using cookie for ip customer if(isset($_COOKIE["ipUserEcommerce"])) { $ip = $_COOKIE["ipUserEcommerce"]; }else{ $ip=getIp(); setcookie('ipUserEcommerce',$ip,time()+1206900); } //Copy the data from the cart data table to the pay _cart data table mysqli_query($con,"INSERT INTO pay_cart (p_id, ip_add, qty) SELECT p_id, ip_add, qty FROM cart WHERE ip_add='$ip'"); //Insert the value in the order_id $run_time=mysqli_query($con,"select * from `pay_cart` where ip_add='$ip' order by id_cart desc limit 1"); while ($run_time = @mysqli_fetch_array($run_time)) { $time=$run_time["order_time"]; } //Updating the order_id filde in the pay_cart table, of course, based on the payout time of the sales order mysqli_query($con,"UPDATE `pay_cart` SET `order_id`=$order_id WHERE `order_time`='$time'"); //destroying the session unset($_SESSION["order_total_price"]); unset($_SESSION["order_id"]); //destroying sessions that hold the qty. $str_ip= str_replace(".", "", "$ip"); $query_delete_session="SELECT * FROM `pay_cart` WHERE `order_id`=$order_id"; $run_delete_session=mysqli_query($con,$query_delete_session); while ($row = mysqli_fetch_array($run_delete_session)) { $product_id=$row["p_id"]; unset($_SESSION["$str_ip"]["$product_id"]); } //Delete customer data from the cart data table mysqli_query($con,"DELETE FROM cart WHERE ip_add='$ip'");
در کدهای بالا دقیقا مشاهده می نمایید که، وقتی مشتری پول را پرداخت کرد، ابتدا ip مشتری را به دست می آوریم، و بعد از آن با استفاده از همین ip مشتری، می توانیم اطلاعات را از جدول داده ایی cart به جدول داده ایی pay_cart کپی کنیم؛ من این کار را توسط دستور SQL زیر انجام داده ام.
INSERT INTO pay_cart (p_id, ip_add, qty) SELECT p_id, ip_add, qty FROM cart WHERE ip_add='$ip'
دستور بالا یک دستور معروف در SQL می باشد، که نام آن، دستور INSERT INTO SELECT است. و تنها نکته ایی است که، تا به حال آن را خدمت شما عرض نکردم، بنابراین در ادامه به طور کامل آن را معرفی می کنم.
طبق تعریف سایت w3schools، دستور INSERT INTO SELECT، داده ها را از یک جدول کپی کرده و آن را در جدول دیگری قرار می دهد. البته نکته ی مهمی را باید مد نظر قرار داد، این است که دستور INSERT INTO SELECT زمانی کار خواهد کرد که نوع داده ی در جدول مبدا و مقصد یکی باشد.
وقتی می خواهیم تمام ستون ها را از یک جدول به جدول دیگر کپی کنیم:
INSERT INTO table2 SELECT * FROM table1 WHERE condition;
وقتی قرار است تنها چند ستون را از یک جدول به جدول دیگری کپی کنیم:
INSERT INTO table2 (column1, column2, column3, ...) SELECT column1, column2, column3, ... FROM table1 WHERE condition;
حالا که با این دستور آشنا شدید به ادامه توضیح کدها می پردازم.
وقتی که اطلاعات سبد خرید مشتری ای که پول محصولاتش را پرداخت کرده است را، از جدول داده ایی cart به جدول داده ایی pay_cart کپی کردیم؛ در فیلد order_time (که یکی از فیلد های جدول داده ایی pay_cart است) زمان ایجاد این رکورد، به صورت خودکار، ثبت می شود.
بنابراین ما این زمان را نمی دانیم و باید زمان ایجاد هر فاکتور فروش را به دست آوریم (این موضوع فوق العاده مهم است)، پس با استفاده از ip مشتری، رکوردهای جدید اضافه شده اش، را مرتب می کنیم؛ تا بتوانیم این زمان را به دست آوریم. به دستور SQL زیر دقت کنید.
select * from `pay_cart` where ip_add='$ip' order by id_cart desc limit 1
در ادامه ما زمان ایجاد آخرین رکورد (دقت کنید مجموع چند رکورد متعلق به یک IP در واقع یک سبد خرید است که از جدول داده ایی cart به جدول داده ایی pay_cart آمده است ولی هنوز این رکورد ها شماره فاکتور ندارند.) متعلق به یک ip را به دست می آوریم و با استفاده از همین زمان، شماره ی فاکتور (order_id) آخرین خرید مشتری را، با استفاده از کدهای زیر به جدول تزریق می کنیم.
mysqli_query($con,"UPDATE `pay_cart` SET `order_id`=$order_id WHERE `order_time`='$time'");
قرار دادن id فاکتور فروش (یا همان order_id) در جدول pay_cart، البته بر اساس زمان پرداخت فاکتور فروش با استفاده از دستور SQL زیر اتفاق می افتد.
UPDATE `pay_cart` SET `order_id`=$order_id WHERE `order_time`='$time'
و در ادامه، متغییر های SESSION که اطلاعات مشتری را نگهداری می کردند باید همگی حذف شوند (این نکته فوق العاده مهم است، زیرا اگر این کار را انجام ندهیم، تمامی اطلاعات به هم می ریزد)، که اینکار را در کدهای زیر انجام داده ام.
unset($_SESSION["order_total_price"]); unset($_SESSION["order_id"]); $str_ip= str_replace(".", "", "$ip"); $query_delete_session="SELECT * FROM `pay_cart` WHERE `order_id`=$order_id"; $run_delete_session=mysqli_query($con,$query_delete_session); while ($row = mysqli_fetch_array($run_delete_session)) { $product_id=$row["p_id"]; unset($_SESSION["$str_ip"]["$product_id"]); }
حالا دیگر تمامی اطلاعاتی مورد نیاز ما، در مورد سبد خرید این مشتری (مشتری که پول محصولات موجود در سبد خریدش را توسط درگاه بانکی پرداخت کرده است ) بعلاوه اطلاعات اضافی مورد نظر، در جدول داده ایی pay_cart قرار گرفته است. همانطور که در ادامه کدها مشاهده می کنید، من، سبد خرید این مشتری (مشتری که پول محصولات موجود در سبد خریدش را توسط درگاه بانکی پرداخت کرده است.) را از جدول داده ایی cart حذف کرده ام. به کدهای زیر دقت کنید.
//Delete customer data from the cart data table mysqli_query($con,"DELETE FROM cart WHERE ip_add='$ip'");
خب حالا کار ما با فایل verify.php تمام شده است و تغییرات مورد نظر خودمان را در آن انجام دادیم. حال مجددا به فایل view_orders.php باز می گردیم و ببینیم که در ادامه باید چه کدهایی را بنویسیم. بنابراین به آدرس C:\wamp\www\ecommerce\admin_area برگردید و فایل view_orders.php را با استفاده از Notepad++ باز کنید.
در میان کدهای این فایل، لینک زیر را پیدا کنید.
<a style="color:#fff;" href="index.php?pay=<?php if($order_is_verified=="true"){echo"yes";}else{echo"no";}?>&order_customer=<?php echo $order_email_customer; ?>&Total_Amount=<?php echo $order_total_price ?>&id_order=<?php echo $id_order; ?>">مشاهده</a>
در این لینک، اساس کار، بر استفاده از متغییر سراسری $_GET بنا شده است. برای اینکه راحت تر متوجه لینک بالا شوید و توجه شما را به ویژگی href این لینک، در تصویر زیر ، جلب می کنم.
تصویر بالا به طور کامل مطالبی که باید خدمت شما عرض می کردم را پوشش داده است، تنها یک موضوع می ماند و آن این است که این لینک "مشاهده" که آن را در تصویر بالا، ملاحظه می کنید، جهت اجرای برنامه را به سمت فایل index.php تغییر می دهد. بنابراین به فایل index.php می رویم و این فایل را برای پذیرش این لینک آماده می کنیم.
به آدرس C:\wamp\www\ecommerce\admin_area بروید و فایل index.php را با استفاده از Notepad++ باز کرده و کدهای زیر را در آن پیدا کنید.
if(isset($_GET['view_orders'])) { include('view_orders.php'); }
آنها را پاک کنید و به جای آنها کدهای زیر را قرار دهید.
if(isset($_GET['view_orders'])) { include('view_orders.php'); } if(isset($_GET['order_customer'])) { include('order_customer.php'); }
در کدهای بالا به وضوح گفته ایم که اگر در آدرس سایت پارامتر order_customer وجود داشت، جهت اجرای برنامه به سمت فایل order_customer.php تغییر می کند.
اما هنوز این فایل را ایجاد نکرده ایم بنابراین به آدرس C:\wamp\www\ecommerce\admin_area می رویم و مانند تصویر زیر فایل order_customer.php را ایجاد می کنیم.
خب عزیزان برای اینکه از لحاظ آموزشی خسته نشوید، این قسمت را در همین جا به پایان می برم و انشاالله در قسمت آینده در مورد کدهایی که قرار است در فایل order_customer.php قرار بدهیم، بیشتر با شما، صحبت می کنم.
فایل verify.php که در آدرس C:\wamp\www\ecommerce قرار دارد.
<!-- start of Header --> <?php include('includes/Header.php'); ?> <!-- end of Header --> <!-- start of content --> <div id="templatemo_content"> <?php // We connect to the database include("includes/db.php"); $order_id= $_GET['order_id_for_verify']; if ($_GET['Status'] == 'OK') { $MerchantID = 'XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX'; $Amount = $_GET['Amount']; //Amount will be based on Toman $Authority = $_GET['Authority']; $client = new SoapClient('https://sandbox.zarinpal.com/pg/services/WebGate/wsdl', ['encoding' => 'UTF-8']); $result = $client->PaymentVerification( [ 'MerchantID' => $MerchantID, 'Authority' => $Authority, 'Amount' => $Amount, ] ); if ($result->Status == 100) { echo "<p style='background:green; padding: 27px; font-size: 20px; border-radius: 15px;border: 5px dashed white;'>از خرید شما متشکریم کد RefID برای پیگیری های بعدی شما :".$result->RefID."می باشد.</p>"; $RefID=$result->RefID; mysqli_query($con,"UPDATE `order` SET `order_is_verified`='true', `refid`=$RefID WHERE `order_id`=$order_id "); //creating or using cookie for ip customer if(isset($_COOKIE["ipUserEcommerce"])) { $ip = $_COOKIE["ipUserEcommerce"]; }else{ $ip=getIp(); setcookie('ipUserEcommerce',$ip,time()+1206900); } //Copy the data from the cart data table to the pay _cart data table mysqli_query($con,"INSERT INTO pay_cart (p_id, ip_add, qty) SELECT p_id, ip_add, qty FROM cart WHERE ip_add='$ip'"); //Insert the value in the order_id $run_time=mysqli_query($con,"select * from `pay_cart` where ip_add='$ip' order by id_cart desc limit 1"); while ($run_time = @mysqli_fetch_array($run_time)) { $time=$run_time["order_time"]; } //Updating the order_id filde in the pay_cart table, of course, based on the payout time of the sales order mysqli_query($con,"UPDATE `pay_cart` SET `order_id`=$order_id WHERE `order_time`='$time'"); //destroying the session unset($_SESSION["order_total_price"]); unset($_SESSION["order_id"]); //destroying sessions that hold the qty. $str_ip= str_replace(".", "", "$ip"); $query_delete_session="SELECT * FROM `pay_cart` WHERE `order_id`=$order_id"; $run_delete_session=mysqli_query($con,$query_delete_session); while ($row = mysqli_fetch_array($run_delete_session)) { $product_id=$row["p_id"]; unset($_SESSION["$str_ip"]["$product_id"]); } //Delete customer data from the cart data table mysqli_query($con,"DELETE FROM cart WHERE ip_add='$ip'"); } else { echo "<p style='background:red; padding: 27px; font-size: 20px; border-radius: 15px;border: 5px dashed white;'> تراکنش انجام نشد : :".$result->Status."</p>"; } } else { echo "<p style='background:red; padding: 27px; font-size: 20px; border-radius: 15px;border: 5px dashed white;'> تراکنش توسط کاربر انجام نشد </p>"; } ?> </div> <!-- end of content --> <!-- start of footer --> <?php include('includes/Footer.php'); ?> <!-- end of footer -->
فایل view_orders.php که در آدرس C:\wamp\www\ecommerce\admin_area قرار دارد.
<table width="700" align="center"> <caption ><b>مشاهده همه سفارشات</b></caption > <tr> <th colspan="5"> <b style="background-color:green;">  فاکتور های پرداخت شده سبز رنگ هستند.  </b> <b style="background-color:red;">  فاکتور های پرداخت نشده قرمز رنگ هستند.  </b></th> </tr> <tr> <td><b>ردیف</b></td > <td><b>ایمیل مشتری</b></td > <td><b>تاریخ فاکتور</b></td > <td><b>قیمت کل فاکتور</b></td > <td><b>مشاهده سفارش</b></td > </tr> <tr align="center"> <?php $i=0; $select_order="SELECT * FROM `order` "; $run_order=mysqli_query($con,"SET NAMES SET utf8"); $run_order=mysqli_query($con,"SET CHARACTER SET utf8"); $run_order=mysqli_query($con,$select_order); while($row_order = mysqli_fetch_array($run_order)) { $id_order=$row_order['order_id']; $order_total_price=$row_order['order_total_price']; $order_is_verified=$row_order['order_is_verified']; /*Since the creation of a record in the order data table is different from the time the record is created in the pay_cart data table, therefore, we should consider the time to create the record in the pay_cart data table, not the time when the record was created in the order data table */ $time_pay_order=""; if($order_is_verified=="true"){ $run_time_pay_order=mysqli_query($con,"select `order_time` from `pay_cart` where `order_id`=$id_order order by `id_cart` desc limit 1 "); while($run_time_pay_order = @mysqli_fetch_array($run_time_pay_order)) { $time_pay_order=$run_time_pay_order["order_time"]; } }else{ $order_time=$row_order['order_time']; } $order_email_customer=$row_order['order_email_customer']; $i++; ?> <td align="center" style="background:<?php if($order_is_verified=="true"){echo"green";}else{echo"red";}?>"><?php echo $i ?></td> <td align="center" style="background:<?php if($order_is_verified=="true"){echo"green";}else{echo"red";}?>"><?php echo $order_email_customer ?></td> <td align="center" style="background:<?php if($order_is_verified=="true"){echo"green";}else{echo"red";}?>"><?php if($order_is_verified=="true"){echo $time_pay_order;}else{echo $order_time;} ?></td> <td align="center" style="background:<?php if($order_is_verified=="true"){echo"green";}else{echo"red";}?>"><p><?php echo $order_total_price ?></p></td> <td align="center" style="background:<?php if($order_is_verified=="true"){echo"green";}else{echo"red";}?>"> <a style="color:#fff;" href="index.php?pay=<?php if($order_is_verified=="true"){echo"yes";}else{echo"no";}?>&order_customer=<?php echo $order_email_customer; ?>&Total_Amount=<?php echo $order_total_price ?>&id_order=<?php echo $id_order; ?>">مشاهده</a> </td> </tr> <?php } ?> </table>
فایل index.php که در آدرس C:\wamp\www\ecommerce\admin_area قرار دارد.
<!-- start of Header --> <?php include('include/Header.php'); ?> <!-- end of Header --> <div id="templatemo_content"> <!-- start of ocntent left --> <div id="templatemo_content_left"> <?php if(isset($_GET['insert_pro'])) { include('insert_product.php'); } if(isset($_GET['view_pro'])) { include('view_product.php'); } if(isset($_GET['edit_pro'])) { include('edit_product.php'); } if(isset($_GET['insert_cat'])) { include('insert_cat.php'); } if(isset($_GET['view_cats'])) { include('view_cats.php'); } if(isset($_GET['edit_cat'])) { include('edit_cat.php'); } if(isset($_GET['insert_brand'])) { include('insert_brand.php'); } if(isset($_GET['view_brands'])) { include('view_brands.php'); } if(isset($_GET['edit_brand'])) { include('edit_brand.php'); } if(isset($_GET['view_customers'])) { include('view_customers.php'); } if(isset($_GET['view_orders'])) { include('view_orders.php'); } if(isset($_GET['order_customer'])) { include('order_customer.php'); } ?> <div class="cleaner_with_height"> </div> </div> <!-- end of ocntent left --> <!-- start of right content --> <?php include('include/Right_Sidebar.php'); ?> <!-- end of right content --> <div class="cleaner"> </div> </div> <!-- start of footer --> <?php include('include/Footer.php'); ?> <!-- end of footer -->
در این قسمت، به پرسشهای تخصصی شما دربارهی محتوای مقاله پاسخ داده نمیشود. سوالات خود را اینجا بپرسید.
در این قسمت، به پرسشهای تخصصی شما دربارهی محتوای مقاله پاسخ داده نمیشود. سوالات خود را اینجا بپرسید.