i
در حال برنامه نویسی و آماده سازی نسخه جدید «وبگو» هستیم، در این نسخه قابلیت ها و ظاهر سایت به کلی متفاوت و کاملتر خواهد بود، این فرآیند زمانبر و از مدتی پیش شروع شده و همچنان ادامه دارد، روند پیشرفت پروژه در این قسمت به صورت درصدی مشخص است و به تناوب به روزرسانی می شود.
نکته:
با توجه به تاریخ نگارش آموزش های سایت و پیشرفت تکنولوژی های مرتبط با وب در سالیان اخیر، محتوای برخی از مطالب قدیمی ممکن است نیاز به ویرایش و به روزرسانی داشته باشند که این کار هم زمان با تهیه نسخه جدید «وبگو» به مرور در حال انجام است، لطفا در استفاده از مطالب سایت به این نکته دقت داشته و حتی المقدور از چند منبع مختلف استفاده نمائید.
article

ارسال و دریافت اطلاعات با متد GET و POST در ای جکس (Ajax)

ajax-asynchronous

به طور کلی ارسال و دریافت اطلاعات در بستر وب با دو متد GET و POST صورت می گیرد که جزئی از استانداردهای تعریف شده پروتکل HTTP هستند و توسط مرورگرها و سرورهای مختلف پشتیبانی می شوند، متد GET معمولا برای ارسال پارامترهای قابل روئیت در آدرس URL درخواستی و دریافت پاسخ از سرور کاربرد دارد، از متد POST نیز به طور معمول در کدنویسی HTML در هنگام کار با فرم ها (تگ form) و ارسال اطلاعات به صورت غیرقابل روئیت استفاده می شود، در ای جکس GET و POST کارکردی مشابه دارند با این تفاوت که در هر دو متد درخواست در پس زمینه ارسال شده و خللی در پیمایش صفحه کاربر ایجاد نمی شود، درک این دو شیوه با توجه به استفاده در بدنه اصلی یک درخواست مبتنی بر ای جکس (Ajax) جهت طی ادامه روند آموزش های این بخش اهمیت زیادی دارد.

متد GET و POST در ای جکس (Ajax)


همانطور که پیش از این گفتیم درخواست های مبتنی بر ای جکس (Ajax) از چند قسمت اصلی تشکیل شده اند (آبجکت XMLHttpRequest، متد open، متد send، متد onreadystatechange و readyState)، آبجکت XMLHttpRequest ساز و کار مورد نیاز را برای ارسال و دریافت اطلاعات بر بستر Ajax فراهم می کند، متد open یک فایل را در سرور با یکی از متدهای GET یا POST فراخوانی کرده و پارامترهای مورد نیاز در قسمت send ارسال می شوند، متد onreadystatechange نیز در کنار متد readyState وضعیت های مختلف را در طی این فرآیند بررسی می کند، با ذکر این ساختار کلی این قسمت از آموزش را به متد open و send اختصاص می دهیم که خود از متدهای GET و POST در پروتکل HTTP استفاده می کنند، به طور خلاصه:
- open و send توابعی در Ajax هستند که برای فراخوانی یک فایل از سرور و ارسال پارامتر به آن از آنها استفاده می کنیم (این توابع را در اصطلاح برنامه نویسی شی گراء، متد می گویند).
- متد open برای فراخوانی فایل از سرور از یکی از شیوه های تعریف شده در پروتکل HTTP استفاده می کند، در پروتکل HTTP دو متد GET و POST برای ارسال و دریافت اطلاعات بین کاربر (Client) و سرور (Server) تعریف شده که جزء استانداردهای این پروتکل هستند.

پارامترهای متد open و send در ای جکس (Ajax)


هر درخواست مبتنی بر ای جکس (Ajax) در نهایت باید یک فایل را از سرور فراخوانی کند، این فراخوانی می تواند با ارسال مقادیر یا بدون ارسال مقادیر باشد، ای جکس برای این نیاز از دو متد open و send استفاده می کند که درخواست ها با این دو متد از طریق استاندارد HTTP و متدهای GET و POST در این استاندارد ارسال و نتیجه دریافت می شود، در نمونه کدهای زیر بخش مربوط به متد open و send از یک درخواست مبتنی بر ای جکس را بررسی می کنیم:
xmlHttp.open("GET", "index.php?action=add&id=22", true);
xmlHttp.send(null);

