سبد خرید (0)

تبلیغات

پروژه فروش فایل در PHP

  •  AJAX (آجاکس)، هنر تبادل داده ها با سرور و بروز رسانی بخش هایی از یک صفحه وب، بدون بارگذاری مجدد کل صفحه است.


    AJAX (آجاکس) چیست؟

    Wiki

    AJAX مخفف کلمات Asynchronous JavaScript And XML است.

    به طور خلاصه، AJAX در مورد بارگذاری داده ها در پس زمینه و نمایش آن بر روی صفحه وب بدون بارگذاری مجدد کل صفحه است.

    مثال هایی از استفاده AJAX در برنامه ها:

    • Gmail
    • Google Maps
    • Youtube
    • Facebook

    AJAX چگونه کار می کند

    Wiki


    AJAX براساس استاندارهای اینترنت

    Wiki

    AJAX براساس استاندارهای اینترنت است و ترکیبی از موارد زیر را استفاده می کند:

    • شیء XMLHttpRequest - برای تبادل داده با سرور، بصورت غیرهمزمان (asynchronously) استفاده می شود.
    • JavaScript/DOM - برای نمایش اطلاعات و یا تعامل با داده ها
    • CSS - برای مشخص کردن نحوه نمایش داده ها
    • XML - اغلب بعنوان یک فرمت برای انتقال داده ها استفاده می شود.
    Note برنامه های کاربردی AJAX مرورگرند و مستقل از پلتفرم عمل می کنند...!

    امکان Google Suggest

    Wiki

    AJAX در سال 2005 توسط Google با امکان Google Suggest این سایت معروف شد.

    این امکان (Google Suggest) با استفاده از AJAX یک واسط کاربری بسیار پویا ایجاد کرده است. زمانی که در کادر جستجوی Google شروع به تایپ می کنید، یک کد JavaScript حروف را به سرور ارسال می کند و سرور لیستی از پیشنهادات برای کلمه مورد جستجوی شما را برمی گرداند.


    شروع به استفاده از AJAX

    Wiki

    در بیاموز PHP، ما نحوه update کردن بخشی از صفحه وب، بدون بارگذاری کل صفحه را با استفاده از AJAX آموزش خواهیم داد.

    اسکریبت های سمت سرور، با PHP نوشته خواهد شد.

    READ MORE
  • Cookie ها در php

    Wiki

     Cookie چیست؟ cookie یک فایل کوچک است که سرور آن را درون کامپیوتر کاربر قرار می دهد. هر بار که همان کامپیوتر یک صفحه را از طریق مرورگرش درخواست می کند، مقدار cookie همراه با درخواست به سرور ارسال می شود. با php، شما می توانید هم مقادیر cookie را بسازید و هم بازیابی کنید.

    توجه: یک cookie اغلب برای شناسایی یک کاربر استفاده می شود.


     چگونه یک cookie ایجاد کنیم؟

    Wiki

     تابع ()setcookie برای ایجاد cookie استفاده می شود.

    نکته: تابع ()setcookie باید قبل از تگ <html> قرار گیرد.

    نحوه استفاده:

    setcookie(name, value, expire, path, domain);

    مثال:

    در مثال زیر٫ یک cookie با نام "user" ایجاد می کنیم و مقدار "Ali Ahmadi" را به آن اختصاص می دهیم. ما همچنین مشخص می کنیم که cookie پس از یک ساعت از بین برود:

    <?php
    setcookie("user", "Ali Ahmadi", time()+3600);
    ?>

    <html>
    .....

    نکته: مقدار cookie به طور خودکار هنگام ارسال کد(URLencoding) می شود و موقع دریافت رمزگشایی می شود (برای پیشگیری از رمزگذاری٫ از ()setrawcookie استفاده کنید.

    مثال:

    شما می توانید زمان انقضای cookie را به روشی دیگر مشخص کنید، احتمالاً این راه ساده تر از مشخص کردن ثانیه هاست:

    <?php
    $expire=time()+60*60*24*30;
    setcookie("user", "Ali Ahmadi", $expire);
    ?>

    <html>
    .....

    در مثال بالا زمان انقضا با مقدار "1 ماه" پر شده است( 60sec * 60 min * 24 hours * 30 days)


    چگونه مقدار یک cookie را بازیابی کنیم؟

    Wiki

     متغیر COOKIE_$  در php برای بازیابی مقدار یک cookie مورد استفاده قرار می گیرد.

    مثال:

    در مثال زیر٫ مقدار cookie با نام "user" را بازیابی می کنیم و بر روی صفحه، نمایش می دهیم:

    <?php
    // Print a cookie
    echo $_COOKIE["user"];

    // A way to view all cookies
    print_r($_COOKIE);
    ?>

    در مثال زیر با استفاده از تابع ()isset چک می کنیم که cookie با نام "user" قبلاً set شده است یا نه؟

    <html>
    <body>

    <?php
    if (isset($_COOKIE["user"]))
      echo "Welcome " . $_COOKIE["user"] . "!<br />";
    else
      echo "Welcome guest!<br />";
    ?>

    </body>
    </html>


    چگونه یک cookie را حذف کنیم؟

    Wiki

     هنگامی که می خواهید یک cookie را حذف کنید باید اطمینان دهید که تاریخ انقضاء آن به پایان رسیده است.

    مثال حذف:

    <?php
    // set the expiration date to one hour ago
    setcookie("user", "", time()-3600);
    ?>


    اگر یک مرورگر cookieها را پشتیبانی نکند چه باید کرد؟

    Wiki

     اگر برنامه شما با مرورگرهایی سروکار دارد که cookieها را پشتیبانی نمی کنند، باید روشهای دیگری رابرای انتقال اطلاعات از یک صفحه به صفحه ی دیگر انتخاب کنید. یک روش انتقال اطلاعات از طریق فرم ها و متغیرهای از پیش تعریف شده است(فرم ها و متغیر های از پیش تعریف شده، قبل از این توضیح داده شده اند).

    در فرم زیر وقتی که کاربر دکمه ی "submit" را کلیک می کند، ورودی های کاربر را به "welcome.php" می فرستد:

    <html>
    <body>

    <form action="welcome.php" method="post">
       Name: <input type="text" name="name" />
       Age: <input type="text" name="age" />
       <input type="submit" />
    </form>

    </body>
    </html>

    بازیابی اطلاعات در صفحه "welcome.php" شبیه زیر خواهد بود:

    <html>
    <body>

    Welcome <?php echo $_POST["name"]; ?>.<br />
    You are <?php echo $_POST["age"]; ?> years old.

    </body>
    </html>

    READ MORE
  • درج کردن یک فایل PHP در یک فایل PHP دیگر

    Wiki

    شما می توانید با استفاده از دو تابع include یا require محتویات یک فایل PHP را داخل یک فایل PHPدیگر درج کنید، البته قبل از اینکه فایل دوم اجرا شود.

    این دو تابع در همه موارد یکسان عمل می کنند، بجز در چگونگی برخورد با خطا:

    • include: پیغام خطا را تولید می کند، اما ادامه اسکریپت اجرا خواهد شد.
    • require: پیغام خطا را تولید می کند و اجرای اسکریپت متوقف خواهد شد.

    موارد استفاده دو تابع include و require می تواند شامل موارد زیر باشد:

    • توابع
    • Header
    • Footer
    • المانهایی که در چندین صفحه استفاده می شود مانند منوها، کامپوننت تاریخ و...

    شما می توانید یک فایل استاندارد Header یا Footer و یا منو ایجاد کنید و در همه صفحات پروژه تان از آنها استفاده کنید، و موقعی که نیاز به تغییر داشت، تنها با تغییر یک فایل، کل پروژه تان را تازه سازی کنید.

    دستور include_once و  require_once:
    دو تابع بالا دقیقاً مثل include و require عمل می کنند، با این تفاوت که اگر فایل مورد نظر قبلاً خوانده شده است، دیگر خوانده نمی شود.


    مثال 1:

    فرض کنید یک فایل Header با نام "header.php" دارید، برای اضافه کردن آن  به صفحه ای از پروژه از کد زیر استفاده کنید:

    <html>
    <body>

    <?php include("header.php"); ?>
    <h1>Welcome to my home page!</h1>
    <p>Some text.</p>

    </body>
    </html>

    دستورات include, include_once, require و require_once را می توان بدون پرانتز نیز بکار برد.


    مثال 2:

    فرض کنید یک فایل منو طبق زیر با نام "menu.php" داریم، که باید به تمام صفحات پروژه اضافه شود:

    <a href="/default.php">Home</a>
    <a href="/tutorials.php">Tutorials</a>
    <a href="/references.php">References</a>
    <a href="/examples.php">Examples</a>
    <a href="/about.php">About Us</a>
    <a href="/contact.php">Contact Us</a>

    در زیر فایل "menu.php" را به صفحه دلخواهمان اضافه کرده ایم:

    <html>
    <body>

    <div class="leftmenu">
    <?php include("menu.php"); ?>
    </div>

    <h1>Welcome to my home page.</h1>
    <p>Some text.</p>

    </body>
    </html>

    اگر بعد از اجرای فایل بالا در  IE ، روی صفحه راست کلیک کرده و View Source را کلیک کنید، کد html شبیه زیر خواهیم داشت:

    <html>
    <body>

    <div class"leftmenu">
    <a href="/default.php">Home</a>
    <a href="/tutorials.php">Tutorials</a>
    <a href="/references.php">References</a>
    <a href="/examples.php">Examples</a>
    <a href="/about.php">About Us</a>
    <a href="/contact.php">Contact Us</a>
    </div>

    <h1>Welcome to my home page!</h1>
    <p>Some text.</p>

    </body>
    </html>


    مثال 3: خطا در تابع include:

    Wiki

    در مثال زیر فایل wrongFile.php وجود ندارد و همان طور که مشاهده می کنید بعد از چاپ پیغام خطا ادامه اسکریپت اجرا می شود.

    <html>
    <body>

    <?php
    include("wrongFile.php");
    echo "Hello World!";
    ?>

    </body>
    </html>

    پیغام خطا:

    Warning: include(wrongFile.php) [function.include]:
    failed to open stream:
    No such file or directory in C:\home\website\test.php on line 5

    Warning: include() [function.include]:
    Failed opening 'wrongFile.php' for inclusion
    (include_path='.;C:\php5\pear')
    in C:\home\website\test.php on line 5

    Hello World!


    مثال 4:پیغام خطا در تابع require:

    Wiki

    <html>
    <body>

    <?php
    require("wrongFile.php");
    echo "Hello World!";
    ?>

    </body>
    </html>

    پیغام خطا:

    Warning: require(wrongFile.php) [function.require]:
    failed to open stream:
    No such file or directory in C:\home\website\test.php on line 5

    Fatal error: require() [function.require]:
    Failed opening required 'wrongFile.php'
    (include_path='.;C:\php5\pear')
    in C:\home\website\test.php on line 5

    بعد از ایجاد خطا، ادامه اجرای اسکریبت متوقف می شود، و در حقیقت خطی که قرار است Hello World را چاپ کند، اجرا نمی شود.

     پیشنهاد می شود از تابع require بجای include استفاده شود، چون اسکریبت ها بعد از برخورد با خطا نباید ادامه پیدا کنند.

    READ MORE
  • SimpleXML چیست؟

    Wiki

    SimpleXML یک روش جدید برای خواندن خصوصیات و متن یک عنصر در PHP5 فراهم می کند. (البته اگر طرح بندی سند XML را بدانید)

    SimpleXML در مقایسه با تجزیه کننده DOM یا Expat با کد کمتری به اطلاعات عناصر دسترسی پیدا می کند.

    SimpleXML یک سند XML را به یک شی تبدیل می کند:

    • عناصر: بوسیله شیء SimpleXMLElement به یک سری خصوصیات تنها تبدیل می شوند، زمانی که در یک سطح، بیش از یک عنصر وجود دارد، از آرایه ها استفاده می شود.
    • خصوصیات: خصوصیات عناصر در یک آرایه انجمنی(PHP Arrays) قابل دسترسی است، نام خصوصیت ایندکس آرایه است.
    • اطلاعات عنصر: متن اطلاعات عنصر به یک رشته تبدیل می شود، اگر یک عنصر بیش از یک متن داشت، آنها را به ترتیبی که پیدا کرده می چیند.

    برای موارد پایه ای شبیه زیر، استفاده از SimpleXML بسیار ساده و سریع است:

    • خواندن یک فایل XML
    • استخراج اطلاعات از یک رشته XMLی
    • ویرایش متن یا مشخصه های یک عنصر

    نکته: زمانی که با یک فایل XML پیشرفته شبیه namespaceها سروکار دارید بهتر است که از تجزه کننده های Expat یا DOM استفاده کنید.


    نصب SimpleXML

    Wiki

    توابع تجزیه کننده SimpleXML قسمتی از هسته PHP 5.0 هستند و نیازی به نصب وجود ندارد.


    چگونه از SimpleXML استفاه کنیم

    Wiki

    لطفاً به فایل XML زیر توجه کنید:

    <?xml version="1.0" encoding="ISO-8859-1"?>
    <note>
    <to>Tove</to>
    <from>Jani</from>
    <heading>Reminder</heading>
    <body>Don't forget me this weekend!</body>
    </note>

    می خواهیم نام و متن اطلاعات هر عنصر را در خروجی چاپ کنیم.

    راه حل؟

    1. فایل XML را لود کنید.
    2. نام اولین عنصر را بخوانید.
    3. یک حلقه روی هر نود(فرزند) ایجاد کنید و برای خواندن اطلاعات هر نود(فرزند) از تابع ()children استفاده کنید.
    4. برای هر نود(فرزند) نام عنصر و متن اطلاعات آنرا چاپ کنید.

    مثال:

    <?php
    $xml = simplexml_load_file("test.xml");

    echo $xml->getName() . "<br />";

    foreach($xml->children() as $child)
      {
      echo $child->getName() . ": " . $child . "<br />";
      }
    ?>

    خروجی کد بالا:

    note
    to: Tove
    from: Jani
    heading: Reminder
    body: Don't forget me this weekend!

    READ MORE
  •  آرایه ها در PHP

    Wiki

    آرایه ها انواع خاصی از متغیرها به حساب می آیند که می توانند چندین داده را در قالب یک نام ذخیره کنند.

    اگر لیستی از آیتمها (برای مثال یک لیست از نام ماشین ها) را داشته باشیم و بخواهیم آنها را در متغیر ها ذخیره کنیم، چیزی شبیه زیر خواهیم داشت:

    $cars1="Samand";
    $cars2="Volvo";
    $cars3="BMW";

    حالا:

    • اگر لیست شما بیشتر از 3 آیتم باشد مثلاً 300تا چه کار می کنید.
    • اگر در این لیست به دنبال یک ماشین خاص باشید چه کار می کنید.

    در اینجا بهترین راه حل استفاده از آرایه ها است.

    یک آرایه می تواند مقادیر متغیرها را تحت یک نام برای شما نگه دارد. و شما از طریق نام آرایه می توانید به مقادیر دسترسی داشته باشید.

    هر آیتم در آرایه ایندکس منحصر به فردی برای خود دارد که به راحتی از طریق ایندکس می توانید به مقادیر دسترسی پیدا کنید.

    در PHP سه نوع آرایه وجود دارد:

    • آرایه عددی (Indexed array): منظور از عددی ایندکس آرایه است، یعنی یک آرایه با ایندکس عددی
    • آرایه انجمنی (Associative array): یک آرایه که بجای ایندکس عددی از یک نام یا مقدار برای ایندکس گذاری استفاده کرده است.
    • آرایه چند بعدی (Multidimensional array): یک آرایه که مقادیر هر سلول آن آرایه ای دیگر است.

    آرایه عددی

    Wiki

    در یک آرایه عددی مقادیر هر سلول آرایه با یک ایندکس عددی مشخص می شود.

    دو روش برای ایجاد چنین آرایه ای وجود دارد:

    1. در مثال زیر ایندکس به صورت اتوماتیک ساخته می شود(ایندکس از 0 شروع می شود):

      $cars=array("Samand","Volvo","BMW","Toyota");

    2. در مثال زیر به صورت دستی می توانید ایندکس را بسازید:

      $cars[0]="Samand";
      $cars[1]="Volvo";
      $cars[2]="BMW";
      $cars[3]="Toyota";

     در مثال زیر بعد از مقداردهی آرایه شما می توانید به مقادیر هر سلول به وسیله نام و ایندکس آرایه دسترسی پیدا کنید: 

    <?php
    $cars[0]="Saab";
    $cars[1]="Volvo";
    $cars[2]="BMW";
    $cars[3]="Toyota";
    echo $cars[0] . " and " . $cars[1] . " are Swedish cars.";
    ?>

    خروجی کد بالا:

    Saab and Volvo are Swedish cars.

    توجه: با استفاده از تابع ()count، می توانید تعداد سلول های یک آرایه را تعیین نمایید.


    آرایه های انجمنی

    Wiki

    در یک آرایه انجمنی ایندکس هر سلول از آرایه، با یک نام یونیک مشخص می شود.

    زمان ذخیره مقادیر سلولها باید یک نام مشخص و یونیک به آن سلول اختصاص دهید.

    مثال 1: در این مثال یک آرایه ای که سن افراد مختلف را نشان می دهد، تعریف شده است:

    $ages = array("Ali"=>32, "Reza"=>30, "Amir"=>34);

    مثال2: این مثال مانند قبلی است اما می تواند نشان دهد که چگونه می توانیم به روش های مختلف یک آرایه را تعریف کنیم:

    $ages['Ali'] = "32";
    $ages['Reza'] = "30";
    $ages['Amir'] = "34";

    در زیر نشان داده شده که چگونه از طریق نام و ایندکس آرایه، توانسته ایم به محتویات هر سلول آرایه دسترسی پیدا کنیم:

    <?php
    $ages['Ali'] = "32";
    $ages['Reza'] = "30";
    $ages['Amir'] = "34";

    echo "Ali is " . $ages['Ali'] . " years old.";
    ?>

    خروجی کد بالا:

    Ali is 32 years old.


    آرایه های چند بعدی

    Wiki

    هریک از عناصر آرایه در php می توانند از هر نوعی باشند پس می توانیم آرایه را نیز به عنوان عضو عناصر در نظر بگیریم. بنابراین به زبان ساده تر می توانیم یک آرایه داخل آرایه دیگر تعریف کنیم و داخل آن نیز یک آرایه دیگر و داخل آن نیز و به همین ترتیب. تعریف آرایه چندبعدی در زبان php به سادگی آرایه های معمولی است.

    مثال: در این مثال یک آرایه چند بعدی تعریف شده که ایندکس آن به صورت اتوماتیک ایجاد می شود:

    $families = array(array("Ali","Reza","Sara"),
                      array("Amir"),
                      array("Poya","Parniya")
                     );

    اگر مایل باشید می توانید آرایه بالا را به صورت زیر تعریف کنید: (ایندکسِ مقداری)

    $families = array("Ahmadi"=>array("a"=>"Ali","b"=>"Reza","c"=>"Sara"),
                      "Naderi"=>array("a"=>"Amir"),
                      "Mohamadi"=>array("a"=>"Poya","b"=>"Parniya")
                     );

     مثال: اجازه بدهید تا با یک مثال نشان دهیم که چگونه می توان به یک سلول از آرایه های چند بعدی دسترسی پیدا کرد:

    echo "Is " . $families['Ahmadi']['b'] . " a part of the Ahmadi family?";

    خروجی کد بالا:

    Is Reza a part of the Ahmadi family?


    مرتب کردن آرایه ها در PHP

    Wiki

    عناصر یک آرایه را می توان به صورت الفبایی یا عددی از کوچک به بزرگ (ascending) یا بزرگ به کوچک (descending) مرتب نمود.

    توابع مرتب سازی آرایه ها:

    • ()sort - مرتب کردن مقادیر آرایه از کوچک به بزرگ
    • ()rsort - مرتب کردن مقادیر آرایه از بزرگ به کوچک
    • ()asort - مرتب کردن آرایه های انجمنی از نزولی به صعودی (بر اساس مقدار)
    • ()ksort - مرتب کردن آرایه های انجمنی از نزولی به صعودی (بر اساس کلید)
    • ()arsort - مرتب کردن آرایه های انجمنی از صعودی به نزولی (بر اساس مقدار)
    • ()krsort - مرتب کردن آرایه های انجمنی از صعودی به نزولی (بر اساس کلید)

    در مثال زیر، آرایه انجمنی age$ بر اساس کلید، از کوچک به بزرگ مرتب شده است:

    مثال (آرایه ها در PHP)

    <?php
    $age=array("Peter"=>"35","Ben"=>"37","Joe"=>"43");
    ksort($age);

    foreach($age as $x=>$x_value)
        {
        echo "Key=" . $x . ", Value=" . $x_value;
        echo "<br>";
        }
    ?>

    خروجی کد بالا:

    Key=Ben, Value=37
    Key=Joe, Value=43
    Key=Peter, Value=35

    در مثال زیر، آرایه انجمنی age$ بر اساس مقادیر سلول ها، از بزرگ به کوچک مرتب شده است:

    مثال (آرایه ها در PHP)

    <?php
    $age=array("Peter"=>"35","Ben"=>"37","Joe"=>"43");
    arsort($age);

    foreach($age as $x=>$x_value)
        {
        echo "Key=" . $x . ", Value=" . $x_value;
        echo "<br>";
        }
    ?>

    خروجی کد بالا:

    Key=Joe, Value=43
    Key=Ben, Value=37
    Key=Peter, Value=35

    برگرداندن تعداد عناصر یک آرایه

    Wiki

    با استفاده از تابع ()count، می توان تعداد عناصر یک آرایه را برگرداند.

    مثال (آرایه ها در PHP)

    برگرداندن تعداد عناصر یک آرایه:

    <?php
    $cars=array("Volvo","BMW","Toyota");
    echo count($cars);
    ?>

    3

    نحوه استفاده:

    count(array,mode);
    پارامتر توضیحات
    array الزامی است، نام آرایه را تعیین می کند.
    mode اختیاری است، در آرایه های چند بعدی، نحوه شمارش عناصر را تعیین می کند.
    • 0: مقدار پیشفرض، در آرایه های چند بعدی، تعداد کل عناصر را برنمی گرداند.
    • 1: در آرایه های چند بعدی، تعداد کل عناصر را برمی گرداند.

    نکته: پارامتر mode از php 4.2 به بعد اضافه شده است.

    یک مثال دیگر از تابع ()count

    مثال (آرایه ها در PHP)

    تعداد عناصر، در آرایه های چند بعدی:

    <?php
    $cars=array
      (
      "Volvo"=>array
      (
      "XC60",
      "XC90"
      ),
      "BMW"=>array
      (
      "X3",
      "X5"
      ),
      "Toyota"=>array
      (
      "Highlander"
      )
      );

    echo "Normal count: " . count($cars)."<br>";
    echo "Recursive count: " . count($cars,1);
    ?>

    Normal count: 3
    Recursive count: 8

    در بیاموزهای بعدی درباره ی حلقه ی foreach توضیح داده شده است.

    READ MORE
  • به چه چیزی نیاز دارم؟

    Wiki

    برای شروع کار با PHP می توانید یکی از موارد زیر را استفاده نمایید:

    1. می توانید از یک وب هاست که PHP و MYSQL را پشتیبانی می کند، استفاده نمایید.
    2. یک web server مانند Apache، روی کامپیوترتان نصب کنید و سپس PHP و MYSQL را نصب نمایید.
    3. می توانید از پکیج هایی مانند Xampp یا Wamp استفاده نمایید.

    1- وب هاستی که PHP را پشتیبانی می کند

    Wiki

    اگر سرور شما PHP را پشتیبانی می کند به چیز دیگری نیاز ندارید.

    فقط باید یک فایل PHP ایجاد نمایید و آنرا در دایرکتوری وب قرار دهید. سرور بطور اتوماتیک آنرا ترجمه خواهد کرد.

    بخاطر اینکه PHP رایگان است و اغلب سرورها آنرا پشتیبانی می کنند نیاز به کامپایل یا نصب ابزار های اضافی ندارید.

    به هر حال اگر سرور شما PHP را پشتیبانی نمی کند، باید PHP را نصب نمایید.


    2- نصب جداگانه Web Server و PHP و MYSQL

    Wiki

    اگر کامپیوترتان، PHP را پشتیبانی نمی کند باید کارهای زیر را انجام دهید:

    • نصب وب سرور (Apache)
    • نصب PHP
    • نصب بک پایگاه داده، مانند MYSQL

     در لینک روبرو، آموزش چگونگی نصب PHP به خوبی توضیح داده شده است: http://php.net/manual/en/install.php

    دانلود Apache Server:

    برای دانلود رایگان Appache از لینک روبرو استفاده کنید: http://httpd.apache.org/download.cgi

    دانلود PHP:

    برای دانلود رایگان PHP از لینک روبرو استفاده کنید: http://www.php.net/downloads.php

    دانلود MySQL :

    برای دانلود رایگان MySQL از لینک روبرو استفاده کنید: http://www.mysql.com/downloads

     توجه: به جای نصب جداگانه PHP , MySQL, Apache می توانید از پکیج هایی مانند Xampp یا Wamp استفاده نمایید که کار شما را بسیار ساده تر می نمایند، البته در مطلب PHP & IIS چگونگی اجرای فایلهای PHP روی IIS توضیح داده شده است.


    3- استفاده از Xampp یا Wamp

    Wiki

    همانطور که قبلاً گفته شد برای شروع کار با php نیاز به نصب مفسر آن داریم که پکیج Xampp برای این منظور مناسب می باشد.

    مراحل نصب XAMPP:

    برای دانلود رایگان XAMPP از لینک روبرو استفاده کنید: http://www.apachefriends.org/en/xampp.html

    1- در اولین مرحله، خوش آمدگویی داریم، پس Next را مطابق شکل زیر کلیک کنید.

    2-  مسیر نصب را مطابق شکل زیر البته به صورت دلخواه مشخص کنید.

    3- در صورتی که میخواهید Apache و MySQL به عنوان سرویس های ویندوز نصب بشوند گزینه های Install Apache as Service و Install MySQL as Service را تیک بزنید، در غیر این صورت اگر تیک Install as Service را نزده باشید باید هر بار که ویندوز بالا می آید Apache و MySQL را فعال کنید، یعنی باید دکمه Start کنارشون را در کنترل پانل XAMPP کلیک کنید، در نهایت کلید Install را مطابق شکل زیر کلیک کنید.

    نکته1: در صورتیکه IIS روی سیستم شما نصب است و XAMPP را نصب کنید، در نهایت برای اجرای فایل های PHP به مشکل برخواهید خورد، بنابراین باید IIS را Stop کنید.

    نکته2:اگر SQL Server روی سیستم شما نصب است باید سرویس Reporting Services Configuration Manager آنرا Stop کنید تا XAMPP به درستی فایلهای PHP را اجرا کند.

    در شکل زیر کنترل پنل Xampp را می بینید که می توانید Apache و MySQL را Start یا Stop کنید.

     حالا مرورگرتان را باز کنید و در آدرس بار مرورگر localhost یا 127.0.0.1 را تایپ کنید و یا می توانید در شکل بالا دکمه Admin را کلیک کنید اگر همه چیز خوب پیش رفته باشه صفحه زیر را خواهید دید که می توانید زبان صفحات Xampp را انتخاب کنید پس روی English کلیک کنید!

    در نهایت صفحه ای مانند شکل زیر نمایش داده می شود.

    ایجاد و اجرای یک فایل PHP:

      1. یک فایل PHP ساده ایجاد کنید، به عنوان مثال در ادیتور NOTEPAD کد زیر را تایپ کنید و با نام hello و با پسوند php ذخیره کنید(hello.php):

        <?php
        echo "Hello";
        ?>

      2.  فایل ایجاد شده در بالا را در مسیر C:\xampp\htdocs کپی کنید. (مسیر نصب XAMPP خواهد بود)
      3. در آدرس بار مرورگر، آدرس localhost/hello.php را وارد کنید.
      4. اگر همه چیز درست پیش رفته باشد، خروجی زیر را خواهید داشت:

        Hello

    READ MORE
  • بهترین راهکار برای اجرای PHP در IIS ویندوز

    Wiki

    تا قبل از آشنایی با امکانات IIS 7 به نظر می رسید که بهترین جا برای میزبانی یک وب سایت PHP فقط و فقط یک سرور Linux می تواند باشد، چون IIS 6 خیلی خوب PHP را اجرا نمی کند و خبری از URL rewriting هم در IIS 6 نیست، اما تغییر زاویه حرکت مایکروسافت در جهتِ گرفتن بیشتر سهم بازار باعث شده امکانات جالبی به IIS7 اضافه بشود و امروز می شود گفت ویندوز به خوبی لینوکس می تواند یک وب سایت PHP را میزبانی کند.

    سه دلیل اصلی که ویندوز می تواند میزبان خوبی برای PHP باشد:

    • اولین و بهترین دلیل این است که، IIS7 خیلی خوب URL rewriting را پشتیبانی می کند، شما به راحتی می توانید از امکان Pretty URLs سایت وردپرسی خودتان در سرور های ویندوز که IIS7 دارن استفاده کنید.
    • دلیل دوم هم اینه که مایکروسافت وقت زیادی را صرف کرده تا عملکرد Fast CGI را تا حد ممکن در IIS 7 بهبود بدهد، و کاملاً مشکل Performance پایین PHP در ویندوز حل شده.
    • دلیل سوم Module اختصاصی مایکروسافت برای PHP هست که کار Output Caching صفحات PHP رو بسیار آسان می کند و در نتیجه باز هم Performance بهتر…

    و حالا یک نکته مهم: تمام Performance خوبی که تا اینجا ازش صحبت شد در گرو خوب Config کردن IIS 7 برای اجرای PHP هست.

    در گذشته 2 راه برای اجرای PHP در IIS وجود داشت، یعنی PHP را می شد در دو Mode مختلف روی IIS ویندوز اجرا کرد:

    1. CGI Application
    2. ISAPI Managed Handler

    اما هر کدام از این دو راه حل، خوبی ها و مشکلات فراوانی را به همراه داشت.

    • خوبی CGIاین است که PHP رو خوب اجرا می کند و کمتر Crash اتفاق می افتد، اما از طرفی خیلی مصرف CPU بالایی دارد چون CGI برای اجرای هر کار کوچکی یک Process جدید ایجاد می کند و سیستم باید برای اجرای یک پردازش کوچیک صفحه PHP بهای راه اندازی و بستن یک Process رو پرداخت کند.
      سرورهای شلوغ هرگز نمی تونن از CGI برای اجرای PHP استفاده کنند. چون هم Ram به زودی پر می شود و هم CPU از پردازش باز می ماند و نهایتاً کار به Crash کردن ویندوز می کشه.
    • اما ISAPIاین مشکل رو حل کرده، PHP در ISAPI Mode به روشی اجرا میشه که ASP و ASP.Net اجرا میشوند، به این صورت که همه صفحات توسط یک Process پرازش میشوند، اما چطوری؟ IIS توسط سرویس word wide web ویندوز همه پردازش ها را انجام می دهد. و برای اینکه بفهمد فایل های مثلا با پسوند php را چه جوری اجرا کند، از یک فایل dll کمک می گیرد. IIS برای اجرای php یا aspx یا asp از dll های مخصوص همون زبان، که بهش Managed Handler میگن، کمک می گیره و با سرویس world wide web ویندوز اجرا می شود.
      ISAPI مشکل Performance اجرای PHP رو حل کرده اما مشکلات دیگه ای با خودش همراه داره. از جمله اینکه PHP در حالت ISAPI گاهی Crash می کنه و یه جورایی سایت هایی که با این روش کار می کند اعصاب صاحباشون رو خورد می کنن.

    ورود Fast CGI و پایان مشکلات

    Wiki

    مشکلات PHP در CGI و ISAPI موجب به وجود آمدن Fast CGI شد. از اسمش هم معلومه که با چه هدفی ایجاد شده. هدف Fast CGI کنار هم آوردن سرعتISAPI و کاراییCGI هست. در واقع روش کار Fast CGI مثل روش کار CGI هست. اما با تفاوتی کوچک اما کلیدی که سرعت بالایی بهش میده.

    Fast CGI برای انجام هر پردازشی یک Process جدید ایجاد نمی کنه. بلکه یک Process بعد از ایجاد باز می مونه و تعدادی پردازش رو انجام میده و بعد بسته میشه. همین تغییر کوچک موجب پایین اومدن باور نکردنی مصرف منابع سیستم توسط PHP میشه.

    با این حال Config کردن Fast CGI کمی سخت تر از CGI و ISAPI هست. اما بعد از اون مثل بنز کار می کنه.

    خوب پس بهترین راه کار برای اجرای PHP در IIS مشخص شد:

    1. قبل از همه مطمئن شوید كه CGI روی IISتون نصب هست، این رو می‌تونید از اینجا چك كنید:

    Control Panel -> Programs and Features -> Turn Windows features on or off

    2. نسخه غیرنصبی PHP رو دانلود كنید و در مسیر دلخواه (مثلاً C:\PHP) كپی كنید.

    3. فایل php.ini-recommended رو به php.ini تغییر نام بدید و این تغییرات رو در اون ایجاد كنید:

    • كاراكتر سمیکالن ( ;) را از ابتدای خط fastcgi.impersonate = 1 بردارید. (اگر مقدارش یك نیست اون رو به یك تغییر بدید).
    • برای خط cgi.fix_pathinfo = 1 هم همون كار رو انجام بدید.
    • این بار خط cgi.force_redirect=0 (حتماً مقدارش صفر باشد).
    • مقدار خط open_basedir رو برابر با مسیر c:\inetpub\wwwroot قرار بدید.

    حالا این فایل رو Save كنید و برای تست صحت نصب در اعلان داس (Command Prompt) دستور C:\PHP>php –info رو اجرا كنید، اگه اطلاعاتی رو در مورد php نشون داد، یعنی كار تا اینجا خوب پیش رفته.

    4. نوبت به تنظیمات در IIS می‌رسه. ابتدا IIS Manager رو اجرا كنید. سرور اصلی رو از لیست Connections سمت چپ انتخاب كنید و از قسمت میانی گزینه Handler Mapping رو دوبار كلیك كنید. این هم عكس:

    از ستون سمت راست گزینه Add Module Mapping رو انتخاب كنید و اون رو مثل عكس زیر پر كنید و OK كه یه پنجره دیگه بعدش باز می‌شه اون رو هم Yes كنید:

    6. كار تمومه اما برای تست تو پوشه c:\inetpub\wwwroot یه فایل به نام phpinfo.php بسازید با این محتوا:

    <?php
    echo 'Hello';
    ؟>

    و اون را با این آدرس باز كنید: http://localhost/phpinfo.php

    READ MORE
  • در PHP نسخه 5 به بالا، برای کار با پایگاه داده MySQL می توانید یکی از روش های زیر را استفاده نمایید:

    • افزونه MySQLi(کاراکتر i مخفف improved بمعنی بهبود یافته است)
    • PDOکه سرنام واژگان PHP Data Objects است

    در نسخه های قبلی PHP از افزونه MySQL استفاده می شده، اما استفاده از این افزونه، از 2012 دیگر توصیه نمی شود.


    باید از MySQLi استفاده کنم یا PDO ؟

    Wiki

    اگر بخواهیم خیلی خلاصه جواب دهیم، این انتخاب بستگی به نیاز شما دارد...!

    هر کدام از گزینه های MySQLi و PDO، مزییت های خودشان را دارند.

    گزینه PDO با 12 پایگاه داده مختلف کار می کند، اما MySQLi تنها با پایگاه داده MySQL کار خواهد کرد.

    بنابراین اگر بخواهید زمانی به یک پایگاه داده دیگر سوییچ کنید، گزینه PDO کار را آسان تر خواهد کرد و فقط کافی است که ارتباط یا connection به پایگاه داده را تغییر دهید و احتمالاً چند تغییر کوچک در کوئری ها را خواهید داشت.

    هر دو گزینه شیء گرا هستند، اما MySQLi رویه های API را نیز ارائه می دهد.

    هر دو گزینه، دستورات آماده برای مقابله با تزریقات SQL یا SQL injection را پشتیبانی می کنند، که البته این موضوع، برای حفظ امنیت برنامه های کاربردی وب بسیار حیاتی است.


    مثال های MySQL به هر دو روش MySQLi و PDO

    Wiki

    در این مطلب و آموزش های بعدی، سه روش مختلف برای کار کردن با پایگاه داده را نشان خواهیم داد:

    • MySQLi (شیء گرا یا Object-Oriented)
    • MySQLi (رویه ای یا Procedural)
    • PDO

    نصب MySQLi

    Wiki

    برای سیستم عامل Linux و Windows، افزونه MySQLi در اغلب موارد بصورت اتوماتیک بعد از نصب پکیج php5 mysql نصب خواهد شد.

    برای کسب اطلاعات بیشتر به لینک روبرو مراجع فرمایید: http://php.net/manual/en/mysqli.installation.php


    نصب PDO

    Wiki

    برای کسب اطلاعات بیشتر به لینک روبرو مراجع فرمایید: http://php.net/manual/en/pdo.installation.php


    ارتباط یا Connection به پایگاه داده MySQL

    Wiki

    قبل از اینکه به داده های پایگاه داده دسترسی داشته باشید، باید یک ارتباط یا Connection تعریف کنید:

    مثال   (MySQLi Object-Oriented)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";

    // Create connection
    $conn = new mysqli($servername, $username, $password);

    // Check connection
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    }
    echo "Connected successfully";
    ?>
    Note توجه داشته باشید که در مثال شیء گرای بالا، connect_error$ تا PHP 5.2.9 و 5.3.0 PHP کار نمی کند، بنابراین اگر می خواهید که کدتان با نسخه های قدیمی PHP نیز سازگار باشد، بجای آن از کد زیر استفاده نمایید:
     // Check connection
    if (mysqli_connect_error()) {
        die("Database connection failed: " . mysqli_connect_error());
    }

    در مثال زیر با استفاده از تابع ()mysqli_connect یک connection به پایگاه داده تعریف شده است:

    مثال (MySQLi Procedural)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";

    // Create connection
    $conn = mysqli_connect($servername, $username, $password);

    // Check connection
    if (!$conn) {
        die("Connection failed: " . mysqli_connect_error());
    }
    echo "Connected successfully";
    ?>

    مثال(PDO)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";

    try {
        $conn = new PDO("mysql:host=$servername;dbname=myDB", $username, $password);
        // set the PDO error mode to exception
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        echo "Connected successfully";
        }
    catch(PDOException $e)
        {
        echo "Connection failed: " . $e->getMessage();
        }
    ?>
    Note توجه داشته باشید که در مثال PDO بالا، با تنظیم گزینه dbname با مقدار "myDB" نام پایگاه داده را نیز مشخص کرده ایم. اگر PDO موفق به اتصال به پایگاه داده نشود یک استثنا یا exception پرتاب (thrown) می شود.

    نکته: یکی از بزرگترین مزیت های PDO وجود کلاس exception برای مدیریت خطاها است. همان طور که می دانید این خطاها ممکن است در کوئری های پایگاه داده رخ دهد و اگر یک استثنا یا exception از داخل بلاک { }try پرتاب (thrown) شود، اجرای اسکریبت متوقف شده و جریان کار به اولین بلاک { }catch منتقل می شود. در واقع استثنای که در قسمت try رخ داده در قسمت catch به دام می افتد.


    بستن یک ارتباط

    Wiki

    ارتباط یا Connection به صورت اتوماتیک وقتی که اسکریبت پایان یافت، بسته می شود، اما اگر مایل باشید می توانید این کار را قبل از پایان اسکریبت انجام دهید:

    مثال(MySQLi Object-Oriented)

    $conn->close();

    مثال(MySQLi Procedural)

    mysqli_close($conn);

    مثال(PDO)

    $conn = null;
    READ MORE
  • در این آموزش، نحوه ی اعتبارسنجی فیلدهای "نام"، "ایمیل" و "وب سایت" نشان داده خواهد شد.


    اعتبارسنجی فیلد "نام" در PHP

    Wiki

    کد زیر، یک روش ساده برای چک کردن اینکه آیا فیلد "نام" معتبر است یا نه را نشان می دهد. (فیلد نام فقط شامل حروف و خط فاصله است)

    اگر فیلد "نام" معتبر نباشد، در متغیر nameErr$ یک متن مناسب، تنظیم می شود:

    $name = test_input($_POST["name"]);
    if (!preg_match("/^[a-zA-Z ]*$/",$name))
      {
      $nameErr = "فیلد نام  فقط شامل حروف و خط فاصله است";
      }
    Note تابع ()preg_match
    با استفاده از تابع ()preg_match، می توانید یک الگوی خاص را در یک رشته جستجو کنید. اگر الگوی مورد نظر در رشته وجود داشت مقدار true و اگر وجود نداشت مقدار false را برمی گرداند.

    اعتبارسنجی فیلد "ایمیل" در PHP

    Wiki

    روش اول: استفاده از تابع ()preg_match

    کد زیر، یک روش ساده برای چک کردن اینکه آیا فیلد "ایمیل" معتبر است یا نه را نشان می دهد. (باید شامل فرمت صحیح ایمیل باشد، همراه با علامت @ و .)

    اگر فیلد "ایمیل" معتبر نباشد، در متغیر emailErr$ یک متن مناسب، تنظیم می شود:

    $email = test_input($_POST["email"]);
    if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email))
      {
      $emailErr = "فرمت فیلد ایمیل صحیح نیست";
      }

    روش دوم: استفاده از تابع ()filter_var

    یکی دیگر از روش های چک کردن اعتبار ایمیل، استفاده از تابع ()filter_var در PHP است. برای کسب اطلاعات بیشتر درباره تابع ()filter_var به لینک آموزش PHP-فیلتر ورودی ها مراجعه نمایید.

    $email = test_input($_POST["email"]);
    if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
      $emailErr ="فرمت فیلد ایمیل صحیح نیست";
    }

    در این آموزش، از روش اول یعنی تابع ()preg_match استفاده شده است.


    اعتبارسنجی فیلد "وب سایت" در PHP

    Wiki

    کد زیر، یک روش ساده برای چک کردن اینکه آیا فیلد "وب سایت" معتبر است یا نه را نشان می دهد. (باید شامل فرمت صحیح URL باشد، همچنین عبارت منظم زیر اجازه می دهد که در URL علامت dash "-" نیز استفاده شود)

    اگر فیلد "وب سایت" معتبر نباشد، در متغیر websiteErr$ یک متن مناسب، تنظیم می شود:

    $website = test_input($_POST["website"]);
    if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i",$website))
      {
      $websiteErr = "فرمت فیلد وب سایت صحیح نیست";
      }

    اعتبارسنجی فیلدهای "نام"، "ایمیل" و "وب سایت" در PHP

    Wiki

    تا اینجا، اسکریپت مان شبیه زیر شده است:

    مثال (اعتبارسنجی فیلد ایمیل در PHP)

    <!DOCTYPE HTML>
    <html>
    <head>
    <style>
      .error {color: #FF0000;}
      span{min-width: 200px;float: right;}
    </style>
    </head>
    <body>

    <?php
    // define variables and set to empty values
    $nameErr = $emailErr = $genderErr = $websiteErr = "";
    $name = $email = $gender = $comment = $website = "";

    if ($_SERVER["REQUEST_METHOD"] == "POST")
    {
       if (empty($_POST["name"]))
         {$nameErr = "Name is required";}
       else
         {
         $name = test_input($_POST["name"]);
         // check if name only contains letters and whitespace
         if (!preg_match("/^[a-zA-Z ]*$/",$name))
           {
           $nameErr = "Only letters and white space allowed";
           }
         }
      
       if (empty($_POST["email"]))
         {$emailErr = "Email is required";}
       else
         {
         $email = test_input($_POST["email"]);
         // check if e-mail address syntax is valid
         if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email))
           {
           $emailErr = "Invalid email format";
           }
         }
        
       if (empty($_POST["website"]))
         {$website = "";}
       else
         {
         $website = test_input($_POST["website"]);
         // check if URL address syntax is valid (this regular expression also allows dashes in the URL)
         if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i",$website))
           {
           $websiteErr = "Invalid URL";
           }
         }

       if (empty($_POST["comment"]))
         {$comment = "";}
       else
         {$comment = test_input($_POST["comment"]);}

       if (empty($_POST["gender"]) || $_GET["gender"]=="undefined")
         {$genderErr = "Gender is required";}
       else
         {$gender = test_input($_POST["gender"]);}
    }

    function test_input($data)
    {
         $data = trim($data);
         $data = stripslashes($data);
         $data = htmlspecialchars($data);
         return $data;
    }
    ?>

    <h2>مثال اعتبارسنجی فرم ها در PHP</h2>
    <form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">
    <div>
      <span>نام:</span><input type="text" name="name">
      <span class="error">*</span>
    </div>
    <div>
      <span>ایمیل:</span>
    <input type="text" name="email">
      <span class="error">*</span>
    </div>
    <div>
      <span>وب سایت:</span>
    <input type="text" name="website">
      <span class="error"></span>
    </div>
    <div>
      <span>توضیحات:</span>
    <textarea name="comment" rows="5" cols="40"></textarea>
      <span class="error">*</span>
    </div>
    <div>
    <span>جنسیت:</span>

    <input type="radio" name="gender" value="female">زن
    <input type="radio" name="gender" value="male">مرد
    </div>
    </div><input type="submit" name="submit" value="ارسال اطلاعات"></div>
    </form>

    <?php
    if ($nameErr!="" || $emailErr!="" || $genderErr!="" || $websiteErr!="")
    echo "<span style='color:red' >
             $nameErr <br /> $emailErr <br /> $genderErr <br /> $websiteErr
          </span>";
    else
    {
    echo "<br /><h2>خروجی کدتان</h2>";
    echo "نام :$name";
    echo "<br />";
    echo "ایمیل: $email";
    echo "<br />";
    echo "وب سایت: $website";
    echo "<br />";
    echo "توضیحات: $comment";
    echo "<br />";
    echo "جنسیت: $gender";
    ?>

    }
    </body>
    </html>

    خروجی کد بالا:

    مثال اعتبارسنجی فرم ها در PHP

    نام:*
    ایمیل:*
    وب سایت:
    توضیحات:
    جنسیت: زن مرد*
     

    در آموزش بعدی نحوه ی جلوگیری از خالی شدن فیلدهای فرم، زمانی که کاربر روی دکمه submit کلیک می کند را نشان خواهیم داد.

    READ MORE
  • امنیت در کد ارسال ایمیل

    Wiki

    یک ضعف در اسکریپت e-mail فصل قبل وجود دارد. ابتدا، به کد آن نگاهی می اندازیم:

    <html>
    <body>

    <?php
    //اگر تکست باکس ایمیل پرشده باشد،ایمیل ارسال می شود
    if (isset($_REQUEST['email']))
      {
      //ارسال ایمیل
      $email = $_REQUEST['email'] ;
      $subject = $_REQUEST['subject'] ;
      $message = $_REQUEST['message'] ;
      mail("این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید", "Subject: $subject",
      $message, "From: $email" );
      echo "Thank you for using our mail form";
      }
    else
    //اگر تکست باکس ایمیل پرنشده باشد، فرم ارسال، نمایش داده می شود
      {
      echo "<form method='post' action='mailform.php'>
      Email: <input name='email' type='text' /><br />
      Subject: <input name='subject' type='text' /><br />
      Message:<br />
      <textarea name='message' rows='15' cols='40'>
      </textarea><br />
      <input type='submit' />
      </form>";
      }
    ?>

    </body>
    </html>

    مشکل کد بالا این است که کاربران غیرمجاز می توانند از طریق فرم ورودی، درون header نامه، داده درج کنند.

    توضیح بیشتر: چه اتفاقی خواهد افتاد اگر کاربر متن زیر را در فیلد ورودی email در فرم اضافه کند؟

    این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید%0ACc:این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید
    %0ABcc:این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید,این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید,
    این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید,این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید
    %0ABTo:این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید

    تابع ()mail طبق معمول متن بالا را درون header نامه قرار می دهد و اکنون header فیلدهای اضافی cc و Bcc و to را دارد. وقتی که کاربر بر روی دکمه submit کلیک می کند ٫email به تمام آدرس های بالا ارسال خواهد شد!


    متوقف کردن تزریقات E-mail در php

    Wiki

    بهترین راه برای متوقف کردن تزریقات email، معتبر کردن ورودی است.

    کد زیر مانند کد فصل قبل است٫ اما حالا ما یک معتبرساز وروردی که فیلد email را در فرم چک می کند اضافه کرده ایم:

    <html>
    <body>
    <?php
    function spamcheck($field)
      {
      $field=filter_var($field, FILTER_SANITIZE_EMAIL);
      if(filter_var($field, FILTER_VALIDATE_EMAIL))
        {
        return TRUE;
        }
      else
        {
        return FALSE;
        }
      }
    //اگر تکست باکس ایمیل پرشده باشد،ایمیل ارسال می شود  
    if (isset($_REQUEST['email']))
      {
      //چک می کنیم که آدرس ایمیل معتبر است یا نه
      $mailcheck = spamcheck($_REQUEST['email']);
      if ($mailcheck==FALSE)
        {
        echo "Invalid input";
        }
      else
        //ارسال ایمیل  
        {
        $email = $_REQUEST['email'] ;
        $subject = $_REQUEST['subject'] ;
        $message = $_REQUEST['message'] ;
        mail("این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید", "Subject: $subject",
        $message, "From: $email" );
        echo "Thank you for using our mail form";
        }
      }
    else
      //اگر تکست باکس ایمیل پرنشده باشد، فرم ارسال، نمایش داده می شود  
      {
      echo "<form method='post' action='mailform.php'>
      Email: <input name='email' type='text' /><br />
      Subject: <input name='subject' type='text' /><br />
      Message:<br />
      <textarea name='message' rows='15' cols='40'>
      </textarea><br />
      <input type='submit' />
      </form>";
      }
    ?>

    </body>
    </html>

    در کد بالا ما از فیلترهای php زیر، برای معتبرسازی ورودی استفاده کرده ایم:

    • فیلتر FILTER_SANITIZE_EMAIL: تمام کاراکترهای غیرمجاز ایمیل را از رشته حذف می کند.
    • فیلتر FILTER_VALIDATE_EMAIL: آدرس ایمیل را معتبر می کند.

    برای اطلاعات بیشتر درمورد فیلتر های PHP می توانید به بخش PHP Filter مراجعه کنید.

    READ MORE
  • پایگاه داده شامل یک یا جند جدول است.

    باید بدانید که برای ایجاد یا حذف پایگاه داده، باید دسترسی لازم را داشته باشید.


    ایجاد پایگاه داده با استفاده از MySQLi و PDO

    Wiki

    دستور CREATE DATABASE برای ایجاد یک پایگاه داده در MySQL استفاده می شود.

    نحوه استفاده:

    CREATE DATABASE database_name

    در مثال زیر یک پایگاه داده به نام "myDB" ایجاد کرده ایم:

    مثال (MySQLi Object-oriented)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";

    // Create connection
    $conn = new mysqli($servername, $username, $password);
    // Check connection
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    }

    // Create database
    $sql = "CREATE DATABASE myDB";
    if ($conn->query($sql) === TRUE) {
        echo "Database created successfully";
    } else {
        echo "Error creating database: " . $conn->error;
    }

    $conn->close();
    ?>
    Note توجه: زمانی که می خواهید یک پایگاه داده جدید ایجاد کنید، در شیء mysqli تنها سه آرگومان اول را باید مشخص نمایید. (servername و username و password)
    نکته:
    اگر برای اتصال به پایگاه داده باید از یک Port مشخص استفاده نمایید، برای تنظیم این آرگومان در شیء mysqli باید آرگومان چهارم یعنی database-name را با یک رشته خالی تنظیم نمایید و سپس آرگومان پنجم را برای تنظیم Port استفاده نمایید:
    mysqli("localhost", "username", "password", "", port)

    مثال (MySQLi Procedural)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";

    // Create connection
    $conn = mysqli_connect($servername, $username, $password);
    // Check connection
    if (!$conn) {
        die("Connection failed: " . mysqli_connect_error());
    }

    // Create database
    $sql = "CREATE DATABASE myDB";
    if (mysqli_query($conn, $sql)) {
        echo "Database created successfully";
    } else {
        echo "Error creating database: " . mysqli_error($conn);
    }

    mysqli_close($conn);
    ?>

    در مثال زیر یک پایگاه داده به نام "myDBPDO" ایجاد کرده ایم:

    مثال(PDO)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";

    try {
        $conn = new PDO("mysql:host=$servername;dbname=myDB", $username, $password);
        // set the PDO error mode to exception
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $sql = "CREATE DATABASE myDBPDO";
        // use exec() because no results are returned
        $conn->exec($sql);
        echo "Database created successfully<br>";
        }
    catch(PDOException $e)
        {
        echo $sql . "<br>" . $e->getMessage();
        }

    $conn = null;
    ?>

    نکته: یکی از بزرگترین مزیت های PDO وجود کلاس exceptionبرای مدیریت خطاها است. همان طور که می دانید این خطاها ممکن است در کوئری های پایگاه داده رخ دهد و اگر یک استثنا یا exceptionاز داخل بلاک { }try پرتاب (thrown) شود، اجرای اسکریبت متوقف شده و جریان کار به اولین بلاک { }catch منتقل می شود. در واقع استثنای که در قسمت try رخ داده در قسمت catch به دام می افتد. در بلاک catch، با استفاده از دستور echo، دستور SQL و متن خطای تولید شده را چاپ می کنیم.

    READ MORE
  • جلسه اول بسته آموزشی طراحی یک فروشگاه اینترنتی-ایجاد سربرگ فروشگاه

    در قسمت اول از این بسته، به آموزش 'ایجاد سربرگ فروشگاه' و همچنین نحوه ی ساخت پروژه از صفر، می پردازیم.


    طرح اولیه ی وب سایت

    طرح اولیه ی وب سایتی که قرار است آن را در مجموعه ی آموزشی 'ایجاد یک فروشگاه اینترنتی' ایجاد کنیم به صورت زیر می باشد:

     


    قابلیت های وب سایت 

    قابلیت های این وب سایت شامل موارد زیر می باشد:

    1. قسمت منوی باز شونده
    2. قسمت سبد خرید
    3. قسمت ورود کاربران
    4. قسمت ثبت نام در سایت
    5. قسمت اسلاید شو  و...

     مباحث برنامه نویسی مطرح شده در پروژه ی 'ایجاد یک فروشگاه اینترنتی'

    در مجموعه ی آموزشی 'ایجاد یک فروشگاه اینترنتی' قصد داریم که از مباحث مختلف طراحی سایت از قبیل HTML و CSS و PHP و AJAX و JQUERY استفاده کنیم. در این مجموعه حتی مباحث آشنایی با فتوشاپ نیز در حد لازم برای طراحان وب، گنجانده شده است.


     مباحث برنامه نویسی مطرح شده درقسمت 'ایجاد سربرگ  فروشگاه'

     در قسمت 'ایجاد سربرگ فروشگاه' صرفاً به کدنویسی HTML این قالب می پردازیم  و در مراحل بعدی، بعد از اینکه کد نویسی های HTML و همچنین کدنویسی های جاوا اسکریپت و جی کوئری تمام شدند، سایت را به یک سایت پویا و داینامیک تبدیل خواهیم کرد. به عبارت دیگر، برای این سایت، یک پنل مدیریتی طراحی خواهیم کرد، که قابلیت اضافه و یا حذف کردن و یا کنترل مطالب را برای مدیریت این سایت فراهم می کند. 


     شروع طراحی قالب

     در ابتدای طراحی قالب، قصد داریم یک خط را به رنگ بنفش، در بالای سایت، همان طور که در تصویر زیر می بینید ایجاد کنیم:

     برای طراحی این سایت، ما از نرم فزار Dreamweaver استفاده می کنیم، پس بعد از نصب این نرم افزار آن را باز کنید. سپس از منوی 'site' گزینه ی 'new site' را انتخاب کنید:

     بدین وسیله می توانیم یک سایت جدید را ایجاد کنیم.

    در جعبه ی گفتگوی باز شده، مقدار sitename را برابر  با eshop قرار می دهیم و سپس در فیلد بعدی، مسیر سایت  را درون پوشه ی ریشه ی خود(root) مشخص می کنیم:

    پس از انجام مراحل بالا، بر روی گزینه ی 'save' کلیک کنید.

    سپس مراحل زیر را انجام دهید:

    1. از جعبه ی سمت راست، در زیر قسمت 'local files'، بر روی پوشه ی ایجاد شده راست-کلیک کنید.
    2.  گزینه ی 'new file' را انتخاب کنید.
    3. نام فایل ایجاد شده را 'index.php' قرار دهید. 

     

    همان طور که ذکر شد، فایل مورد نظر را با پسوند php ایجاد کردیم. به این دلیل که سایت مورد نظر قرار است به صورت یک سایت داینامیک باشد. به طوری که دارای یک پنل مدیریت باشد تا مدیر سایت بتواند مطالب سایت را کنترل کند. و همچنین بتوانیم اطلاعات را از Database بخوانیم و یا اطلاعات را در آن ذخیره کنیم. 

    توجه کنید که، نام این فایل را index قرار دادیم، زیرا صفحه ی پیش فرضی که، تمام مرورگرها آن را باز می کنند، صفحه ی index می باشد. و در ادامه این فایل را باز می کنیم و شروع به نوشتن کدهای مورد نظر می کنیم...


    در ادامه ی آموزش 'ایجاد سربرگ فروشگاه' خواهید دید...!

    با خرید بسته ی آموزشی "ایجاد سربرگ فروشگاه"  موارد زیر را خواهید دید:

    1. نحوه ی وسط قرار دادن عناصر div با استفاده از دستور margin
    2. نحوه ی ایجاد قسمت بالایی منو با استفاده از HTML و CSS
    3. نحوه ی اضافه کردن لوگو به بالای سایت و تراز کردن آن
    4. نحوه ی استفاده از دستور float در شناور کردن عناصر

    دسترسی به موارد آموزشی بالا در بسته خریداری شده

    • شماره جلسه: 1
    • نام فایل ویدئو: 01
    • فرمت فایل: mp4.

    نقطه ی شروع بحث بالا (ایجاد سربرگ فروشگاه) در ویدئو: 00:20 

    READ MORE
  • ایجاد یک ارتباط ODBC

    Wiki

    با ODBC یا Open Database Connectivity می توان از هر کامپیوتری که روی شبکه قرار دارد به هر پایگاه داده ای متصل شد البته تازمانی که ارتباط ODBC برقرار باشد.

    در اصل ODBC فراهم کننده یک رابط نرم افزاری (API) می باشد که بدین وسیله می توان از DBMS های مختلف استفاده کرد. هدف طراحان ODBC بوجود آوردن یک بستر مستقل از زبان های برنامه نویسی، سیستم عامل ها و DBMS ها بوده است.

    در زیر چگونگی ایجاد یک ارتباط ODBC به پایگاه داده Access توضیح داده شده است:

    1. در کنترل پانل ویندوز روی آیکون Administrative Tools کلیک کنید.
    2. آیکون Data Sources را باز کنید. (ODBC)
    3. تب System DSN را انتخاب کنید.
    4. روی دکمه Add در تب System DNS کلیک کنید.
    5. Microsoft Access Driver را انتخاب کنید و دکمه Finish را کلیک کنید.
    6. در صفحه باز شده محل پایگاه داده را انتخاب کنید.
    7. یک نام مناسب در قسمت Data Source Name وارد کنید.
    8. دکمه OK را کلیک کنید.

    توجه داشته باشید که تنظیمات بالا باید روی کامپیوتری انجام شود که وب سایتتان روی آن قرار دارد و در ادامه اگر Internet Information Server یا IIS روی کامپیوترتان نصب باشد، سایتتان به درستی کار خواهد کرد، اما اگر وب سایتتان روی یک server راه دور قرار دارد، برای تنظیم کردن موارد بالا باید دسترسی فیزیکی به آن سرور داشته باشید و یا می توانید از میزبان وبتان در این مورد سوال کنید.


    ارتباط به یک پایگاه داده

    Wiki

    تابع ()odbc_connect برای ارتباط به پایگاه داده ODBC استفاده می شود. این تابع چهار پارامتر دارد:

    • data source name
    • username
    • password
    • optional cursor type

    می توان از تابع ()odbc_exec برای اجرای یک کوئری روی پایگاه داده استفاده نمود.

    مثال: در مثال زیر یک ارتباط به پایگاه داده northwind ایجاد کرده ایم و سپس یک کوئری اجرا شده است:

    $conn=odbc_connect('northwind','','');
    $sql="SELECT * FROM customers";
    $rs=odbc_exec($conn,$sql);


    بازیابی رکودها

    Wiki

    تابع ()odbc_fetch_row برای بازیابی رکوردهای، کوئری های اجرا شده استفاده می شود، این تابع اگر ردیفی برای بازیابی باشد، مقدار true والا مقدار false را برمی گرداند. این تابع دو پارامتر دارد:

    • نتیجه اجرای یک کوئری
    • پارامتر اختیاری شماره ردیف

    odbc_fetch_row($rs)


    بازیابی یک فیلد

    Wiki

    تابع ()odbc_result برای خواندن یک فیلد از یک رکورد استفاده می شود، این تابع دو پارامتر می گیرد:

    • نتیجه کوئری اجرا شده
    • نام فیلد یا شماره فیلد

    کد زیر مقدار فیلد اول از رکورد اول را در متغیر compname$ قرار می دهد:

    $compname=odbc_result($rs,1);

    کد زیر مقدار فیلدی که نام آن CompanyName است را در متغیر compname$ قرار می دهد:

    $compname=odbc_result($rs,"CompanyName");


    بستن ارتباط

    Wiki

    تابع ()odbc_close برای بستن یک ارتباط ODBC استفاده می شود.

    odbc_close($conn);


    یک مثال ODBC:

    در مثال زیر ابتدا یک Connection ایجاد می کنیم و سپس با اجرای کوئری، نتایج آنرا در یک جدول HTMLی نشان می دهیم:

    <html>
    <body>

    <?php
    $conn=odbc_connect('northwind','','');
    if (!$conn)
      {exit("Connection Failed: " . $conn);}
    $sql="SELECT * FROM customers";
    $rs=odbc_exec($conn,$sql);
    if (!$rs)
      {exit("Error in SQL");}
    echo "<table><tr>";
    echo "<th>Companyname</th>";
    echo "<th>Contactname</th></tr>";
    while (odbc_fetch_row($rs))
      {
      $compname=odbc_result($rs,"CompanyName");
      $conname=odbc_result($rs,"ContactName");
      echo "<tr><td>$compname</td>";
      echo "<td>$conname</td></tr>";
      }
    odbc_close($conn);
    echo "</table>";
    ?>

    </body>
    </html>

    READ MORE
  • بررسی استثناها در php

    Wiki

     همراه با php 5 یک روش جدید شیء گرا برای کار با خطاها ارائه شده است.

    استثنا یا Exception چیست؟

    اگر در حین اجرای عادی اسکریبت، یک خطای خاص رخ دهد، بررسی کننده استثنا، راه اندازی شده و ادامه اجرای اسکریبت را تغییر می دهد، این خطا را می توان با دستورات شرطی، مشخص کرد، این شرط در حقیقت همان استثنای ماست.

    برای استفاده از استثناها می توان مستقیماً از کلاس Exception استفاده کرد و آنرا به صورت زیر راه اندازی یا پرتاب (throw) کرد:

    <?php
    if($error)
      {
         throw new Exception("خطایی رخ داده است\n");
      }
    ?>

    به طور معمول وقتی یک استثنا راه اندازی می شود چه چیزهایی اتفاق می افتد؟

    1. وضعیت فعلی کد ذخیره می شود.
    2. ادامه اجرای کد به یک تابع از پیش تعریف شده (بررسی کننده استثنا) منتقل می شود.
    3. بسته به موقعیت، بررسی کننده استثنا ممکن است اجرای اسکریپت را از وضعیت ذخیره شده از سر بگیرد، یا اجرای اسکریبت را متوقف کند و  یا اجرای اسکریپت را از یک مکان متفاوت در کد ادامه دهد.

    روش های مختلف بررسی خطا:

    1. استفاده اصلی از استثناها
    2. تعریف کلاس استثایِ خودمان
    3. استثناهای چندگانه
    4. راه اندازی مجدد استثنا
    5. تعیین یک مهارکننده استثنای سطح بالا

     نکته: یک استثنا همیشه با یک شرط همراه است و نباید برای پرش به جای دیگر استفاده شود.


    1- استفاده اصلی از استثناها

    Wiki

    زمانی که یک استثنا راه اندازی می شود، اجرای کدهای بعد از آن متوقف شده و php سعی به پیدا کردن بلاک تطابقی استثنای مذکور که catch نامیده می شود، خواهد کرد. به زبان ساده تر بعد از بروز خطا و راه اندازی استثنا، ادامه اجرای اسکریبت در یک بلاک که catch نامیده می شود، گرفتار می شود.

    نکته:اگر php برای یک استثنا بلاک تطابقی آنرا نیابد، یک fatal error یا خطای مهلک، همراه با پیغام "Uncaught Exception" صادر خواهد شد.

    مثال: در این مثال تابع "checkNum" بررسی می کند، اگر پارامتر ورودی آن بزرگتر از "1" بود استثنا راه اندازی شود، البته توجه داشته باشید که استثنای تعریف شده بدون Catch است:

    <?php
    function checkNum($number)
      {
      if($number>1)
        {
        throw new Exception("Value must be 1 or below");
        }
      return true;
      }

    checkNum(2);
    ?>

    خروجی کد بالا:

    Fatal error: Uncaught exception 'Exception'
    with message 'Value must be 1 or below' in C:\webfolder\test.php:6
    Stack trace: #0 C:\webfolder\test.php(12):
    checkNum(28) #1 {main} thrown in C:\webfolder\test.php on line 6

    راه اندازی استثنا همراه با بلاک های try و catch

    در مثال بالا برای مدیریت بهتر خطا، ما به یک کد مناسب برای بررسی کردن استثنا نیاز داریم که می تواند شامل بخش های زیر باشد:

    1. بلاک try: تابعی که یک استثنا را استفاده می کند باید در بلاک "try" باشد. (اگر استثنا راه اندازی نشود، کد داخل این بلاک به طور معمول، ادامه خواهد یافت اما اگر شرط استثنا برقرار شود استثنا اجرا خواهد شد)
    2. راه انداز یا پرتاب استثنا(throw): یعنی چه طور یک استثنا را راه اندازی شود. هر "throw" باید حداقل یک "catch" داشته باشد.
    3. بلاک catch: اگر استثانی پرتاب شود، بلاک "catch" آنرا می گیرد و یک شیء شامل اطلاعات استثنا ایجاد می کند.

    مثال:

    <?php
    function checkNum($number)
      {
      if($number>1)
        {
        throw new Exception("Value must be 1 or below");
        }
      return true;
      }

    try
      {
      checkNum(2);
      //اگر استثنا راه اندازی بشود، خط بعدی اجرا نخواهد شد
      echo 'If you see this, the number is 1 or below';
      }

    catch(Exception $e)
      {
      echo 'Message: ' .$e->getMessage();
      }
    ?>

    خروجی کد بالا:

    Message: Value must be 1 or below

    توضیح مثال بالا:

    1. تابع ()checkNum بررسی می کند که آیا پارامتر ورودی آن بزرگتر از 1 است. اگر بزرگتر باشد یک استثنا پرتاب می شود.
    2. تابع ()checkNum در بلاک "try" فراخوانی می شود
    3. بلاک "catch" استثناهای پرتاب شده را می گیرد و یک شیء (e$) شامل اطلاعات استثنا ایجاد می کند.
    4. پیغام خطای استثنا، با فراخوانی تابع ()getMessage از شیء (e$) تولید می شود.

    2- ایجاد کلاس استثنایِ خودمان

    Wiki

    به سادگی می توانیم یک کلاس سفارشی، همراه با توابعی که بتوانند هنگام رخداد یک استثنا در php فراخوانی شوند، ایجاد کرد، لطفاً به مثال زیر توجه فرمایید:

    نکته:کلاس جدیدمان باید از کلاس Exception ارثبری داشته باشد.

    مثال:

    <?php
    class customException extends Exception
      {
      public function errorMessage()
        {
        $errorMsg = 'Error on line '.$this->getLine().' in '.$this->getFile()
        .': <b>'.$this->getMessage().'</b> is not a valid E-Mail address';
        return $errorMsg;
        }
      }

    $email = "این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید";

    try
      {  
      if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
        {
        throw new customException($email);
        }
      }

    catch (customException $e)
      {
      echo $e->errorMessage();
      }
    ?>

     توضیح مثال:

    1. کلاس customException از کلاس Exception ارثبری دارد، بنابراین، این کلاس همه ی متدها و خصوصیات را از کلاس قبلی به ارث می برد (getMessage,getFile,getLine)
    2. تابع ()errorMessage یک پیغام خطا برمی گرداند (درصورتی که آدرس ایمیل نامعتبر باشد).
    3. متغییر email$ با یک مقدار نامعتبر برای ایمیل تنظیم شده است.
    4. بلاک try اجرا می شود و چون که آدرس ایمیل نامعتبر است، یک استثنا راه اندازی می شود
    5. بلاک catch استثنا را می گیرد و یک پیغام خطا نمایش می دهد

    3- استثناهای چندگانه

    Wiki

    برای یک اسکریپت این امکان وجود دارد که به ازای اتفاق افتادن شرط های متفاوت، استثناهای متفاوت با بلاک های catch متفاوت را تعریف کنیم.

    مثال:

    <?php
    class customException extends Exception
    {
    public function errorMessage()
       {
         $errorMsg = 'Error on line '.$this->getLine().' in '.$this->getFile()
         .': <b>'.$this->getMessage().'</b> is not a valid E-Mail address';
         return $errorMsg;
       }
    }

    $email = "این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید";

    try
      {
      // style="font-family: Courier New;">اگر ایمیل معتبر نباشد، استثنا راه اندازی می شود
      if(filter_var($email, FILTER_VALIDATE_EMAIL) === FALSE)
        {
         throw new customException($email);
        }
      // style="font-family: Courier New;">اگر در آدرس ایمیل کلمه مشخص شده وجود داشت، استثنا راه اندازی می شود
      if(strpos($email, "example") !== FALSE)
        {
         throw new Exception("$email is an example e-mail");
        }
      }

    catch (customException $e)
      {
      echo $e->errorMessage();
      }

    catch(Exception $e)
      {
      echo $e->getMessage();
      }
    ?>

    خروجی کد بالا:

    این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید is an example e-mail

    توضیح مثال:

    1. متغییر email$ با یک آدرس ایمیل معتبر تنظیم می شود، اما شامل رشته ی "example" است.
    2. چون متغییر تعریف شده حاوی رشته ی "example" است? استثنا دوم در بلاک try راه اندازی می شود.
    3.  بلاک catch دوم استثنا را می گیرد و خطای مناسب را برمی گرداند.

    نکته: اگر استثنای بوجود آمده، بلاک catch خود را نیابد، شروع به جستجوی یک بلاک catch دیگر در "سطوح بالاتر" خواهد کرد.


    دوباره راه اندازی استثناها

    Wiki

    بعضی مواقع ممکن است مایل باشید که یک استثنا به صورتی متفاوت از آنچه که استاندارد است بررسی شود. این امر با راه اندازی یک استثنا برای بار دوم از داخل بلاک catch امکان پذیر است.

    یک اسکریبت خوب، باید خطاهای سیستمی را از کاربران معمولی پنهان کند، چون نمایش این خطاها برای برنامه نویس ها کاربرد دارد و برای کاربران معمولی جالب نیست، یک ایده خوب برای ساخت چنین پیغام هایی، دوباره راه اندازی استثناهاست.

    مثال:

    <?php
    class customException extends Exception
      {
      public function errorMessage()
        {
        $errorMsg = $this->getMessage().' is not a valid E-Mail address.';
        return $errorMsg;
        }
      }

    $email = "این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید";

    try
      {
      try
        {   
        if(strpos($email, "example") !== FALSE)
          {      
          throw new Exception($email);
          }
        }
      catch(Exception $e)
        {
        //استثنا دوباره راه اندازی می شود
        throw new customException($email);
        }
      }

    catch (customException $e)
      {
      //display custom message
      echo $e->errorMessage();
      }
    ?>

    توضیح مثال:

    1. بلاک try بک بلاک try دیگر را در خود جای داده است و این امکان را فراهم می کند تا از بلاکِ try داخلی یک استثنا که قبلاً راه اندازی شده را دوباره راه اندازی کرد.
    2. اگر متغییر ایمیل شامل زیر رشته "example" باشد استثنا برای بار اول راه اندازی می شود.
    3. بلاکِ catch اولی(Exception) استثنا را مهار کرده و در ادامه استثنای customException را راه اندازی می کند.
    4. بلاکِ catch دومی(customException) بلافاصله بعد از مهار کردن استثنا، پیغام مناسب را چاپ می کند.

    تعیین یک بررسی کننده استثنای سطح بالا

    Wiki

     تابع ()set_exception_handler، نام یک تابع تعریف شده توسط کاربر را به عنوان پارامتر ورودی می گیرد و برای کار با همه ی استثناهایی که بلاک catch برای آنها مشخص نشده است، از تابع مذکور استفاده می کند.

    مثال:

    <?php
    function myException($exception)
    {
    echo "<b>Exception:</b> " , $exception->getMessage();
    }

    set_exception_handler('myException');

    throw new Exception('Uncaught Exception occurred');
    ?>

    خروجی کد بالا:

    Exception: Uncaught Exception occurred

    در کد بالا بلاک catch وجود ندارد، درعوض یک بررسی کننده استثنای سطح بالا  راه اندازی شده، که می تواند برای گرفتن یا مهار کردن استثناهایی که بلاک catch ندارند، استفاده شود.


    قوانین استثناها

    Wiki

    • با قرار دادن کدهایمان در بلاک try به مهار کردن استثناهای بالقوه کمک کرده ایم.
    • هر بلاک try یا throw باید حداقل یک بلاک catch متناظر داشته باشد
    • استثناها می توانند درون یک بلاک catch راه اندازی شوند.

    یک قانون ساده: چیزی را که راه اندازی(throw) می کنید باید مهار شود(catch). 

    READ MORE
  • در این آموزش قصد داریم تا حرفه ای ترین و محبوب ترین فریم ورک PHP به نام Laravelرا به صورت پروژه محور و تحت یک فروشگاه فروش فایل خدمت شما کاربران محترم، آموزش دهیم.

    شاید در ذهن تان این سوال ایجاد شود که فریم ورک چیست...!؟

    مجموعه ای از کد ها و کلاس ها و توابع آماده که در قالب یک پروژه در اختیار برنامه نویس قرار می گیرد و برنامه نویس می تواند از تمام موارد مندرج در این پروژه در پروژه اصلی خود استفاده کند. برای مثال ما برای ساخت فرم عضویت و ورود بدون فریم ورک باید اقدام به کدنویسی طولانی نماییم و رابط های دیتابیس و جداول و... را ایجاد کنیم و سپس از طریق اعتبار سنجی هویت کاربر را تایید و یا کاربر را وارد دیتابیس(عضویت) نماییم اما در فریم ورک Laravel برای ساخت بخش عضویت و ورود، تنها از کد زیر استفاده می کنید:

    پروژه فروش فایل در PHP

    php artisan make:auth

    سپس به صورت اتوماتیک برگه های عضویت و ورود و دیتابیس ایجاد شده و ما تنها باید فیلد ها را ویرایش و تغییرات ظاهری را اعمال نماییم و موارد مورد نیاز را اضافه کنیم.

    دلایل استفاده از فریم ورک

    مهمترین دلایل ما برای استفاده از فریم ورک ها امنیت بسیار بالای آنها می باشد چون کلاس و توابع توسط برنامه نویسان حرفه ای نوشته و توسعه پیدا کرده اند و همچنین کتابخانه ای از کد ها آماده در اختیار ما قرار دارد که باعث می شود سرعت کدنویسی ما به شدت افزایش پیدا کند مانند نمونه ساخت فرم عضویت و ورود که با کد نویسی php شاید 30 دقیقه زمان برای یک فرد حرفه ای لازم باشد تا اقدام به ایجاد آن نماید اما تحت فریم ورک، یک برنامه نویس عادی در کمتر از 3 دقیقه می تواند این عملیات را انجام دهد و صد البته صد ها دلیل دیگر نیز وجود دارد اما مهمترین آنها این 3 مورد می باشد که بیان شده است.

    بخش های مختلف پروژه فروش فایل در PHP

    در پروژه فروش فایل در PHP، در درس های اول ما تنها بخش های مختلف و کدنویسی های کلی را آموزش می دهیم و در ادامه در یک پروژه کاملا حرفه ای قصد داریم توسط بوت استرپ قالب وب سایت دانلود فایل(فروشگاه دانلودی) را آماده کنیم و همچنین توسط خود لاراول اقدام به ساخت فروشگاه نماییم در این آموزش نحوه درج ایمن فایل و عضویت کاربر و ویرایش کاربر و ساخت سطوح مختلف کاربری و موارد بسیار مهم دیگر قرار دارد.

    پروژه فروش فایل در PHP شامل 38 درس ارزشمند است. اما جهت آشنایی شما با نحوه ی بیان و تدریس مدرس، 4 درس اول بصورت رایگان ارائه شده است:

    1- آموزش پروژه محور فریم ورک لاراول فصل اول (قسمت اول)  - رایـــــگـان

    2- آموزش پروژه محور فریم ورک لاراول فصل اول (قسمت دوم) - رایـــــگـان

    3- آموزش پروژه محور فریم ورک لاراول فصل اول (قسمت سوم) - رایـــــگـان

    4- آموزش پروژه محور فریم ورک لاراول فصل اول (قسمت چهارم) - رایـــــگـان


    برای خرید و دانلود فیلمآموزش پروژه فروش فایل در PHP کلیک کنید.

    READ MORE
  • جلسه ی هفتم طراحی یک فروشگاه اینترنتی-تبدیل سبد خرید به حالت داینامیک

    در قسمت پنجم از این جلسه، به آموزش 'تبدل سبد خرید به حالت داینامیک' خواهیم پرداخت.


    آنچه که در قسمت قبل طراحی شد

    در قسمت قبل، موارد کلی زیر آموزش داده شدند:

    1.  طراحی سبد خرید با استفاده از php

    مشاهده ی آنچه که در قسمت قبل طراحی شد:

     


    آنچه که در قسمت 'تبدیل سبد خرید به حالت داینامیک' خواهید آموخت

    در قسمت 'تبدیل سبد خرید به حالت داینامیک' موارد زیر آموزش داده خواهند شد:

    توضیح اجمالی:

    1.  ادامه ی طراحی سبد خرید با استفاده از php

    توضیح تفصیلی:

    1. بررسی set شدن کوکی با استفاده از دستور isset.
    2. اجرای دو کوئری به صورت تو در تو و استفاده از دو حلقه while جهت دریافت مشخصات محصولاتی که در سبد خرید کاربر وجود دارد.
    3. کار با کوئری select در pdo و مثال هایی متفاوت ، از این کوئری مهم.
    4. کار با افزونه های فایرفاکس که کار ما را در طراحی وب سایت راحت تر می کنند.
    5. نمایش پیغام هیچ محصولی در سبد خرید شما وجود ندارد (در حالتی که کاربر هنوز سبد خریدی را تشکیل نداده است)

    تبدیل سبد خرید به حالت داینامیک

     در این جلسه، ابتدا می خواهیم به سراغ قسمت سبد خرید شما برویم، برویم.همان طور که می دانید،  قبلا کدهای HTML و جی کوئری مربوط به این سبد خرید را یک بار نوشته بودیم. حالا می خواهیم در این قسمت، اطلاعات را از tblsabad دریافت کنیم و در داخل سبد خرید شما، به کاربر نشان بدهیم:

    به عبارت دیگر، می خواهیم از حالت استاتیک،به حالت داینامیک برویم. پس نرم افزار دریم ویور را باز می کنیم. درواقع این سایتی بود که ما بر روی آن کار می کردیم. که نام آن eshop بود.

    در نرم افزار دریم ویور، قسمت سبد خرید در فایل top.php قرار داشت:

     همان طور که در تصویر زیر مشاهده می کنید، اینجا li هایی بود که در قسمت سبد خرید شما، آنها را ایجاد کرده بودیم. حالا برای اینکه بتوانیم این بار اطلاعات را از دیتابیس دریافت کنیم کدهایی که مربوط به دیتابیس هست و قبلا یک بار آنها را نوشته ایم، را کپی می کنیم و در اینجا از آنها استفاده می کنیم. زیرا برای اینکه تکراری نشود، ما این کدها را دوباره نمی نویسیم:

     

     حالا قرار است که ما در داخل قسمت سبد خرید شما،محصولات  سبد خریدی که کاربر قبلا آنها انتخاب کرده است را به او نمایش بدهیم. ابتدا باید چک کنیم که آیا، اصلا سبد خریدی وجود دارد یا نه. یعنی آیا کوکی ما ست شده است یا نه. پس با این توضیحات، ما به یک دستور if نیاز داریم...


    دسترسی به موارد آموزشی بالا در بسته ی خریداری شده:

    • شماره جلسه: 7
    • نام فایل ویدئو: 27
    • فرمت فایل: mp4.

    نقطه ی شروع بحث بالا (تبدیل سبد خرید به حالت داینامیک) در ویدئو: 02:48

    READ MORE
  • جلسه ی هفتم طراحی یک فروشگاه اینترنتی-تبدیل سبد خرید به حالت داینامیک(2)

    در قسمت ششم از این جلسه، به آموزش 'تبدیل سبد خرید به حالت داینامیک(2)' خواهیم پرداخت.


    آنچه که در قسمت قبل طراحی شد

    در قسمت قبل، موارد کلی زیر آموزش داده شدند:

    1.  تبدیل سبد خرید از حالت استاتیک به داینامیک

    مشاهده ی آنچه که در قسمت قبل طراحی شد:

     


    آنچه که در قسمت 'تبدیل سبد خرید به حالت داینامیک(2)' خواهید آموخت

    در قسمت 'تبدیل سبد خرید به حالت داینامیک(2)' موارد زیر آموزش داده خواهند شد:

    توضیح اجمالی:

    1.  ادامه ی تبدیل سبد خرید  از حالت استاتیک به داینامیک

    توضیح تفصیلی:

    1.  ایجاد یک تغییر کوچک در ست کردن زمان کوکی ها به خاطر از بین نرفتن آنها با بستن مرورگر
    2. نحوه ی ست کردن زمان کوکی یه 1 سال.
    3. نحوه ی نمایش دادن آنی محصول بعد از کلیک کردن بر روی اضافه به سبد خرید.
    4. طراحی قسمت تعداد محصول در سبد خرید. 
    5. نحوه ی تشخیص اینکه، آیا محصولی که کلیک شده است، در سبد خرید وجود دارد یا نه.

    و...


    تبدیل سبد خرید به حالت داینامیک(2)

     کاری که می خواهیم در این جلسه انجام دهیم به این صورت می باشد: زمانی که کاربر دکمه ی افزودن به سبد خرید را کلیک می کند در داخل سبد خرید شما، تا قبل از اینکه صفحه را رفرش کند، محصول خودش را نمی تواند مشاهده کند. یعنی این محصول، به صورت آنی و لحظه ای، وارد قسمت سبد خرید شما نمی شود. حتما لازم است که کاربر، صفحه ی خود را رفرش کند تا محصول جدیدی را در داخل سبد خرید خودش بتواند مشاهده کند:

     می خواهیم کاری کنیم که به صورت آنی و لحظه ای، به محض اینکه کاربر، سبد خرید شما را کلیک کرد، محصول انتخابی در داخل سبد خرید شما، به او نمایش داده شود. و نیازی به رفرش کردن صفحه نباشد:

     دوباره در اینجا، دو حالت مختلف داریم. همان طور که در عکس بالا مشاهده می کنید، تلوزیون مدل پارس، در سبد خرید ما وجود دارد، اگر که کاربر دوباره تلوزیون مدل پارس را انتخاب کند، کاری که باید داخل کدهایمان انجام دهیم، این است که عدد فیلد مربوط به تعداد را پیدا کنیم و 1 واحد به آن اضافه کنیم. اما حالت دوم حالتی است که محصولی در داخل سبد خرید وجود ندارد. یعنی اگر کاربر به طور فرضی، یک محصول را که در سبد خرید وجود ندارد را انتخاب کند، ما باید در قسمت سبد خرید، یک li جدید به بخش سبد خریدمان اضافه کنیم که عکس محصول و تعدادش را به کاربر نشان بدهیم. پس ما دو حالت مختلف داریم. حالا سوال اینجاست: زمانی که کاربر روی یکی از محصولات کلیک کرد، و خواست آن را به سبد خرید اضافه کند، چطور می توانیم تشخیص دهیم که آیا محصول داخل سبد خرید وجود دارد یا خیر؟


    دسترسی به موارد آموزشی بالا در بسته ی خریداری شده:

    • شماره جلسه: 7
    • نام فایل ویدئو: 28
    • فرمت فایل: mp4.

    نقطه ی شروع بحث بالا (تبدیل سبد خرید به حالت داینامیک2) در ویدئو: 05:20

    READ MORE
  • تجرد یا Abstract:

    Wiki

    تجرد یا Abstract موقعی استفاده می شود که بخواهیم کلاس یا تابعی را بدون داشتن بدنه تعریف کنیم و بخواهیم بدنه آن را بعداً تعریف کنیم.

    به عنوان مثال اگر بخواهیم چندین کلاس مختلف برای کار با دیتابیس های مختلف در برنامه تعریف کنیم که در آن برخی کارها یکسان می باشد؛ میتوانیم یک کلاس abstract برای تعریف اولیه و توابع یکسان آنها تعریف کنیم و سپس به نسبت هر دیتابیس توابع مخصوص آن را فراخوانی کرد.

    مزیت های استفاده از abstarct:

    1. کم تر شدن کدهای نوشته شده
    2. افزایش سرعت برنامه
    3. روان تر و خواناتر بودن کدها

    مثال:

    <?php
    abstract class Base_DB{
        private $id; 
        abstract function update($data,$id); 
        abstract function insert($data);
        function save($data){
            if(is_null($this->id)){
                $this->insert($data);
            }else{
                $this->update($data,$this->id);
            }
        }
    }
    class MySQL_DB extends Base_DB{
        function update($data,$id)
        { 
            // کدهای مربوط به ویرایش 
        }
        function insert($data)
        {
            // کدهای مربوط به درج کردن 
        }
    }
    class Oracle_DB extends Base_DB{ 
        function update($data,$id)
        { 
            // کدهای مربوط به ویرایش 
        }
        function insert($data)
        {
            // کدهای مربوط به درج کردن 
        } 
    }
    ؟>

    با کمک کلاس های MySQL_DB و Oracle_DB که در بالا تعریف شد می توان با تابع save و یا هر تابع دیگری کارهای مربوطه را انجام داد؛ توجه داشته باشید که توابع update و insert که در کلاس Base_DB به صورت abstract تعریف شده اند باید در کلاسهایی که از آن سرچشمه می گیرند تعریف شده باشند.


    interface

    Wiki

    کلاسهایی که به صورت interface تعریف می شوند تقریباً همانند کلاس هایی هستند که به صورت abstract تعریف می شوند اما نحوه تعریف و استفاده آنها متفاوت می باشد.

    مثال:

    <?php
    interface class Base_DB {
        public function update($data,$id);
        public function insert($data);
    }

    class MySQL_DB implements Base_DB{ 
        function update($data,$id)
        { 
            // کدهای مربوط به ویرایش 
        }
        function insert($data)
        {
            // کدهای مربوط به درج کردن 
        }
    }
    class Oracle_DB implements Base_DB{ 
        function update($data,$id)
        { 
            // کدهای مربوط به ویرایش 
        }
        function insert($data)
        {
            // کدهای مربوط به درج کردن 
        }

    ؟>

    توجه داشته باشید که کلاسهایی که به صورت interface تعریف می شوند نباید شامل بدنه یک تابع باشند؛ در صورتی که کلاس های abstract می توانستند ادغامی از توابع معمولی و توابع abstract شوند.
    به این نکته نیز توجه داشته باشید که کلاسهای interface بجای extends با implements توسعه می یابند.


    تشخیص کلاس یک شئ

    Wiki

    در برنامه نویسی توجه به این نکته که آیا شئ مورد نظر از کلاس مد نظر ما ساخته شده است یا نه نکته ای است که کاربرد های زیادی دارد.

    برای این منظور می توان از دستور instanceof استفاده کرد؛

    instanceof همچنین برای کلاس هایی که از یک کلاس دیگر ارث بری کرده اند نیز استفاده می شود؛

    مثال:

    <?php 
    class Parent
    {
        // ...
    }

    class PLUS extends Parent
    {
        // ...
    }

    $test = new PLUS();
    if($test instanceof PLUS)
    {
        echo "test comes from PLUS....<br />";
    }
    if($test instanceof Parent)

        echo "test comes from Parent....<br />";

    ?>

    خروجی کد بالا:

    test comes from PLUS....
    test comes from Parent....

    همانطور که در مثال بالا دیده میشود test$ هم از نوع PLUS است و هم از نوع Parent!

    READ MORE
  • تجزیه کننده DOM چیست؟

    Wiki

    یک سری اشیاء استاندارد برای دسترسی و دستگاری فایل های HTML و XML فراهم می کند و در سه بخش زیر مجزا شده است:

    •  هسته DOM:  یک سری اشیاء استاندارد برای فایل های ساخت یافته تعریف می کند.
    • XML DOM: یک سری اشیاء استاندارد برای فایل های XML تعریف می کند.
    • HTML DOM: یک سری اشیاء استاندارد برای فایل های HTML تعریف می کند.

    تجزیه کننده XML

    Wiki

    برای خواندن، ویرایش کردن، ایجاد و خلاصه دستگاری یک فایل XML، به یک تجزیه کننده XML نیاز داریم.

    به صورت کلی دو نوع تجزیه کننده XML وجود دارد:

    1. تجزیه کننده درختی: این تجزیه کننده فایل XML را به یک ساختار درختی منتقل می کند و تمام فایل را تحلیل کرده و دسترسی به عناصر درخت را فراهم می کند.
    2. تجزیه کننده رویدادی: یک فایل XML را به صورت یک سری از رویدادها می بیند و زمانی که یک رویداد خاص اتفاق می افتد، یک تابع را برای بررسی آن صدا می زند.

    تجزیه کننده DOM از نوع درختی است.

    به فایل XML زیر توجه کنید:

    <?xml version="1.0" encoding="ISO-8859-1"?>
    <from>Amir</from>

    تجزیه کننده DOM فایل XML بالا را به صورت زیر می بیند(سه سطح):

    • سطح اول درخت: یک فایل XML را مشخص می کند.
    • سطح دوم درخت: ریشه عنصر را مشخص می کند که تگ <from> است.
    • سطح سوم درخت: متن عنصر که کلمه "Amir" است.

    نصب تجزیه کننده XML

    Wiki

    توابع تجزیه کننده DOM قسمتی از هسته PHP هستند و نیازی به نصب وجود ندارد.


    فایل XML زیر در مثال های آینده استفاده خواهد شد:

    <?xml version="1.0" encoding="ISO-8859-1"?>
    <note>
    <to>Tove</to>
    <from>Jani</from>
    <heading>Reminder</heading>
    <body>Don't forget me this weekend!</body>
    </note>


    لود و چاپ یک فایل XML

    Wiki

    مثال:در مثال زیرمی خواهیم یک تجزیه کننده XML تعریف کرده و فایل XML بالا را داخل آن لود کنیم و سپس در خروجی چاپ کنیم:

    <?php
    $xmlDoc = new DOMDocument();
    $xmlDoc->load("note.xml");
    print $xmlDoc->saveXML();
    ?>

    خروجی کد بالا:

    ToveJaniReminderDon't forget me this weekend!

    اگر در Browser ویندوزتان گزینه "View source" را انتخاب کنید، فایل HTML زیر را خواهید دید:

    <?xml version="1.0" encoding="ISO-8859-1"?>
    <note>
    <to>Tove</to>
    <from>Jani</from>
    <heading>Reminder</heading>
    <body>Don't forget me this weekend!</body>
    </note>

    مثال بالا یک شی از DOMDocument ایجاد می کند و فایل "note.xml" را داخل آن لود می کند. 

    سپس تابع ()saveXML فایل XML لود شده را داخل یک رشته قرار می دهد، حالا می توانیم آنرا در خروجی چاپ کنیم.


    حلقه زدن در یک فایل XML

    Wiki

    مثال: در مثال زیر می خواهیم یک تجزیه کننده XML تعریف کنیم و فایل XML قبلی را در آن لود کرده و بین عناصر آن یک حلقه بزینم:

    <?php
    $xmlDoc = new DOMDocument();
    $xmlDoc->load("note.xml");

    $x = $xmlDoc->documentElement;
    foreach ($x->childNodes AS $item)
      {
      print $item->nodeName . " = " . $item->nodeValue . "<br />";
      }
    ?>

    خروجی کد بالا:

    #text =
    to = Tove
    #text =
    from = Jani
    #text =
    heading = Reminder
    #text =
    body = Don't forget me this weekend!
    #text =

    در مثال بالا  می بینید که بین هر عنصر یک نود خالی وجود دارد.

    در زمان ایجاد یک فایل XML، در بین نودهای آن فضاهای خالی قرار می گیرد، تجزیه کننده XML با این فضاهای خالی مانند یک عنصر معمولی برخورد می کند و اگر مراقب آنها نباشید، برای شما مشکل ایجاد خواهند کرد.

    READ MORE
  • XML چیست؟

    Wiki

    XML برای شرح و بیان اطلاعات طراحی شده است، در واقع ساختار اطلاعات را شرح می دهد.

    در XML هیچ تگ از پیش تعریف شده ای وجود ندارد، و باید خودمان تگ ها را تعریف کنیم.


    تجزیه کننده Expat چیست؟

    Wiki

    برای خواندن، ویرایش کردن، ایجاد و خلاصه دستگاری یک فایل XML، به یک تجزیه کننده XML نیاز داریم.

    به صورت کلی دو نوع تجزیه کننده XML وجود دارد:

    1. تجزیه کننده درختی: این تجزیه کننده فایل XML را به یک ساختار درختی منتقل می کند و تمام فایل را تحلیل کرده و دسترسی به عناصر درخت را فراهم می کند.(همان طور که قبلاً گفته شد تجزیه کننده DOM از نوع درختی است)
    2. تجزیه کننده رویدادی: یک فایل XML را به صورت یک سری از رویدادها می بیند و زمانی که یک رویداد خاص اتفاق می افتد، یک تابع را برای بررسی آن صدا می زند.

    تجزیه کننده Expat از نوع رویدادی است.

    نکته: تجزیه کننده رویدادی، به جای اینکه روی ساختار تمرکز کند روی محتوای یک فایل XML تمرکز می کند، به همین خاطر دسترسی به اطلاعات در این نوع تجزیه کننده سریع تر است.

    به فایل XML زیر توجه کنید:

    <from>Amir</from>

    یک تجزیه کننده رویدادی فایل XML بالا را به صورت سه رویداد زیر گزارش می دهد:

    1. شروع عنصر: from
    2. شروع بخص اطلاعات با مقدار: "Amir"
    3. بستن عنصر: form

    مثال XML بالا با یک فرمت درست نوشته شده است، اما به خاطر اینکه DTD ندارد، معتبر نیست.

    نکته: DTD یا Document Type Definition مشخص کننده قوانین به کار رفته در یک سند است، به این قوانین الگو می گویند، الگوها ابزارهای مهمی برای نگهداری پیوستگی اسناد محسوب می گردند. با مقایسه سند معینی با الگوی آن اعتبار آن سند تعیین می شود. اگر یک سند با تمام قوانین موجود در الگوی آن مطابقت داشته باشد به آن یک سند معتبر می گویند. معتبر بودن یک سند نشانه مطلوب بودن داده های آن است.

    تجزیه کننده Expat یک تجزیه کننده بدون اعتبار است، و برای آن فرقی نمی کند که سند شنا از DTD استفاده کرده یا نه!

    سند XML شما باید در یک فرمت درست نوشته شده باشد والا تجزیه کننده Expat خطایی نمایش خواهد داد.


    نصب تجزیه کننده Expat

    Wiki

    توابع تجزیه کننده Expat قسمتی از هسته PHP هستند و نیازی به نصب وجود ندارد.


    فایل XML زیر در مثال های آینده استفاده خواهد شد:

    <?xml version="1.0" encoding="ISO-8859-1"?>
    <note>
    <to>Tove</to>
    <from>Jani</from>
    <heading>Reminder</heading>
    <body>Don't forget me this weekend!</body>
    </note>


    اعلان یک تجزیه کننده XML

    Wiki

    در PHP می توانیم یک تجزیه کننده XML را اعلان کنیم، برای رویدادهای مختلف، تعدادی رسیدگی کننده (Handler) تعریف می شود و سپس فایل XML را تحزیه می کنیم.

    مثال:

    <?php
    //Initialize the XML parser
    $parser=xml_parser_create();

    //Function to use at the start of an element
    function start($parser,$element_name,$element_attrs)
      {
      switch($element_name)
        {
        case "NOTE": echo "-- Note --<br />"; break;
        case "TO": echo "To: "; break;
        case "FROM": echo "From: "; break;
        case "HEADING": echo "Heading: "; break;
        case "BODY": echo "Message: ";
        }
      }

    //Function to use at the end of an element
    function stop($parser,$element_name)
      {
      echo "<br />";
      }

    //Function to use when finding character data
    function char($parser,$data)
      {
      echo $data;
      }

    //Specify element handler
    xml_set_element_handler($parser,"start","stop");

    //Specify data handler
    xml_set_character_data_handler($parser,"char");

    //Open XML file
    $fp=fopen("test.xml","r");

    //Read data
    while ($data=fread($fp,4096))
      {
      xml_parse($parser,$data,feof($fp)) or die (sprintf("XML Error: %s at line %d",
      xml_error_string(xml_get_error_code($parser)),
      xml_get_current_line_number($parser)));
      }

    //Free the XML parser
    xml_parser_free($parser);
    ?>

    خروجی کد بالا:

    -- Note --
    To: Tove
    From: Jani
    Heading: Reminder
    Message: Don't forget me this weekend!

    توضیح مثال بالا:

    1. تابع ()xml_parser_create یک تجزیه کننده XML را اعلان می کند.
    2. تابع start به عنوان رسیدگی کننده به رویدادهای مختلف ایجاد شده است.
    3. تابع ()xml_set_element_handler مشخص می کند، زمانی که تجزیه کننده با تگ باز و بسته مواجه شد، کدام تابع اجرا شود.
    4. تابع ()xml_set_character_data_handler مشخص می کند، زمانی که تجزیه کننده با اطلاعات مواجه شد، کدام تابع اجرا شود.
    5. تابع ()xml_parse فایل "test.xml" را تجزیه می کند.
    6. در صورتی که خطایی رخ دهد، تابع ()xml_error_string خطای گزارش شده را به شرحی مناسب تبدیل می کند.
    7. در آخر تابع ()xml_parser_free حافظه اختاص داده شده به تجزه کننده را آزاد می کند.
    READ MORE
  • تعریف توابع در PHP

    Wiki

    قدرت واقعی PHPدر توابع آن است، در PHP بیش از 1000 تابع از قبل نوشته شده وجود دارد.

    در این فصل به شما نشان خواهیم داد که در PHP چگونه می توانید توابع خودتان را تعریف کنید.

    یک تابع به وسیله صدا زدن آن اجرا خواهد شد، شما می توانید از هر جای صفحه آنرا صدا بزنید.

    نحوه تعریف توابع:

    function functionName()
    {
    code to be executed;
    }

    توجه:برای نامگذاری توابع موارد زیر را در نظر داشته باشید:

    • اسامی توابع به نحوی انتخاب شوند که نام انتخاب شده معرفی کننده عملی باشد که تابع انجام می دهد
    • نام تابع می تواند با حروف و یا علامت "_" شروع شود(با عدد نمی تواند شروع شود).

    مثال: یک تابع ساده که با صدا زدن آن نام من چاپ می شود:

    <html>
    <body>

    <?php
    function writeName()
    {
    echo "pahlavan sadegh";
    }

    echo "My name is ";
    writeName();
    ?>

    </body>
    </html>

    خروجی کد بالا:

    My name is pahlavan sadegh


    ارسال پارامتر به توابع

    Wiki

    یک پارامتر چیزی شبیه یک متغیر است، پارامترها بعد از نام تابع داخل پرانتز تعریف می شوند.

    مثال1: در مثال زیر با ارسال نام شخص به تابع، بعد از صدا زدن تابع، نام های مختلف با فامیلی یکسان چاپ می شود.

    <html>
    <body>

    <?php
    function writeName($fname)
    {
    echo $fname . " Ahmadi.<br />";
    }

    echo "My name is ";
    writeName("Ali");
    echo "My sister's name is ";
    writeName("Sara");
    echo "My brother's name is ";
    writeName("Amir");
    ?>

    </body>
    </html>

    خروجی کد بالا:

    My name is Ali Ahmadi.
    My sister's name is Sara Ahmadi.
    My brother's name is Amir Ahmadi.

    مثال2: تابع زیر دو پارامتر دارد.

    <html>
    <body>

    <?php
    function addNumbers($a , $b)
    {
    $sum = $a + $b;
    echo $sum;
    }

    addNumbers(100,200);
    ؟>

    </body>
    </html>

     خروجی کد بالا:

    300

    نکته: به صورت پیش فرض پارامترهایی که به توابع ارسال می شوند، طوری هستند که در صورتی که در تابع تغییر کنند مقدار اصلی آنها تغییری نخواهد کرد و به همان صورت باقی خواهند ماند، اما اگر در تعریف تابع قبل از اسم متغیر از علامت "&" استفاده کنیم، این ویژگی تغییر می کند یعنی با تغییر یک متغیر در درون تابع، اصل متغیر هم تغییر خواهد نمود، به مثال زیر توجه کنید.

    مثال:

    <html>
    <body>

    <?php
    function changeit(&$string)
    {
    echo "String is: " . $string . '<br />';
    $string="Learning PHP";
    echo "String Changed to: " . $string . '<br />';
    }

    $str="PLUS";
    changeit($str);
    echo $str;

    ?>

    </body>
    </html>

    خروجی کد بالا:

    String is: PLUS
    String Changed to: Learning PHP
    Learning PHP


     بازگرداندن یک مقدار توسط توابع

    Wiki

    شما می توانید از دستور return برای بازگرداندن یک مقدار استفاده کنید، یعنی کافی است نتیجه را جلوی دستور return قرار دهید.

    مثال:

    <html>
    <body>

    <?php
    function add($x,$y)
    {
    $total=$x+$y;
    return $total;
    }

    echo "1 + 16 = " . add(1,16);
    ?>

    </body>
    </html>

    خروجی کد بالا:

    1 + 16 = 17


    توابع از پیش تعریف شده:

    Wiki

    در php بیش از 5300 تابع از پیش تعریف شده وجود دارد که البته برای اجرای آنها ممکن است در ورژن های مختلف برخی توابع وجود نداشته باشند و یا برای اجرای بعضی توابع احتیاج باشد تا extension خاصی نصب باشد.
    توابع از پیش تعریف شده همانند توابعی که کاربر تعریف می کند اجرا می شوند.

    READ MORE
  • ثابت ها مانند متغیرها هستند با این تفاوت که یکبار آنها را تعریف می کنید و دیگر نمی توانید آنها را تغییر دهید.


    ثابت ها (Constant) در PHP

    Wiki

    یک ثابت، در واقع یک شناسه یا یک نام برای یک مقدار ساده است. در طول اسکریبت، مقدار ثابت نمی تواند تغییر نماید.

    نام یک ثابت باید با یک حرف یا یک "_" آغاز شود. به علامت $ قبل از نام ثابت نیازی نیست.

    توجه: برخلاف متغیرها، یک ثابت بطور اتوماتیک در طول تمام اسکریبت عمومی است.


    تنظیم یک ثابت در PHP

    Wiki

    با استفاده از تابع ()define، می توانید یک ثابت را تنظیم نمایید. این تابع سه پارامتر می گیرد: پارامتر اول، نام ثابت را تعیین می کند، پارامتر دوم، مقدار ثابت و پارامتر اختیاری سوم، تعیین می کند که آیا نام ثابت به حروف بزرگ و کوچک حساس است یا خیر.  (مقدار پیشفرض false است به این معنی که نسبت به حروف کوچک و بزرگ حساس است)

    در مثال زیر، یک ثابت با نام GREETING و مقدار "!Welcome to Beyamooz.com" تعریف شده است:

    مثال (ثابت ها در PHP)

    <?php
    define("GREETING", "Welcome to Beyamooz.com!");
    echo GREETING;
    ?>

    خروجی کد بالا:

    Welcome to Beyamooz.com!

    در مثال زیر، نام ثابت به حروف بزرگ و کوچک حساس نیست (greeting و GREETING یکسان است):

    مثال (ثابت ها در PHP)

    <?php
    define("GREETING", "Welcome to Beyamooz.com!", true);
    echo greeting;
    echo GREETING;
    ?>

    خروجی کد بالا:

    Welcome to Beyamooz.com!
    Welcome to Beyamooz.com!
    READ MORE
  • جملات شرطی

    Wiki

    اغلب اوقات هنگام نوشتن یک اسکریپت، شما نیاز دارید که تصمیم های متفاوتی در مقابل نتایج مختلف بگیرید، برای تحقق این موضوع از جملات شرطی استفاده می کنیم.

    انواع جملات شرطی در PHP:

    1. ... if:هنگامی که شرط درست باشد، دستور مقابل if اجرا می شود.
    2. if... else: اگر شرط درست باشد دستور مقابل if وگرنه دستور مقابل else اجرا می شود.
    3. if... elseif... else: برای اجرای یک دستور از بین چند دستور کاربرد دارد.
    4. PHP Switch: برای انتخاب و اجرای یک دستور از بین چند دستور استفاده می شود.

     دستور if

    Wiki

    نحوه استفاده:

    if (Condition)
    {
    Statement 1
    Statement 2
    ...
    }

    دستور(Statement) مورد نظر تنها موقعی اجرا می شود که شرط(Condition) برقرار باشد، یعنی مقدار آن برابر true باشد.

    مثال: در کد PHP زیر اگر امروز جمعه باشد، جمله "Have a nice weekend" چاپ می شود.

    <html>
    <body>

    <?php
    $d=date("D");
    if ($d=="Fri") echo "Have a nice weekend!";
    ?>

    </body>
    </html>


    دستور if...else

    Wiki

     این دستور که در واقع می تواند کامل کننده if باشد، تعیین می کند که اگر شرط درست نبود چه دستوری اجرا شود.

    نحوه استفاده:

    if (condition)
      code to be executed if condition is true;
    else
      code to be executed if condition is false;

    مثال: در مثال زیر اگر امروز جمعه باشد جمله "Have a nice weekend" چاپ می شود وگرنه جمله "Have a nice day" چاپ خواهد شد.

    <html>
    <body>

    <?php
    $d=date("D");
    if ($d=="Fri")
      echo "Have a nice weekend!";
    else
      echo "Have a nice day!";
    ?>

    </body>
    </html>


    دستور if...elseif....else

    Wiki

    همان طور که در بالا گفته شد این نوع if برای اجرای یک دستور از بین چند دستور کاربرد دارد.

    نحوه استفاده:

    if (condition)
      code to be executed if condition is true;
    elseif (condition)
      code to be executed if condition is true;
    else
      code to be executed if condition is false;

     مثال:در مثال زیر اگر امروز جمعه باشد جمله "Have a nice weekend" چاپ می شود و اگر یکشنبه بود جمله "Have a nice Sunday" چاپ می شود وگرنه جمله "Have a nice day" چاپ خواهد شد.

    <html>
    <body>

    <?php
    $d=date("D");
    if ($d=="Fri")
      echo "Have a nice weekend!";
    elseif ($d=="Sun")
      echo "Have a nice Sunday!";
    else
      echo "Have a nice day!";
    ?>

    </body>
    </html>


      توجه: نوع دیگر اجرای دستورات کنترلی(مثال):

    if ($i == 1):
        echo "i is 1";
        $i+=2;
    elseif ($i == 2):
        echo "i is 2";
        $i+=3;
    else:
        echo "is not 1 or 2";
        $i-=1;
    endif;

    READ MORE
  • حذف اطلاعات یک جدول با استفاده از MySQLi و PDO

    Wiki

    دستور DELETE FROM برای حذف رکورد از یک جدول استفاده می شود.

    نحوه استفاده:

    DELETE FROM table_name
    WHERE some_column = some_value

    نکته: قسمت WHERE مشخص می کند که چه رکورد یا رکوردهایی باید حذف بشوند، توجه داشته باشید که اگر این قسمت را در نظر نگیرید کلیه رکوردهای جدول حذف می شوند.

    برای کسب اطلاعات بیشتر در مورد SQL، به لینک روبرو مراجعه فرمایید: آموزش SQL-مقدمه

    به جدول "MyGuests" که در فصل های قبلی همین آموزش ایجاد شده است توجه کنید:

    id firstname lastname email reg_date
    1 John Doe این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید 2014-10-22 14:26:15
    2 Mary Moe این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید 2014-10-23 10:22:30
    3 Julie Dooley این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید 2014-10-26 10:48:23

    در مثال زیر، رکوردی که id آن برابر با 3 است در جدول "MyGuests" حذف خواهد شد:

    مثال(MySQLi Object-oriented)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // ایجاد ارتباط
    $conn = new mysqli($servername, $username, $password, $dbname);
    // اطمینان از صحت ارتباط
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    }

    // تنظیم کوئری حذف
    $sql = "DELETE FROM MyGuests WHERE id=3";

    if ($conn->query($sql) === TRUE) {
        echo "Record deleted successfully";
    } else {
        echo "Error deleting record: " . $conn->error;
    }

    $conn->close();
    ?>

    مثال(MySQLi Procedural)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // ایجاد ارتباط
    $conn = mysqli_connect($servername, $username, $password, $dbname);
    // اطمینان از صحت ارتباط
    if (!$conn) {
        die("Connection failed: " . mysqli_connect_error());
    }

    // تنظیم کوئری حذف
    $sql = "DELETE FROM MyGuests WHERE id=3";

    if (mysqli_query($conn, $sql)) {
        echo "Record deleted successfully";
    } else {
        echo "Error deleting record: " . mysqli_error($conn);
    }

    mysqli_close($conn);
    ?>

    مثال(PDO)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDBPDO";

    try {
        $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
        // تنظیم حالت برخورد با خطاها
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

        // تنظیم کوئری حذف
        $sql = "DELETE FROM MyGuests WHERE id=3";

        // بدلیل اینکه کوئری نتیجه ای را برنمی گرداند از تابع زیر استفاده می کنیم
        $conn->exec($sql);
        echo "Record deleted successfully";
        }
    catch(PDOException $e)
        {
        echo $sql . "<br>" . $e->getMessage();
        }

    $conn = null;
    ?>

    نتیجه کار بعد از حذف رکورد:

    id firstname lastname email reg_date
    1 John Doe این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید 2014-10-22 14:26:15
    2 Mary Moe این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید 2014-10-23 10:22:30
    READ MORE
  • جلسه ی هشتم طراحی یک فروشگاه اینترنتی-حذف محصول از سبد خرید

    در قسمت اول از این جلسه، به آموزش 'حذف محصول از سبد خرید' خواهیم پرداخت.


    آنچه که در قسمت قبل طراحی شد

    در قسمت قبل، موارد کلی زیر آموزش داده شدند:

    1. ایجاد قسمت های قیمت کل و ورود به درگاه پرداخت در سبد خرید

    مشاهده ی آنچه که در قسمت قبل طراحی شد:

     


    آنچه که در قسمت 'حذف محصول از سبد خرید' خواهید آموخت

    در قسمت 'حذف محصول از سبد خرید' موارد زیر آموزش داده خواهند شد:

    توضیح اجمالی:

    1. نحوه ی حذف محصول از سبد خرید با استفاده از جی کوئری

    توضیح تفصیلی:

    1.  انجام کدنویسی جی کوئری برای دکمه ی حذف محصول از سبد خرید.
    2. استفاده از ajax برای حذف محصول.
    3. حذف li مورد نظر از سبد خرید به صورت آنی
    4. تعریف id یا کلاس برای دکمه های ضربدری شکل.

    حذف محصول از سبد خرید

     چون که قرار است ما، دستورات جی کوئری و ajax را زمانی اجرا کنیم که کاربر روی این ضربدر های قرمز کلیک می کند، پس بهتر است که به این ضربدرها، یک آی دی و یا کلاس خاص بدهیم، تا بتوانیم در دستورات جی کوئری به سادگی به این علامت های ضربدر دسترسی داشته باشیم:

     یعنی در جایی که در فایل top.php آمدیم و محصولاتمان را از tblsabad دریافت کردیم، و سپس یک li را echo کردیم که در داخل این li علامت ضربدر هم وجود داشت، یک آی دی را تحت عنوان delete مشخص کنیم:

     پس id این ضربدر های قرمز برابر با delete شد. حالا اگر که صفحه را رفرش کنیم، و کلید f12 را فشار دهیم، می بینیم که id این ضربدر ها، delete می باشد. این آی دی باعث می شود که ما کدهای جی کوئری مان را بتوانیم راحت تر بنویسیم.

    حالا به سراغ صفحه ی left.php می رویم. درون این قسمت که ما تگ اسکریپت را باز کردیم و دستورات قبلی را نوشتیم، حال می آییم و یک دستور جدید را هم اجرا می کنیم. حال می خواهیم ببینیم که سلکتور ما در اینجا، چه چیزی است. یعنی در چه زمانی می خواهیم عملیات delete برای محصول را انجام بدهیم؟ مشخص است که زمانی می خواهیم این کار را انجام دهیم که کاربر روی دکمه ی delete کلیک می کند. پس در اینجا ما سلکتور خودمان را مشخص می کنیم:

    کد

    $("#sabad1 li #delete").click

    این می شود همان سلکتور ما. زمانی که کاربر بر روی این سلکتور کلیک می کند، یک تابع باید اجرا شود:


    دسترسی به موارد آموزشی بالا در بسته ی خریداری شده:

    • شماره جلسه: 8
    • نام فایل ویدئو: 31
    • فرمت فایل: mp4.

    نقطه ی شروع بحث بالا (حذف محصول از سبد خرید) در ویدئو: 03:08

    READ MORE
  • در این آموزش نحوه ی جلوگیری از خالی شدن فیلدهای فرم، زمانی که کاربر روی دکمه submit کلیک می کند را نشان خواهیم داد.


    حفظ مقادیر فرم در PHP

    Wiki

    زمانی که کاربر، مقادیر فیلدهای فرم را تنظیم و روی دکمه submit کلیک می کند، تمام فیلدها، مقادیرشان را از دست می دهند. حالا تصور نمایید که کاربر، در ورود اطلاعات یک فیلد (مثلاً فیلد "ایمیل") خطایی داشته باشد، بنابراین باید از ابتدا شروع به وارد کردن اطلاعات کند...!

    بمنظور حفظ مقادیر فیلدهای فرم، برای فیلدهای متنی، باید یک کد PHP کوچک در خصوصیت value تگ <input> قرار دهیم. همچنین برای عنصر <textarea> باید کد PHP را بین تگ های باز و بسته <textarea> و </textarea> قرار دهیم. این قطعه کدها، مقادیر متغیرهای name, $email, $website, $comment$ را نمایش می دهند.

    سپس، در مورد فیلد "جنسیت" باید مشخص کنیم که کدام گزینه انتخاب شده است. بنابراین باید خصوصیت ckecked آنرا دستکاری کنیم (نه خصوصیت value):

    نام: <input type="text" name="name" value="<?php echo $name;?>">

    ایمیل: <input type="text" name="email" value="<?php echo $email;?>">

    وب سایت: <input type="text" name="website" value="<?php echo $website;?>">

    توضیحات: <textarea name="comment" rows="5" cols="40"><?php echo $comment;?></textarea>

    جنسیت:
    <input type="radio" name="gender"
    <?php if (isset($gender) && $gender=="female") echo "checked";?>
    value="female">زن
    <input type="radio" name="gender"
    <?php if (isset($gender) && $gender=="male") echo "checked";?>
    value="male">مرد

    مثال تکمیل شده اعتبارسنجی فرم در PHP

    Wiki

    در زیر، کد تکمیل شده اعتبارسنجی فرم در PHP آمده است:

    مثال (حفظ مقادیر فرم در PHP)

     <!DOCTYPE HTML>
    <html>
    <head>
    <style>
       body {direction:rtl;}
      .error {color: #FF0000;}
    </style>
    </head>
    <body>

    <?php
    // define variables and set to empty values
    $nameErr = $emailErr = $genderErr = $websiteErr = "";
    $name = $email = $gender = $comment = $website = "";

    if ($_SERVER["REQUEST_METHOD"] == "POST")
    {
       if (empty($_POST["name"]))
         {$nameErr = "Name is required";}
       else
         {
         $name = test_input($_POST["name"]);
         // check if name only contains letters and whitespace
         if (!preg_match("/^[a-zA-Z ]*$/",$name))
           {
           $nameErr = "Only letters and white space allowed";
           }
         }
      
       if (empty($_POST["email"]))
         {$emailErr = "Email is required";}
       else
         {
         $email = test_input($_POST["email"]);
         // check if e-mail address syntax is valid
         if (!preg_match("/([\w\-]+\@[\w\-]+\.[\w\-]+)/",$email))
           {
           $emailErr = "Invalid email format";
           }
         }
        
       if (empty($_POST["website"]))
         {$website = "";}
       else
         {
         $website = test_input($_POST["website"]);
         // check if URL address syntax is valid (this regular expression also allows dashes in the URL)
         if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%=~_|]/i",$website))
           {
           $websiteErr = "Invalid URL";
           }
         }

       if (empty($_POST["comment"]))
         {$comment = "";}
       else
         {$comment = test_input($_POST["comment"]);}

       if (empty($_POST["gender"]))
         {$genderErr = "Gender is required";}
       else
         {$gender = test_input($_POST["gender"]);}
    }

    function test_input($data)
    {
         $data = trim($data);
         $data = stripslashes($data);
         $data = htmlspecialchars($data);
         return $data;
    }
    ?>

    <h2>مثال اعتبارسنجی فرم ها در PHP</h2>
    <form method="post" action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>">
    <div>
      <span>نام:</span><input type="text" name="name" value="<?php echo $name;?>">
      <span class="error">*</span>
    </div>
    <div>
      <span>ایمیل:</span>
    <input type="text" name="email" value="<?php echo $email;?>">
      <span class="error">*</span>
    </div>
    <div>
      <span>وب سایت:</span>
     
    <input type="text" name="website" value="<?php echo $website;?>">
      <span class="error"></span>
    </div>
    <div>
      <span>توضیحات:</span>
    <textarea name="comment" rows="5" cols="40">
                              <?php echo $comment;?>
                           </textarea>
      <span class="error">*</span>
    </div>
    <div>
    <span>جنسیت:</span>

    <input type="radio" name="gender" value="female" <?php if (isset($gender) && $gender=="female") echo "checked";?>>زن
    <input type="radio" name="gender" value="male" <?php if (isset($gender) && $gender=="male") echo "checked";?>>مرد
    </div>
    </div><input type="submit" name="submit" value="ارسال اطلاعات"></div>
    </form>

    <?php
    if ($nameErr!="" || $emailErr!="" || $genderErr!="" || $websiteErr!="")
    echo "<span style='color:red' >
             $nameErr <br /> $emailErr <br /> $genderErr <br /> $websiteErr
          </span>";
    else
    {
    echo "<br /><h2>خروجی کدتان</h2>";
    echo "نام :$name";
    echo "<br />";
    echo "ایمیل: $email";
    echo "<br />";
    echo "وب سایت: $website";
    echo "<br />";
    echo "توضیحات: $comment";
    echo "<br />";
    echo "جنسیت: $gender";
    }
    ?>

    </body>
    </html>

    خروجی کد بالا:

    مثال اعتبارسنجی فرم ها در PHP

    نام:*
    ایمیل:*
    وب سایت:
    توضیحات:
    جنسیت: زن مرد*
     
    READ MORE
  • حلقه for در PHP

    Wiki

    از حلقه for زمانی که تعداد دفعات اجرای دستورات را بدانید استفاده می شود یعنی دستورات داخل حلقه از یک عدد مشخص به تعدادی مشخص تکرار می شود.

    نحوه استفاده:

    for (init; condition; increment)
      {
      code to be executed;
      }

    پارامترها:

    • init: تنها یکبار در ابتدای حلقه اجرا می شود، و اغلب برای تعریف یک شمارنده استفاده می شود.
    • condition: ارزیابی تکرار حلقه، اگر شرط برقرار باشد دستورات اجرا می شوند، در غیر اینصورت دستورات ادامه نمی یابند.
    •  incrementبعد از هربار اجرای دستورات حلقه، این دستور اجرا می شود و اغلب برای افزایش شمارنده استفاده می شود.

    نکته:

    1. در for می توان هرکدام از پارامترهای بالا را خالی گذاشت، به این صورت که اگر شرط خالی باشد، مقدار آن برابر با true در نظر گرفته می شود و حلقه بینهایت بار اجرا میشود! (البته با استفاده از دستور break که بعداً به آن اشاره می شود، می توان آن را قطع نمود)
    2. در for همچنین می توان برای پارامترهای بالا چند دستور مختلف را اجرا نمود به اینصورت که با علامت "," آنها را باید از یکدیگر جدا نمود.

    مثال:

    در مثال زیر یک حلقه تعریف شده که با i=1 شروع می شود، و تا زمانی که i<=5 باشد ادامه خواهد یافت و به مقدار i در هر بار اجرای حلقه یک واحد اضافه می شود.

    <html>
    <body>

    <?php
    for ($i=1; $i<=5; $i++)
      {
      echo "The number is " . $i . "<br />";
      }
    ?>

    </body>
    </html>

    خروجی کد بالا:

    The number is 1
    The number is 2
    The number is 3
    The number is 4
    The number is 5


    حلقه foreach درPHP

    Wiki

    مخصوص کار با آرایه ها می باشد.

    نحوه استفاده:

    foreach ($arrayas $value)
      {
      code to be executed;
      }

    این دستور تمام مقادیر آرایه را یکی یکی از ابتدایی تا انتهایی به درون value می ریزد و دستورات را اجرا می نماید.

    نکته:مقدار value کپی داده می باشد و با تغییر آن داده اصلی در آرایه تغییری نمی کند، اما با قرار دادن علامت "&" در ابتدای value یک نشانگر از آن برگردانده می شود، بدین معنا که با تغییر آن داده اصلی درون آرایه نیز تغییر می کند.

    مثال1:مثال زیر یک حلقه را نشان می دهد که مقادیر گرفته شده از یک آرایه را چاپ می کند.

    <html>
    <body>

    <?php
    $x=array("one","two","three");
    foreach ($x as $value)
      {
      echo $value . "<br />";
      }
    ?>

    </body>
    </html>

    خروجی کد بالا:

    one
    two
    three

    مثال2: با قرار دادن علامت "&" در ابتدای value اگر در حلقه این مقدار تغییر کند، داده اصلی نیز تغییر می کند.

    <html>
    <body>

    <?php
    $arr=array(1,2,3,4);
    foreach($arr as &$value)
    {
      echo $value;
      echo " ";
      $value *= 2;
    }
    echo "<br />";
    foreach($arr as $value)
    {
      echo $value;
      echo " ";
    }
    ?>

    </body>
    </html>

    خروجی کد بالا:

    1 2 3 4
    2 4 6 6

    مثال3: چاپ کلید و مقدار آن (key and value)

    <html>
    <body>

    <?php
    $a = array(
        "one" => 1,
        "two" => 2,
        "three" => 3,
        "seventeen" => 17
    );

    foreach ($a as $k => $v) {
        echo "a[$k] => $v"."<br />";
    }
     
    ?>

    </body>
    </html>

    خروجی کد بالا:

    a[one] => 1
    a[two] => 2
    a[three] => 3
    a[seventeen] => 17

    مثال4: چاپ کلید و مقدار آن (key and value) در یک آرایه دو بعدی

    <html>
    <body>

    $families = array("Ahmadi"=>array("a"=>"Ali","b"=>"Reza","c"=>"Sara"),
                      "Naderi"=>array("a"=>"Amir"),
                      "Mohamadi"=>array("a"=>"Poya","b"=>"Parniya")
                     );
    foreach ($families as $k => $v)
        foreach ($v as $b=>$v)
        echo "families[$k][$b] => $v "."<br />";

    </body>
    </html>

    خروجی کد بالا:

    families[Ahmadi][a] => Ali
    families[Ahmadi][b] => Reza
    families[Ahmadi][c] => Sara
    families[Naderi][a] => Amir
    families[Mohamadi][a] => Poya
    families[Mohamadi][b] => Parniya

    READ MORE
  • حلقه ها در PHP

    Wiki

     اغلب مواقعی که کد می نویسیم، می خواهیم که یک مجموعه از دستورات بارها و بارها اجرا بشوند، بجای اینکه آن چند خط که اغلب یکسان هستند را در دستورات تکرار کنیم از حلقه ها استفاده می کنیم.

    انواع دستورات حلقه ای در PHP:

    • while:تا زمانی که شرط حلقه درست باشد، دستورات اجرا می شود.
    • do...while:دستورات داخل حلقه چه شرط حلقه درست باشد و چه نباشد برای یک بار اجرا می شود، و در مراحل بعدی اگر شرط حلقه درست بود، دستورات اجرا می شوند.
    • for:دستورات داخل حلقه از یک عدد مشخص به تعدادی مشخص تکرار می شود.
    • foreach:برای کار با آرایه ها کاربرد دارد.

    حلقه while

    Wiki

    این دستور تا زمانی که شرط برقرار باشد دستورات را اجرا می کند و شرط قبل از اجرای دستورات چک می شود. بدین معنا که اگر در وسط اجرای دستورات متغیرها طوری تغییر کنند که شرط برقرار نباشد، دستورات همچنان تا پایان اجرا می شوند و نیز اگر شرط از ابتدا برقرار نباشد دستورات دیگر اجرا نخواهند شد.

    نحوه استفاده:

    while (condition)
      {
      code to be executed;
      }

    مثال:

    در مثال زیر یک حلقه تعریف کرده ایم که با i=0 شروع می شود و دستورات داخل حلقه تا زمانی که i<=5 باشد ادامه می یابد، البته توجه داشته باشید که مقدار متغیر i در داخل حلقه هر بار یک واحد اضافه می شود و اگر این تغییر، شرط حلقه را false کند، دستورات داخل حلقه تا پایان حلقه ادامه خواهد یافت.

    <html>
    <body>

    <?php
    $i=1;
    while($i<=5)
      {
      echo "The number is " . $i . "<br />";
      $i++;
      }
    ?>

    </body>
    </html>

    خروجی کد بالا:

    The number is 1
    The number is 2
    The number is 3
    The number is 4
    The number is 5


    دستور do...while

    Wiki

    این دستور شباهت بسیار زیادی به دستور while دارد با این تفاوت که شرط در پایان اجرای دستورات چک می شود یعنی به این صورت که اگر از ابتدا هم شرط برقرار نباشد، دستورات یکبار اجرا می شوند و بعد شرط چک می شود.

    نحوه استفاده:

    do
      {
      code to be executed;
     
    }
    while (condition);

    مثال:

    تفاوت این مثال با مثال قبلی در دو چیز است:

    1. چون شرط حلقه در پایان دستورات چک می شود، دستورات داخل حلقه حتماً برای یک بار اجرا می شوند.
    2. چون دستور ;++i$ قبل از دستور چاپ است، بنابراین اعداد از 2 تا 6 چاپ می شود.

    <html>
    <body>

    <?php
    $i=1;
    do
      {
      $i++;
      echo "The number is " . $i . "<br />";
      }
    while ($i<=5);
    ?>

    </body>
    </html>

    خروجی کد بالا:

    The number is 2
    The number is 3
    The number is 4
    The number is 5
    The number is 6

    حلقه for و foreach در فصل بعدی توضیح داده خواهد شد.

    READ MORE
  • درج کردن اطلاعات در MySQL با استفاده از MySQLi و PDO

    Wiki

    بعد از اینکه پایگاه داده و جداول را ایجاد کردیم، حالا نوبت به درج اطلاعات می رسد.

    دستور INSERT INTO برای درج کردن یک رکورد جدید در جدول استفاده می شود.

    در اینجا چند قانون ساختاری وجود دارد که باید پیروی کنید:

    • کوئری های SQL در PHP باید با علامت کوتیشن محصور شوند.
    • مقادیر رشته ای استفاده شده در کوئری ها باید با علامت کوتیشن محصور شوند.
    • اعداد را نباید با کوتیشن محصور کنید.
    • کلمه NULL نباید با کوتیشن محصور شود.

    به دو صورت می توان از دستور INSERT INTO استفاده کرد:

    1- در این روش نیازی نیست که نام ستونها ذکر شود:

    INSERT INTO table_name
    VALUES (value1, value2, value3,...)

    2- در این روش باید نام ستون ها و مقادیر متناظرشان ذکر شود:

    INSERT INTO table_name (column1, column2, column3,...)
    VALUES (value1, value2, value3,...)

    برای کسب اطلاعات بیشتر در مورد SQL، به لینک روبرو مراجعه فرمایید: آموزش SQL-مقدمه

    در مطلب قبل، یک جدول با نام "MyGuests" با 5 فیلد "id" و "firstname" و "lastname" و "email" و "reg_date" ایجاد کردیم، حالا اجازه دهید تا جدول را با اطلاعات پر کنیم.

    Note توجه: اگر هنگام تعریف جدول، برای یک ستون، گزینه AUTO_INCREMENT را تنظیم کرده باشیم (مانند فیلد id) و یا فیلد مورد نظر از نوع TIMESTAMP باشد (مانند فیلد reg_date) هنگام درج اطلاعات نیازی به مشخص کردن مقدار نیست و MySQL بصورت اتوماتیک آنها را پر خواهد کرد.

    مثال های زیر یک رکورد جدید به جدول "MyGuests" اضافه خواهند کرد:

    مثال (MySQLi Object-oriented)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // Create connection
    $conn = new mysqli($servername, $username, $password, $dbname);
    // Check connection
    if ($conn->connect_error) {
        die("Connection failed: " . $conn->connect_error);
    }

    $sql = "INSERT INTO MyGuests (firstname, lastname, email)
    VALUES ('John', 'Doe', این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید')";

    if ($conn->query($sql) === TRUE) {
        echo "New record created successfully";
    } else {
        echo "Error: " . $sql . "<br>" . $conn->error;
    }

    $conn->close();
    ?>

    مثال(MySQLi Procedural)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // Create connection
    $conn = mysqli_connect($servername, $username, $password, $dbname);
    // Check connection
    if (!$conn) {
        die("Connection failed: " . mysqli_connect_error());
    }

    $sql = "INSERT INTO MyGuests (firstname, lastname, email)
    VALUES ('John', 'Doe', این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید')";

    if (mysqli_query($conn, $sql)) {
        echo "New record created successfully";
    } else {
        echo "Error: " . $sql . "<br>" . mysqli_error($conn);
    }

    mysqli_close($conn);
    ?>

     توجه: همانطور که قبلاً گفته شد در روش MySQLi Procedural برای اجرای کوئری ها، باید از تابع ()mysqli_query استفاده کرد، این تابع توسط Connectionی که برقرار شده برای ارسال کوئری به MySQL استفاده می شود.

    مثال(PDO)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDBPDO";

    try {
        $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
        // set the PDO error mode to exception
        $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        $sql = "INSERT INTO MyGuests (firstname, lastname, email)
        VALUES ('John', 'Doe', این آدرس ایمیل توسط spambots حفاظت می شود. برای دیدن شما نیاز به جاوا اسکریپت دارید')";
        // use exec() because no results are returned
        $conn->exec($sql);
        echo "New record created successfully";
        }
    catch(PDOException $e)
        {
        echo $sql . "<br>" . $e->getMessage();
        }

    $conn = null;
    ?>
    READ MORE
  • انتخاب داده ها از پایگاه داده MySQL

    Wiki

    دستور SELECT برای انتخاب داده از یک جدول استفاده می شود.

    نحوه استفاده:

    می توانیم با استفاده از نام ستون ها، تعداد محدودی از ستون های یک جدول را انتخاب کنیم:

    SELECT column_name(s) FROM table_name

    یا می توانیم با استفاده از کاراکتر *، تمام ستون های یک جدول را انتخاب کنیم:

    SELECT * FROM table_name

    برای کسب اطلاعات بیشتر در مورد SQL، به لینک روبرو مراجعه فرمایید: آموزش SQL-مقدمه


    انتخاب داده ها با استفاده از MySQLi

    Wiki

    در مثال زیر، ستون های id و firstname و lastname از جدول MyGuests در صفحه نمایش داده خواهند شد:

    مثال(MySQLi Object-oriented)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // ارتباط به پایگاه داده
    $conn = new mysqli($servername, $username, $password, $dbname);
    // مطمئن شدن از صحت ارتباط
    if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
    }
    //تنظیم کوئری
    $sql = "SELECT id, firstname, lastname FROM MyGuests";
    //اجرای کوئری و قرار دادن نتیجه در متغیر
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
    // نمایش داده ها به ازای هر ردیف
    while($row = $result->fetch_assoc()) {
    echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>";
    }
    } else {
    echo "0 results";
    }
    //بستن ارتباط با پایگاه داده
    $conn->close();
    ?>

    خروجی کد بالا:

    id: 1 - Name: John Doe
    id: 2 - Name: Mary Moe
    id: 3 - Name: Julie Dooley

    توضیح مثال:

    1. ابتدا یک کوئری SQL را تنظیم کردیم که ستون های id و firstname و lastname از جدول MyGuests را انتخاب می کند. نتیجه اجرای کوئری توسط تابع ()query در متغیر result$ ذخیره می شود.
    2. حالا نتیجه کوئری در متغیر result$ است و می خواهیم که آنها را در خروجی نمایش دهیم، اما قبل از آن باید مطمئن شویم که کوئری ما نتیجه ای را در بر داشته است، بنابراین با استفاده از تابع ()num_rows چک می کنیم که ردیف ها بزرگتر از صفر باشد.
    3. با استفاده از تابع ()fetch_assoc ردیف اول داده ها برگردانده می شود، در یک اسکریبت با هر بار فراخوانی این تابع ردیف های بعدی بر می گردد.
    4. با استفاده از حلقه while و با هر بار فراخوانی تابع ()fetch_assoc نتیجه در متغیر row$ ذخیره می شود و این کار تا آخرین رکورد ادامه می یابد و اطلاعات ستون ها چاپ می شود.

    در مثال زیر نیز با استفاده از روش MySQLi procedural ستون های id و firstname و lastname از جدول MyGuests در صفحه نمایش داده خواهند شد:

    مثال(MySQLi Procedural)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // ایجاد ارتباط با پایگاه داده
    $conn = mysqli_connect($servername, $username, $password, $dbname);
    // اطمینان از صحت ارتباط
    if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
    }
    //تنظیم کوئری
    $sql = "SELECT id, firstname, lastname FROM MyGuests";
    $result = mysqli_query($conn, $sql);

    if (mysqli_num_rows($result) > 0) {
    // نمایش داده ها به ازای هر ردیف
    while($row = mysqli_fetch_assoc($result)) {
    echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>";
    }
    } else {
    echo "0 results";
    }

    mysqli_close($conn);
    ?>

    خروجی کد بالا:

    id: 1 - Name: John Doe
    id: 2 - Name: Mary Moe
    id: 3 - Name: Julie Dooley

    همچنین می توانید خروجی را در یک جدول HTML نمایش دهید:

    مثال(MySQLi Object-oriented)

    <?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";

    // ایجاد ارتباط با پایگاه داده
    $conn = new mysqli($servername, $username, $password, $dbname);
    // اطمینان از صحت ارتباط
    if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
    }
    //تنظیم کوئری
    $sql = "SELECT id, firstname, lastname FROM MyGuests";
    $result = $conn->query($sql);

    if ($result->num_rows > 0) {
    echo "<table><tr><th>ID</th><th>Name</th></tr>";
    // نمایش داده ها به ازای هر ردیف
    while($row = $result->fetch_assoc()) {
    echo "<tr><td>".$row["id"]."</td><td>".$row["firstname"]." ".$row["lastname"]."</td></tr>";
    }
    echo "</table>";
    } else {
    echo "0 results";
    }
    $conn->close();
    ?>

    خروجی کد بالا، البته با استایل زیر:

    <style>
    table, th, td {
    border: 1px solid black;
    }
    </style>

    خروجی:

    ID Name
    1 John Doe
    2 Mary Moe
    3 Julie Dooley

    انتخاب داده ها با استفاده از PDO + دستورات آماده

    Wiki

    در مثال زیر، از دستورات آماده (prepared statements) استفاده شده است.

    در مثال زیر نیز با استفاده از روش PDO ستون های id و firstname و lastname از جدول MyGuests در یک جدول HTMLی نمایش داده خواهند شد:

    مثال(PDO)

    <?php
    echo "<table style='border: solid 1px black;'>";
    echo "<tr><th>Id</th><th>Firstname</th><th>Lastname</th></tr>";

    class TableRows extends RecursiveIteratorIterator {
    function __construct($it) {
    parent::__construct($it, self::LEAVES_ONLY);
    }

    function current() {
    return "<td style='width:150px;border:1px solid black;'>" . parent::current(). "</td>";
    }

    function beginChildren() {
    echo "<tr>";
    }

    function endChildren() {
    echo "</tr>" . "\n";
    }
    }

    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDBPDO";

    try {
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $stmt = $conn->prepare("SELECT id, firstname, lastname FROM MyGuests");
    $stmt->execute();

    // set the resulting array to associative
    $result = $stmt->setFetchMode(PDO::FETCH_ASSOC);
    foreach(new TableRows(new RecursiveArrayIterator($stmt->fetchAll())) as $k=>$v) {
    echo $v;
    }
    }
    catch(PDOException $e) {
    echo "Error: " . $e->getMessage();
    }
    $conn = null;
    echo "</table>";
    ?>

    خروجی کد بالا:

    Id Firstname Lastname
    1 John Doe
    2 Mary Moe
    3 Julie Dooley
    READ MORE
تمامی محصولات و خدمات این وبسایت، حسب مورد دارای مجوزهای لازم از مراجع مربوطه می‌باشند و فعالیت‌های این سایت تابع قوانین و مقررات جمهوری اسلامی ایران است.
logo-samandehi مجوز نشر دیجیتال از وزرات فرهنگ و ارشاد اسلامی پرداخت آنلاین -  بانک ملت پرداخت آنلاین - بانک پارسیان پرداخت آنلاین - بانک اقتصاد نوین پرداخت آنلاین - بانک سامان
 
دوره های آموزشی راه اندازی کسب و کارهای اینترنتی
تبلیغات اینترنتی