<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های Joey.WD</title>
        <link>https://virgool.io/feed/@joeywd</link>
        <description>برنامه‌نویس وب ( PHP/Laravel)، متخصص توسعه وردپرس</description>
        <language>fa</language>
        <pubDate>2026-06-07 15:10:44</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/1704974/avatar/avatar.png?height=120&amp;width=120</url>
            <title>Joey.WD</title>
            <link>https://virgool.io/@joeywd</link>
        </image>

                    <item>
                <title>تغییر کوئری درست قبل از گرفتن اطلاعات</title>
                <link>https://virgool.io/@joeywd/pre-get-post-gm6xzkwdavra</link>
                <description>امروز می‌خوام راجع به یه هوک خیلی کاربردی تو وردپرس صحبت کنم:pre_get_post()با این هوک شما می‌تونین درست قبل از اینکه پست‌ها توسط کوئری گرفته بشن، کوئری رو طبق نیازتون تغییر بدین.جاهایی که من تا حالا ازش استفاده کردم:تغییر کوئری پیشفرض سرچ (فوق‌العاده کاربردیه اینجا. مثلا:‌ حذف پست‌های no-index از سرچ یا اضافه کردن meta_query به کوئری اصلی و...)تغییر تعداد پست‌هایی که تو یه صفحه لود میشهتغییر ترتیب پست‌ها (order by)حذف/اضافه کردن یسری پستِ خاص در صفحهچرا از این هوک استفاده کنیم؟خوبی‌ای که این هوک داره اینه که کوئری اصلی رو عوض نمی‌کنه و فقط تغییراتی رو که می‌خوایم رو روش اعمال می‌کنه.مثلا ما می‌خوایم هرجایی که قرار شده پست‌ها لود بشن با کوئری، بیشتر از ۲۰ تا پست لود نشه. یا مثلا می‌خوایم کتگوری‌ها رو برای یه مدت موقت کلا لود نکنیم. برای انجام دادن این کارا بهترین روش اینه که بیایم با یه هوک همه‌ی کوئری‌هایی که زده میشه رو تغییر بدیم تا جایی رو فراموش نکنیم و همه جا تغییراتمون اعمال بشن.چجوری ازش استفاده کنیم؟تو این مثال تعداد پست‌های هر صفحه رو برای پست تایپ movie تغییر دادیم:function change_movie_posts_per_page( $query ) {
	if( $query-&gt;is_main_query() &amp;&amp; !is_admin() &amp;&amp; is_post_type_archive( &#039;movie&#039; ) ) {
		$query-&gt;set( &#039;posts_per_page&#039;, &#039;5&#039; );
	}
}
add_action( &#039;pre_get_posts&#039;, &#039;change_movie_posts_per_page&#039; );اینجا هم یه متاکوئری اضافه میکنیم:function movie_query( $query ) {
	
	if( $query-&gt;is_main_query() &amp;&amp; !$query-&gt;is_feed() &amp;&amp; !is_admin() &amp;&amp; $query-&gt;is_post_type_archive( &#039;movie&#039; ) ) {
		$meta_query = array(
			array(
				&#039;key&#039;              =&gt; &#039;movie_date&#039;,
				&#039;value&#039;           =&gt; time(),
				&#039;compare&#039;    =&gt; &amp;quot&gt;&amp;quot
			)
		);
		$query-&gt;set( &#039;meta_query&#039;, $meta_query );
		$query-&gt;set( &#039;orderby&#039;, &#039;meta_value_num&#039; );
		$query-&gt;set( &#039;meta_key&#039;, &#039;movie_date&#039; );
		$query-&gt;set( &#039;order&#039;, &#039;DSEC&#039; );
		$query-&gt;set( &#039;posts_per_page&#039;, &#039;5&#039; );
	}

}

add_action( &#039;pre_get_posts&#039;, &#039;movie_query&#039; );اگه سؤال یا نظری داشتین روی لینکدین یا توییتر سریعتر جواب میدم تا اینجا.</description>
                <category>Joey.WD</category>
                <author>Joey.WD</author>
                <pubDate>Thu, 14 Jul 2022 10:30:38 +0430</pubDate>
            </item>
                    <item>
                <title>نانس (Nonce) در وردپرس چیه و چجوری ازش استفاده کنیم؟</title>
                <link>https://virgool.io/Bartarinha/nonce-pidhuk19e1g0</link>
                <description>نانس چیه؟در مهندسی امنیت، نانس عبارت است از تعدادی عدد دلخواه که تنها یکبار برای امضای یک ارتباط استفاده می‌شود.پاراگراف بالا توضیح خلاصه ویکیپدیا از نانسه. کلمه Nonce در اصل از ترکیب کلمات یک جمله تولید شده که تو رفرنس‌های مختلف جمله‌ی که تشکیل‌دهنده رو چیزای مختلفی می‌گن:Number OnceNumber Used OnceNumber Only Used Onceهمونطور که می‌بینید مفهوم این جملات یکیه و دارن میگن «عددی که فقط یکبار استفاده میشه».کاربرد نانس چیه؟نانس یه توکن یکتاست که برای اضافه کردن یک لایه امنیتی به اپلیکیشن استفاده میشه. کسایی که با مفهوم بلاکچین و ماینینگ آشنا باشن احتمالا نانس به گوششون خورده. امنیت بلاکچین رو نانس تامین میکنه.نمونه کارکرد نانسعکس بالا یه مثال خوبه که بهتر متوجه بشین. پروسه فعالیت یک نانس اینجوری میشه:سرور یک نانس تولید میکنه، اون رو لوکالی ذخیره میکنه و به کلاینت میفرستتش.کلاینت کارشو انجام میده و درخواستشو به همراه نانسی که بهش داده شده به سمت سرور میفرسته.سرور که درخواست رو دریافت میکنه اول چک میکنه ببینه آیا تو درخواست نانس وجود داره یا نه، اگه وجود داشت مقدار نانس رو با مقداری که لوکالی ذخیره کرده بود با مقایسه اعتبارسنجی میکنه و اگه معتبر بود درخواست رو سالم و قابل اعتماد تلقی میکنه و کار رو انجام میده.بعد از اینکه اعتبارسنجی انجام شد نانسی که ازش استفاده شده باید نامعتبر یا نابود بشه تا مفهوم Number Used Only Once (عددی که فقط یکبار استفاده میشه) محقق بشه.نانس در وردپرس یه نانس واقعی نیست!شاید بدونین که وردپرس خودش یه سیستم نانس داره. اما این سیستم وردپرس نانس واقعی نیست و مفهوم Number Used Only Once (عددی که فقط یکبار استفاده میشه) رو محقق نمیکنه. چرا؟ چون مرحله ۴ام از پروسه‌ای که بالاتر نوشتم رو رعایت نمیکنه و میتونه بیشتر از یک بار استفاده بشه.وردپرس نانسی که می‌سازه رو حداقل ۱۲ ساعت معتبر نگه می‌داره (البته میتونه تا ۲۴ ساعت هم معتبر بمونه، بستگی به تیکش داره). در نتیجه میشه از یه نانس بی‌شمار مرتبه استفاده کرد و این مفهوم اصلی نانس رو نقض می‌کنه.تیک-تیکتیک‌ها یا Ticks یکی از پارامتر‌هایی هستن که وردپرس برای ساختن نانس ازشون استفاده می‌کنه که با فانکشن wp_nonce_tick در پروسه ساخته شدن نانس تعریف میشن.تیک یک مقداریه که در هر نیمه‌روز (۱۲:۰۰:۰۰) و نیمه‌شب (۰۰:۰۰:۰۰) یک واحد تغییر میکنه، یعنی هر ۱۲ ساعت. تیک برای مشخص کردن لایف‌تایم هر نانس استفاده میشه. همونطور که گفتیم لایف‌تایم هر نانس تو وردپرس نهایتا تا ۲۴ ساعته. یا به عبارت درست‌تر، به انداره مقدار تیک حال حاضر و تیک قبلی اعتبار داره.حالا چون تیک هر ۱۲ ساعت تغییر می‌کنه، تنها در صورتی یه نانس می‌تونه ۲۴ ساعت معتبر بمونه که ساعت ۰۰:۰۰:۰۱ یا ۱۲:۰۰:۰۱ ساخته شده باشه. جدول زیر رو ببینین بهتر متوجه میشین:لایف‌تایم نانس وردپرسبا این وضعیت نانس وردپرس چیکار کنیم؟درسته که نانس وردپرس نانس واقعی نیست و این از نظر امنیتی کمی ضعیفش میکنه، ولی در هر صورت برای جلوگیری از CSRF خیلی بدرد میخوره. فقط حواستون باشه که فقط روی نانس برای امنیت حساب نکنین و فاکتور‌های امنیتی دیگه‌ هم حتما لحاظ کنین.در کل یه نانس واقعی هم فقط به شما میگه که سورس رکوئستی که دارین به اصطلاح geniuinعه (اصیله، قابل اعتماده) و کاری با این نداره که اصلا آیا سورسِ رکوئست پرمیشنِ دادنِ این رکوئست رو داره یا نه!نحوه استفاده از نانس وردپرسچند تا فانکشن برای ساختن و چند تا فانکشن برای اعتبارسنجی نانس وجود داره که همه رو بررسی میکنیم:ساختن نانسوردپرس ۳ تا تابع برای ساختن نانس داره:wp_create_nonce()wp_nonce_field()wp_nonce_url()تابع wp_create_noncewp_create_nonce( string|int $action = -1 )این تابع برای استفاده کلیه و شما هرجا که نیاز داشته باشین میتونین ازش استفاده کنین تا یه Nonce بسازین. یه ورودی اکشن میگیره که بهتره همیشه ازش استفاده کنین و اکشن رو تعریف کنین تا با یه نانس دیگه کانفلیکت نخوره. مثلا:// create nonce
$save_form_nonce = wp_create_nonce( &#039;save_form_&#039; . $form_id );
// usage
&lt;a href=&amp;quotsave.php?action=save_form&amp;nonce_token=&lt;?= esc_attr( $save_form_nonce ); ?&gt;&amp;form=&lt;?= esc_attr( $form_id ); ?&gt;&amp;quot&gt;&lt;?php esc_html_e( &#039;Save&#039;, &#039;textdomain&#039; ); ?&gt;&lt;/a&gt;تابع wp_nonce_fieldwp_nonce_field( int|string $action = -1, string $name = &#x27;_wpnonce&#x27;, bool $referer = true, bool $echo = true )این تابع برای توی فرم‌های HTMLعه و خروجیش فیلد مخفی‌ایه که نانس رو به عنوان مقدار داره. چهار تا ورودی میگیره که بهتره همیشه از اولی که اکشنه استفاده کنین و اکشن رو تعریف کنین تا با یه نانس دیگه کانفلیکت نخوره.ورودی دوم اسم فیلد مخفیه و ورودی چهارم میگه که echo کنم یا نه.ورودی سوم یک فیلد مخفی اضافه ایجاد میکنه به اسم _wp_http_referer که مقدارش URL رفرریه که از متغیر سوپرگلوبال _SERVER گرفته. مثلا:&lt;form method=&amp;quotpost&amp;quot id=&amp;quot80&amp;quot&gt;
   &lt;!-- some form fields --&gt;
   &lt;input type=hidden name=&amp;quotis_edit&amp;quot value=&amp;quot&lt;?php echo esc_attr( $is_edit ); ?&gt;&amp;quot&gt;
   &lt;?php wp_nonce_field( &#039;save_form_80&#039;, &#039;nonce_token&#039; ); ?&gt;
&lt;/form&gt;تابع wp_nonce_urlwp_nonce_url( string $actionurl, int|string $action = -1, string $name = &#x27;_wpnonce&#x27; )این تابع برای URL استفاده میشه که نانس رو به URL به عنوان یه کوئری استرینگ اضافه میکنه. سه تا ورودی میگیره که بهتره همیشه از دومی که اکشنه استفاده کنین و اکشن رو تعریف کنین تا با یه نانس دیگه کانفلیکت نخوره.ورودی اول URLایه که میخواین نانس رو بهش اضافه کنین و ورودی سوم هم اسم متغیره. مثلا:&lt;?php
$url = wp_nonce_url( admin_url(), &#039;save_form_&#039; . $form_id, &#039;nonce_token&#039; );
?&gt;
&lt;a href=&amp;quot&lt;?= $url; ?&gt;&amp;quot&gt;&lt;?php esc_html_e( &#039;Save&#039;, &#039;textdomain&#039; ); ?&gt;&lt;/a&gt;اعتبارسنجی نانسوردپرس ۳ تا تابع هم برای اعتبارسنجی نانس داره:wp_verify_nonce()check_admin_referer()check_ajax_referer()تابع wp_verify_noncewp_verify_nonce( string $nonce, string|int $action = -1 )این تابع مثل تابع اول ساختن نانس برای استفاده کلیه و شما هرجا که نیاز داشته باشین یه نانس رو استفاده کنین میتونین ازش استفاده کنین. ورودی اولش که مقدار خود نانسه و ورودی دومش هم اسم اکشنیه که تو فانکشن ساختن نانس استفاده کردین.خروجی تابع اگه نانس معتبر نباشه falseعه و اگه معتبر باشه نسبت به این که تو این تیک ساخته شده یا تیک قبلی بین ۱ و ۲ متغیره. اگه تو این تیک ساخته شده باشه ۱ و اگه تو تیک قبلی باشه ۲ برمیگردونه. مثلا:$nonce = $_REQUEST[ &#039;nonce_token&#039; ];
$nonce = wp_verify_nonce( $nonce, &#039;save_form_&#039; . $form_id );
switch ( $nonce ) {
    case 1:
        echo &#039;Nonce was generated in the current tick&#039;;
        break;
    case 2:
        echo &#039;Nonce was generated in the previous tick&#039;;
        break;
    default:
        exit( &#039;Nonce is invalid&#039; );
}تابع check_admin_referercheck_admin_referer( int|string $action = -1, string $query_arg = &#x27;_wpnonce&#x27; )برخلاف اسم غلط‌اندازش، این فانکشن با پرمیشن‌های یوزر کاری نداره و دقیقا مثل فانکشن قبلیه. تنها تفاوتی که دارن اینه که این فانکشن در صورتی که نانس نامعتبر باشه، به صورت خودکار با صدا زدن فانکشن wp_nonce_ays که متن ?Are you sure رو نمایش میده، اسکریپت رو متوقف میکنه (die). مثلا:$nonce = $_REQUEST[ &#039;nonce_token&#039; ];
if ( check_admin_referer( $nonce, &#039;save_form_&#039; . $form_id ) ) {
  // Nonce validated.
}تابع check_ajax_referercheck_ajax_referer( int|string $action = -1, false|string $query_arg = false, bool $die = true )آخرین تابع اعتبارسنجی یه نانس برای رکوئست‌های ایجکس استفاده میشه. این فانکشن ۳ تا ورودی می‌گیره که اولی اکشنه، دومی اسم متغیر در کوئریه و سومی هم میگه بمیرم یا نمیرم. :) مثلا:// Ajax Request
&lt;?php
//Create your nonce
$my_ajax_nonce = wp_create_nonce( &#039;save_form_&#039; . $form_id );
?&gt;

&lt;script type=&amp;quottext/javascript&amp;quot&gt;
jQuery(document).ready(function($){
    var data = {
        action: &#039;save_form&#039;,
        form: &#039;&lt;?php echo $form_id; ?&gt;&#039;,
        nonce_token: &#039;&lt;?php echo $my_ajax_nonce; ?&gt;&#039;,
    };
    $.post(
           ajaxurl, 
           data,
           function(response) {
           console.log({response});
    });
});


// Ajax Request callback
add_action( &#039;wp_ajax_save_form&#039;, &#039;save_form&#039; );

function save_form() {
  if ( check_ajax_referer( &#039;save_form_&#039; . $_post[&#039;form&#039;], &#039;nonce_token&#039; ) ) {
   // Nonce validated.
   wp_send_json_success();
  }
}اگه نانس واقعی بخوایم چی؟من یه نانس واقعی برای وردپرس طراحی کردم که خودم استفاده میکردم. امروز براتون گذاشتمش روی گیت‌هاب، می‌تونین ازش استفاده کنین.https://github.com/josephyas/wp-real-nonceاگه سؤال یا نظری داشتین روی لینکدین یا توییتر سریعتر جواب میدم تا اینجا.منابع:https://codex.wordpress.org/WordPress_Nonceshttps://developer.wordpress.org/themes/theme-security/using-nonces/https://en.wikipedia.org/wiki/Cryptographic_nonce</description>
                <category>Joey.WD</category>
                <author>Joey.WD</author>
                <pubDate>Tue, 05 Jul 2022 18:01:23 +0430</pubDate>
            </item>
            </channel>
</rss>