var params = "action=add&id=22";
xmlHttp.open("POST", "index.php", true);
xmlHttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xmlHttp.send(params);
همان طور که در نمونه کدهای بالا مشخص است، زمانی که متد GET در قسمت open استفاده می شود، پارامترها از طریق آدرس URL به سرور ارسال می شوند و قسمت send مقدار null یا خالی دارد، اما در حالت استفاده از POST باید تنظیماتی اعمال شود که از جمله استفاده از متد setRequestHeader است، این متد در ای جکس برای تنظیم سربرگ (Header) های HTTP در یک درخواست استفاده می شود، در مثال بالا نیز سربرگ Content-type با مقادیر application/x-www-form-urlencoded تنظیم شده است، این دستور به مرورگر تفهیم می کند که اطلاعات را مانند یک فرم ساده HTML ارسال کند، پارامترها در حالت استفاده از متد POST، هم می توانند از طریق آدرس URL (مشابه متد GET) و هم در بخش send ارسال شوند که هر کدام برای شرایط خاصی مناسب هستند که در ادامه در این رابطه بیشتر خواهیم گفت، پارامتر سوم متد open نیز برای تعیین غیر همزمانی (هم روند یا Asynchronous) بودن یا نبودن درخواست است، در صورتی که این مقدار true باشد در پیمایش صفحه کاربر خللی ایجاد نمی شود اما اگر این مقدار را false تنظیم کنیم، تا زمانی که فرآیند درخواست ای جکس به پایان نرسیده، کاربر نمی تواند در صفحه پیمایش کند.

GET یا POST، کدام متد را استفاده کنیم؟!


GET و POST هر کدام با هدف خاصی در HTTP تعریف شده اند، متد GET برای ارسال پارامترها در آدرس URL به کار می رود و از POST برای ارسال بسته های اطلاعات به صورت غیر قابل روئیت استفاده می شود.
کجا از GET استفاده کنیم؟
- متد GET معمولا برای ارسال پارامترهای دستوری در آدرس URL استفاده می شود، به طور مثال می توانیم شماره ID کاربر یا کلمه جستجو شده را در این متد ارسال کنیم.
- در صورتی که اطلاعات ارسال شده حالت عمومی داشته باشند استفاده از GET مانعی ندارد، به طور مثال ارسال اطلاعات حساس مانند رمز عبور از این طریق توصیه نمی شود چرا که در آدرس URL و به صورت آشکار قابل روئیت خواهد بود.
- در مواردی که نیاز به ذخیره سازی موقت (Cache) اطلاعات باشد GET گزینه مناسبی است (البته این حالت را می توان با برنامه نویسی جاوا اسکریپت به نحو دلخواه تغییر داد).
- متد GET در ای جکس سریعتر از متد POST است و برای موارد عمومی که صرفا نیاز به فراخوانی یک فایل از سرور با Ajax است، گزینه مناسبی است، متد POST در ای جکس به صورت دو مرحله ای عمل می کند (ابتدا سربرگ های HTTP و سپس اطلاعات ارسال می شوند).
جهت آشنایی بیشتر در مثال زیر اطلاعات فرضی را توسط متد GET برای یک فایل PHP با نام ajax-get.php ارسال و پاسخ را در بلاکی با آی دی result خروجی می دهیم:

فایل ajax-get.php


<?php
@$site = $_GET['site'];
@$domain = $_GET['domain'];
echo "نام سایت: $site<br>";
echo "آدرس دامنه: $domain<br>";
echo "متد استفاده شده: GET<br>";
?>

کد HTML درخواست و تنظیمات Ajax


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>وبگو | ارسال و دریافت اطلاعات با متد GET</title>
<!-- Webgoo.ir -->
<style type="text/css">
body {
    font-family: Tahoma, Geneva, sans-serif;
    direction: rtl;
    font-size: 12px;
}
</style>
<script type="text/javascript">
function ajaxCallFile(id) {
    var xmlHttp;
    
    try {
        //Opera, Firefox, Safari
        xmlHttp = new XMLHttpRequest();
    } catch (e) {
        //Internet Explorer
        try {
            xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
        } catch (e) {
            try {
                xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
            } catch (e) {
                alert("متاسفانه مرورگر شما از ای جکس پشتیبانی نمی کند");
                return false;
            }
        }
    }
    xmlHttp.onreadystatechange = function () {
        if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {
            document.getElementById(id).innerHTML = xmlHttp.responseText;
            document.getElementById('button-1').innerHTML = 'ارسال درخواست ای جکس';
            document.getElementById('button-1').disabled = false;
        } else {
            document.getElementById('button-1').innerHTML = 'لطفا چند لحظه صبر کنید...';
            document.getElementById('button-1').disabled = true;
        }
    }
    
    xmlHttp.open("GET", "ajax-get.php?site=Webgoo&domain=https://webgoo.ir", true);
    xmlHttp.send(null);
}
</script>
</head>
<body>
<noscript>
جاوا اسکریپت در مرورگر شما غیر فعال است!<br>
</noscript>
<button id="button-1" type="button" onclick="ajaxCallFile('result')">ارسال درخواست ای جکس</button>
<div id="result"></div>
<hr>
پس از کلیک بر روی دکمه بالا، تابع جاوا اسکریپتی فراخوانی شده و درخواست ای جکس به فایل PHP در سرور ارسال می شود، سپس نتیجه دریافت و در بلاک نمایش داده خواهد شد، در این مثال از متد GET استفاده شده است.
</body>
</html>
پیش نمایش
متد POST در ای جکس شباهت زیادی به GET دارد، با این تفاوت که در این شیوه درخواست، مانند تگ form در HTML سربرگ های HTTP یا HTTP Headers نیز به مرورگر ارسال می شوند، از طرفی xmlHttp.send به جای مقادیر null، پارامترهایی با مقادیر رشته ای دارد.
کجا از POST استفاده کنیم؟
- در ای جکس هرکجا نیاز به ارسال اطلاعات حساس مانند نام کاربری، کلمه عبور، مشخصات حساب بانکی و... باشد، بهتر است از POST استفاده کنیم، چرا که اطلاعات در این شیوه در آدرس URL قابل روئیت نیست.
- برای ارسال اطلاعات حجیم (به طور مثال اطلاعات یک فرم HTML) از POST استفاده می شود، متد GET از نظر میزان اطلاعات مجاز با محدودیت های بیشتری در مقایسه با POST روبرو است.
جهت آشنایی بیشتر در مثال زیر اطلاعات فرضی را توسط متد POST برای یک فایل PHP با نام ajax-post.php ارسال و پاسخ را در بلاکی با آی دی result خروجی می دهیم:

فایل ajax-post.php


<?php
@$site = $_POST['site'];
@$domain = $_POST['domain'];
echo "نام سایت: $site<br>";
echo "آدرس دامنه: $domain<br>";
echo "متد استفاده شده: POST<br>";
?>

کد HTML درخواست و تنظیمات Ajax


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>وبگو | ارسال و دریافت اطلاعات با متد POST</title>
<!-- Webgoo.ir -->
<style type="text/css">
body {
    font-family: Tahoma, Geneva, sans-serif;
    direction: rtl;
    font-size: 12px;
}
</style>
<script type="text/javascript">
function ajaxCallFile(id) {
    var xmlHttp;
    
    try {
        //Opera, Firefox, Safari
        xmlHttp = new XMLHttpRequest();
    } catch (e) {
        //Internet Explorer
        try {
            xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
        } catch (e) {
            try {
                xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
            } catch (e) {
                alert("متاسفانه مرورگر شما از ای جکس پشتیبانی نمی کند");
                return false;
            }
        }
    }
    xmlHttp.onreadystatechange = function () {
        if (xmlHttp.readyState == 4 && xmlHttp.status == 200) {
            document.getElementById(id).innerHTML = xmlHttp.responseText;
            document.getElementById('button-1').innerHTML = 'ارسال درخواست ای جکس';
            document.getElementById('button-1').disabled = false;
        } else {
            document.getElementById('button-1').innerHTML = 'لطفا چند لحظه صبر کنید...';
            document.getElementById('button-1').disabled = true;
        }
    }
    
    xmlHttp.open("POST", "ajax-post.php", true);
    xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    xmlHttp.send('site=Webgoo&domain=https://webgoo.ir');
}
</script>
</head>
<body>
<noscript>
جاوا اسکریپت در مرورگر شما غیر فعال است!<br>
</noscript>
<button id="button-1" type="button" onclick="ajaxCallFile('result')">ارسال درخواست ای جکس</button>
<div id="result"></div>
<hr>
پس از کلیک بر روی دکمه بالا، تابع جاوا اسکریپتی فراخوانی شده و درخواست ای جکس به فایل PHP در سرور ارسال می شود، سپس نتیجه دریافت و در بلاک نمایش داده خواهد شد، در متد POST از متد setRequestHeader استفاده و پارامترها در قسمت send تنظیم و ارسال می شوند، در این مثال از متد POST استفاده شده است.
</body>
</html>
پیش نمایش
ارسال پارامترها در ای جکس صرفا به روش ثابت مانند نمونه کدهای بالا محدود نمی شود، در آموزش های بعدی خواهیم دید که چگونه می توان به نحو حرفه ای تر و با قابلیت تعاملی بیشتر به صورت پویا از قابلیت های ای جکس در طراحی امکانات و رابط کاربری برنامه های تحت وب استفاده کرد.
sectionدسته بندی: آموزش مقدماتی » Ajax
related مطالب بیشتر:
» نمایش پیام و تصویر در حال بارگذاری (loading) در آژاکس (ajax)
» نمایش و ذخیره اطلاعات فایل با آژاکس (Ajax)
» آموزش ای جکس (Ajax)، تکنیک غیرهمزمانی در وب
» نمایش افکت fade in با آژاکس (ajax)
» فریم ورک های آژاکس (Ajax Frameworks)
commentنظرات (۴۳ یادداشت برای این مطلب ارسال شده است)
نویسنده: saeid
زمان: ۱۸:۲۷:۱۵ - تاریخ: ۱۳۹۴/۰۳/۲۸
ممنون از پاسختون
منظورم همان بعد از پرس و جو کردن و بدست آوردن مقدار مورد نظر از MySQL جایگذاری شود دقیقا بجای id در عبارت
$name = $_POST['id'];
چون نام فیلد ها در فرم html از طریق پرس و جو از دیتابیس بدست می آید در صفحه php هم برای دریافت مقادیری که از متد post ارسال شده هم از روش پرس و جو استفاده میشه
چون در صفحه html به سادگی میتوان مقدار پرس و جو رو به عنوان نام فیلد جای گذاری کرد اما در صفحه php نمی توان مقدار را جایگزاری کرد
امیدوارم توانسته باشم درست منظورم رو بیان کرده باشم
با تشکر
پاسخ: 
اگر می خواهید برای پارامتر قسمت POST در PHP مقادیری از دیتابیس را قرار دهید که در واقع همان نام فیلد است، حالت زیر صحیح است:
$name = $_POST[$row['id']];
روش دیگر نسبت دادن مقادیر قسمت row (که در مثال شما عبارت data استفاده شده) در حلقه while به متغیر دیگر و استفاده از آن متغیر در ادامه کدها است.
نویسنده: saeid
زمان: ۱۴:۳۴:۱۶ - تاریخ: ۱۳۹۴/۰۳/۲۹
ممنون از راهنماییتون مشکل بطرف شد و همون دو تا ' اضافه باعث خطا شده بود
نویسنده: ترنم
زمان: ۲۳:۲۲:۳۸ - تاریخ: ۱۳۹۴/۰۵/۱۸
سلام و خداقوت
من میخوام از طریق ajax بین دو کاربر اطلاعات رد و بدل کنم مثلا یک کاربر پیامی به کاربر دیگر ارسال کند.
دقیقا نمیدونم باید چیکار کنم، میشه کمک کنید؟؟؟
پاسخ: 
این موارد جزء قابلیت های تقریبا پیشرفته محسوب می شوند، به این معنی که شما حداقل باید یک برنامه نویس با تجربه متوسط باشید تا بتوانید چنین سیستمی طراحی کنید، در هر صورت در حد راهنمائی، ابتدا باید در دیتابیس ساختار مناسب را طراحی کنید که شامل جدول اطلاعات کاربران، جدول مدیریت پیام ها و ... است، در مرورگر نیز یک موتور Ajax داشته باشید که به فواصل زمانی مشخص، فرآیندها را با دیتابیس هماهنگ کند، به این صورت که به فرض پیام کاربر را به سرور منتقل و بین پیام های موجود، موارد خوانده نشده ای که گیرنده پیام، کاربر حاضر می باشد را دریافت و در مرورگر او چاپ کند، البته قاعدتا بدون آشنایی با مباحثی مانند سشن و کوکی نمی توانید درک درست و راحتی از نحوه طراحی این ساختار داشته باشید.
نویسنده: غریب
زمان: ۱۸:۵۲:۴۶ - تاریخ: ۱۳۹۴/۰۶/۱۹
سلام دوست عزیز بنده دو سوال در مورد متد get دارم
اول اینکه چطور میشه یه عدد یا کلمه پیش فرض واسه فایل قرار داد یعنی وقتی طرف مقابل خود فایل پی اچ پی رو بدون متد اضافه شده به اخرش باز میکنه جلوی جاهایی که ما در فایل مقدار دهی کردیم خالی نباشه و مثلا یه عدد پیش فرض داشته باشه
دوم اینکه چطور میتونم برای فایل متغییر با این متد محدودیت کاراکتر بزارم که کاربر مثلا فقط بتونه 10 حرف و یا کاراکتر وارد بخش خالی متد get بکنه این رو برای امنیت میخوام البته بگم متد پست نیست
ممنون و خسته هم نباشید
پاسخ: 
- اگر منظور از "باز کردن فایل" همان فراخوانی از طریق مرورگر است، در این صورت می توانید با یک دستور شرطی، مقدار اولیه برای پارامتر در نظر بگیرید، به فرض:
<?php
$var = $_GET['param'];
if(!isset($var) || $var == ''){
$var = 0;
}
?>
- برای متد GET نمی توانید در سمت مرورگر محدودیت ایجاد کنید (تا حدی که مرورگر اجازه دهد، کاربر می تواند پارامتر را به سرور ارسال کند)، منتها ایمن سازی باید ابتدا توسط فایروال و ماژول های امنیتی سرور انجام شود، سپس در کدهای PHP نیز می توان طول رشته را بررسی کرد:
<?php
$var = $_GET['param'];
if(mb_strlen($var) > 10){
echo 'Error!';
}
?>
نویسنده: غریب
زمان: ۲۱:۵۴:۰۴ - تاریخ: ۱۳۹۴/۰۸/۰۲
سلام مجدد عزیز
کد اول رو گذاشتم اما عمل نکرد اگه میشه توضیح کاملتری بدید ممنون میشم و مشکل اصلی بنده اینه که میخوام با این متد لینک تصویر قرار داده بشه اما مشکل اینجاست که ممکنه فایلهای مخربی بگذارن حالا پیشنهاد شما برای بنده چیه ایا دستوری هست که بشه چند فرمت رو به فایل معرفی کرد؟
و کلا پیشنهاد شما برای بنده چی هست که بتونم امنیت همچین فایلی رو حفظ کنم ممنون میشم ساده و روون توضیح بدید چون دانش بنده قابل مقایسه با شما نیست جوری بفرمایید که بنده هم بتونم استفاده کنم از راهنماییتون مرسی و موفق باشید
در ضمن واقعا تشکر میکنم ازتون بابت راه اندازی سایتی اینگونه مفید جایی مثل سایت شما پیدا نکردم که انقدر ساده و بی تکلف به خواست دیگران اهمیت بده
پاسخ: 
- این کد صرفا یک مثال بود نه کدی کاربردی، منظور این بود که شما اگر با PHP آشنا باشید، با چنین روشی می توانید پارامترهای ارسالی به سرور را مدیریت کنید، قاعدتا اگر با PHP آشنا نباشید، نمی شود انتظار داشت چند خط کد ساده همه کارها را انجام دهد، باید معنی دستورات استفاده شده را بدانید.
- دقیقا متوجه نشدیم، منظورتان از لینک تصویر با متد GET چیست؟! آیا در حال طراحی یک سیستم آپلود هستید؟ لطفا ضمن توضیح گام به گام هدفتان، چند اسکرین شات تهیه یا آدرس صفحه مورد نظر را درج کنید.
نویسنده: Sepehr
زمان: ۱۹:۰۳:۵۵ - تاریخ: ۱۳۹۴/۱۱/۰۹
با عرض سلام. من برای پروژه دانشگاه لازم هست تا با فناوری Ajax و Php از پایگاه داده اطلاعاتی را جستجو کرده و بدون ریفرش شدن صفحه اطلاعات نمایش داده شود.
اطلاعات به گونه ای از قبل در Mysql ذخیره شده اند که کلید اصلی کد ملی است. در صورتی که مدیریت سایت در هنگام جستجو کد ملی شخص را وارد کند باید اطلاعات او با فناوری Ajax در خروجی نشان داده شود. از شما خواهشمند هستم من را راهنمایی بفرمایید . با تشکر
پاسخ: 
لطفا از طرح سوالات کلی خودداری کنید!
برای این کار علاوه بر آشنایی با PHP و نحوه ارتباط با MySQL، باید مباحث Ajax را هم مرور کرده باشید، در این صورت با آموزش ها و نمونه کدهایی که وجود دارد می توانید مطابق نیازتان کدهای پروژه را تعریف کنید.
نویسنده: مهدی
زمان: ۱۷:۲۳:۱۴ - تاریخ: ۱۳۹۵/۰۸/۰۸
سلام
ما هر وقت از متد post استفاده می کنیم باید
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
رو هم بنویسیم؟ یا نه؟
و اگه نه ، چه مواقعی باید نوشت؟
ممنون از راهنمایی هاتون!
پاسخ: 
متد setRequestHeader برای تنظیم سربرگ های HTTP در یک درخواست مبتنی بر AJAX است، در حالت معمول نیازی به تنظیم این مقادیر نیست و به صورت پیش فرض داده ها به صورت متنی ارسال می شوند، اما اگر بخواهید به طور مثال یونیکد داده های ارسالی را مشخص کنید، باید از این متد استفاده کنید (توضیح این موارد نیاز به آموزش های جداگانه دارد!)، لیست پارامترهایی که می توانید در این متد استفاده کنید:
https://en.wikipedia.org/wiki/List_of_HTTP_header_fields
نویسنده: محسن
زمان: ۰۱:۱۰:۲۴ - تاریخ: ۱۳۹۵/۱۲/۱۷
با سلام و خسته نباشید بابت سایت و مطالب خوبتون.
من یه سوال دارم.
من در جایی از سایتم یک کوئری با متد get می گیرم از مواردی که در دیتابیس ذخیره شده.
به این صورت:
http://khadmat.ir/search.php?id=157
که این کوئری با توجه به شماره id نتیجه مربوطه رو نمایش میده.
حالا نگرانی و سوالم اینه که من چطور میتونم جلوی کوئری ناخواسته رو بگیرم!
یعنی اینکه نذارم کاربر مستقیم از طریق تغییر شماره id در آدرس بار بیاد کوئری های هر id رو نمایش بده و ببینه!!!
با تشکر
پاسخ: 
دقیقا متوجه هدفتان نشدیم! در تئوری لینک های سایت یا حالت عمومی دارند یا حالت خصوصی و محافظت شده، برای لینک های عمومی به طور معمولا باید این امکان برای همه کاربران باشد که با فراخوانی، محتوا نمایش داده شود، در واقع با تغییر شماره ID باید محتوای مربوطه نمایش داده شود و این امری عادی است، اما اگر محتوای مد نظر خصوصی بود یا وجود نداشت، بحث دیگری است که باید در ابتدا برای آن یک قانون و ساختار مشخص داشته باشید، به طور مثال در ردیفی از دیتابیس برای ID های خصوصی به فرض ستون Access داشته باشید، اگر برابر 1 بود، محتوا را به کاربر نمایش دهید، در غیر اینصورت پیام خطای 403 را چاپ کنید! همین طور است برای ID هایی که در دیتابیس وجود ندارند، اگر نتیجه پرس و جو برابر 0 ردیف بود می توانید پیام "محتوای مد نظر در سایت وجود ندارد" را چاپ کنید!
نویسنده: سینا الف
زمان: ۲۰:۲۲:۲۱ - تاریخ: ۱۳۹۶/۰۵/۰۶
باسلام! من یه قالب رو از بلاگفا به بلاگ اسکای ترجمه کردم اما با مشکلی مواجه شدم: اینکه امکاناتی مانند بخش نظرسنجی یا لایک مطالب و موارد مشابه که در بلاگ اسکای بصورت آژاکس هست، اصلا کار نمیکنه... کد قالب رو روی وبلاگ آزمایشی قرار دادم، صمیمانه ممنون میشم راهنمایی بفرمائید تا بتونم این مطلب رو تا حدودی یاد بگیرم و مشکل قالبم رو رفع کنم. باتشکر!
پاسخ: 
بلاگ اسکای اسکریپت های مورد نیاز را به صورت فایل زیر در صفحه قرار می دهد:
http://www.blogsky.com/scripts/common?v=1
لذا این فایل باید در کد قالب شما وجود داشته باشد.
نکته: برخی قابلیت های قالب ممکن است فقط روی یک سرویس قابل اجرا باشند، به طور مثال ممکن است خدماتی مانند نظرسنجی روی سرویس دیگر ارائه نشوند.
نویسنده: محمدی
زمان: ۱۹:۴۹:۰۶ - تاریخ: ۱۳۹۶/۰۵/۱۵
سلام خواهش میکنم مشکل منو حل کنید هر چی بیشتر می گردم نا امید تر میشم من یه دکمه ای دارم که بعد از کلیک اون، یه جدول پایین همون صفحه نمایش داده میشه ولی بعد از کلیک، صفحه رفرش میشه و کاربر باز باید از بالا اسکرول کنه تا برسه محل جدول
تو رو خدا کمک کنید حلش کنم اینجوری خیلی بده
پاسخ: 
لطفا آدرس صفحه را جهت بررسی درج کنید یا فایل ها را به صورت فشرده شده به آدرس ایمیل سایت (موجود در بخش تماس) ارسال نمائید.
نویسنده: Kylo ren
زمان: ۰۸:۵۱:۴۷ - تاریخ: ۱۳۹۶/۱۰/۲۳
سلام بر شما ، من یه صفحه ویرایش مطلب دارم که اطلاعات اون به صورت فیلدهای یک فرم هستن ، و برای ثبت تغییرات فرم رو به یک فایل php ارسال می کنم تا توسط اون اعتبارسنجی و ثبت بشه . اما برای اینکه اعتبارسنجی انجام بشه من باید فرم رو ارسال کنم به اون صفحه و در نتیجه تغییرات در فیلدها از بین میرن. میشه لطفا راهنمایی کنید چجوری میتوان این فرم رو به صورت ای جکس اعتبارسنجی کرد به صورتی که مثلا اگر روی دکمه ثبت کلیک کردم بررسی انجام بشه و تغییرات رو ثبت کنه یا خطا رو بنویسه . البته منظورم اجرای اون فایل php بدون رفرش صفحه و نمایش نتیجه اونه . من سعی کردم اما واقعا غیراصولی شد و البته کاراکترهای فارسی رو ثبت نمی کرد! کلا منظورم مانند ویرایش مطالب وردپرس است. لطفا پیشنهادی بدین!
پاسخ: 
پاسخ کوتاهی برای سوالتان قابل ارائه نیست! باید از مقدمات با Ajax آشنا باشید، در هر صورت نمونه آموزشی در همین خصوص در سایت وجود دارد، برای دسترسی به این آموزش لطفا عبارت "ارسال اطلاعات فرم با ای جکس + وبگو" را در گوگل جستجو کنید، در صورتی که همچنان با مشکل مواجه بودید به صورت موردی مطرح کنید تا بررسی گردد.
نویسنده: Kylo ren
زمان: ۲۰:۵۵:۳۲ - تاریخ: ۱۳۹۶/۱۰/۲۳
با تشکر من از جی کوری از تابع serialize استفاده کردم ولی اطلاعات textarea رو که فارسی هست به صورت کاراکترهای ناشناخته منتقل میکنه چجوری میشه حروف فارسی رو درست منتقل کرد؟ البته textarea من یک texteditor هست با قالب html
پاسخ: 
تا آنجا که اطلاع داریم متد serialize از تابع encodeURIComponent استفاده می کند که این تابع مقادیر را پیش از انتقال بر اساس استاندارد URL با یونیکد UTF-8 تبدیل می کند، لذا برای دریافت مقادیر در PHP ابتدا باید آنها را Decode کنیم، مثال:
$editor_text = rawurldecode(htmlspecialchars($_POST['editor_text']));
اگر یک نمونه آنلاین یا اسکرین شات از شکل کاراکترها درج می کردید درک مشکل ساده تر بود.
نویسنده: Kylo ren
زمان: ۱۴:۱۷:۲۵ - تاریخ: ۱۳۹۶/۱۰/۲۴
سلام هر کاری کردم اطلاعاتی رو که با Ajax ارسال می کردم اگرچه با echo خروجی درست بود ولی در دیتابیس به صورت کاراکترهای نامفهوم ذخیره می شد. آخر فرم رو با تارگت iframe در همان صفحه ارسال کردم و برای خود فریم از jquery استفاده کردم. ولی در این حالت دیگه اطلاعات درست منتقل میشه! از تابع بالا هم استفاده کردم ولی فقط حروف نامفهوم رو به علامت سوال تغییر میده. (با روش ajax حروف فارسی و اموجی هارو به صورت åäö نمایش میداد) لطفا بیشتر درباره encode توضیح میدید؟
پاسخ: 
در استاندارد URL کاراکترهای فارسی در هنگام انتقال از سمت کاربر به سمت سرور تبدیل به علائم خاصی می شوند به طور مثال حرف ب تبدیل به معادل
%D8%A8
می شود، در حال حاضر این مقدار به طور معمول به صورت خودکار بین سمت کاربر و سرور انجام می گیرد و در صورتی که کل فرآیند از یونیکد UTF-8 پیروی کند مشکلی پیش نمی آید، اما گاهی نیاز است که به صورت دستی این مقادیر را تبدیل کنیم (معمولا در حالتی که بخشی از فرآیند به صورت پیش فرض از UTF-8 استفاده نکند)، برای تبدیل نیز از توابع زیر استفاده می شود (تابع پیشنهادی در سوال قبل اصلاح شد):
- urldecode
- rawurldecode
در هر حال با توجه به اینکه طبق گفته شما در دستور echo مشکلی دیده نمی شود، خطایابی بیشتر نیاز به تست عملی کدها دارد، ممکن است حتی یک ایراد کوچک باعث بروز این موارد شود که قابل پیش بینی نباشد و فقط در تست مشخص شود، همچنین باید دید دیتابیس، جداول و ستون ها از utf8_persian_ci استفاده کنند! اطلاعاتی در خصوص حروف فارسی و معادل آنها در MySQL:
http://collation-charts.org/mysql60/mysql604.utf8_persian_ci.html
paged صفحه 3 از 3




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

3 × 4
 refresh
آگهی
رنگین کمان عکس
Ranginkamaan.com

آرشیو عکس های باکیفیت با موضوعات متنوع...
پرشین آی تی
Persianit.net

آموزش و دانلود پروژه های برنامه نویسی سی شارپ (#C)
سامانه استخدام ایران
Iran-karyab.com

اطلاع رسانی استخدام های معتبر دانلود رایگان نمونه سئوالات