ToolDeck

JSON Diff

Compare two JSON objects and highlight differences

یک مثال امتحان کنید

JSON A (original)

JSON B (modified)

ابزار JSON Diff چیست؟

ابزار JSON Diff دو سند JSON را با هم مقایسه می‌کند و هر تفاوتی — کلیدهای اضافه‌شده، حذف‌شده، مقادیر تغییریافته و آیتم‌های جابه‌جاشده — را به صورت بصری نمایش می‌دهد. به جای اینکه دو بلوک متن را خط به خط بررسی کنید، سریع می‌بینید چه چیزی و کجا تغییر کرده است.

After · json
Before · json
{
  "name": "Alice",
  "age": 31,
  "roles": ["user"],
  "active": true,
  "score": 98
}
{
  "name": "Alice",
  "age": 30,
  "roles": ["admin", "user"],
  "active": true
}

چرا از ابزار JSON Diff استفاده کنیم؟

مقایسه دستی JSON مستعد خطا و زمان‌بر است. یک ابزار Diff تفاوت‌ها را واضح می‌کند؛ چه در حال بررسی تغییر پاسخ API باشید، چه بررسی تغییرات تنظیمات، یا اشکال‌زدایی یک پایپلاین داده.

🔍
تشخیص دقیق تغییرات
دقیقاً می‌بینید کدام کلیدها اضافه، حذف یا تغییر یافته‌اند — نه فقط کدام خطوط تغییر کرده‌اند. حتی اگر ترتیب کلیدها بین دو آبجکت متفاوت باشد، به درستی کار می‌کند.
🏗️
درک ساختار داده
برخلاف Diff متن ساده، JSON Diff ساختار داده را درک می‌کند. تغییر ترتیب کلیدها در یک آبجکت تغییر به حساب نمی‌آید؛ فقط تفاوت‌های واقعی در مقادیر علامت‌گذاری می‌شوند.
سریع و خصوصی
مقایسه کاملاً در مرورگر شما انجام می‌شود. هیچ داده‌ای به هیچ سروری ارسال نمی‌شود، بنابراین می‌توانید با اطمینان پیلودهای حساس، اعتبارنامه‌ها و تنظیمات داخلی را Diff کنید.
🔒
خروجی خوانا
نتایج با رنگ‌بندی و تورفتگی نمایش داده می‌شوند. به‌راحتی می‌توانید مقدار قدیم، مقدار جدید و دقیقاً محل آن در ساختار تودرتو را تشخیص دهید.

نحوه خواندن نتیجه Diff

هر تفاوت با رنگی که نوع تغییر را نشان می‌دهد هایلایت می‌شود. کلیدهای بدون تغییر با متن کم‌رنگ نمایش داده می‌شوند تا بتوانید روی آنچه واقعاً تغییر کرده تمرکز کنید.

اضافه‌شده
کلید یا مقداری که در JSON اصلاح‌شده وجود دارد اما در نسخه اصلی نیست.
حذف‌شده
کلید یا مقداری که در JSON اصلی وجود دارد اما در نسخه اصلاح‌شده حذف شده است.
تغییریافته
کلیدی که در هر دو نسخه وجود دارد، اما مقدار آن بروزرسانی شده است.
بدون تغییر
کلیدها و مقادیری که در هر دو سند یکسان هستند — برای نمایش زمینه نشان داده می‌شوند.

موارد استفاده رایج

نسخه‌بندی پاسخ API
پاسخ‌های API دو نسخه مختلف سرویس خود را مقایسه کنید تا سازگاری رو به عقب را تأیید کنید و تغییرات ناخواسته شکننده را قبل از رسیدن به محیط تولید شناسایی کنید.
ممیزی فایل‌های تنظیمات
فایل‌های تنظیمات JSON را قبل و بعد از استقرار Diff کنید تا دقیقاً مطمئن شوید چه چیزی تغییر کرده و هیچ چیز غیرمنتظره‌ای اصلاح نشده است.
مقایسه رکوردهای پایگاه داده
یک رکورد را قبل و بعد از بروزرسانی مقایسه کنید تا تأیید کنید فقط فیلدهای مورد نظر تغییر کرده‌اند و هیچ عوارض جانبی رخ نداده است.
اشکال‌زدایی پایپلاین‌های داده
وقتی خروجی یک پایپلاین اشتباه به نظر می‌رسد، JSON ورودی را با JSON خروجی Diff کنید تا سریع پیدا کنید تبدیل کجا خطا ایجاد کرده است.
کمک به بررسی کد
دو پیلود JSON را در یک نظر بررسی کد وارد کنید تا تفاوت‌ها برای همتیمی‌ها آشکار شود بدون اینکه نیاز باشد خودشان دستی دو بلوک متن را تجزیه کنند.
نگهداری فیکسچرهای تست
وقتی خروجی‌های مورد انتظار تست تغییر می‌کنند، از ابزار Diff استفاده کنید تا تأیید کنید تغییر عمدی است و فیکسچرها را با اطمینان بروزرسانی کنید.

سوالات متداول

آیا ترتیب کلیدها در Diff اهمیت دارد؟
خیر. Diff به صورت معنایی JSON را مقایسه می‌کند، نه متنی. دو آبجکت با همان کلیدها و مقادیر در ترتیب‌های مختلف یکسان تلقی می‌شوند.
با آرایه‌ها چه اتفاقی می‌افتد؟
عناصر آرایه بر اساس موقعیت مقایسه می‌شوند. اگر عنصری را از اندیس ۰ به اندیس ۱ منتقل کنید، در هر دو موقعیت تغییر به حساب می‌آید. برای مقایسه آرایه مستقل از ترتیب، قبل از Diff آرایه‌ها را مرتب کنید.
آیا می‌توانم JSON با تودرتویی عمیق را Diff کنم؟
بله. Diff به صورت بازگشتی وارد آبجکت‌ها و آرایه‌های تودرتو در هر عمقی می‌شود و مسیر دقیق هر مقدار تغییریافته را گزارش می‌دهد.
آیا داده‌هایم به سرور ارسال می‌شود؟
خیر. همه چیز به صورت محلی در مرورگر شما با JavaScript اجرا می‌شود. JSON شما هرگز دستگاه شما را ترک نمی‌کند.
اگر JSON نامعتبر باشد چه می‌شود؟
اگر هر کدام از ورودی‌ها JSON معتبر نباشند، ابزار قبل از هر گونه مقایسه یک خطای تجزیه نشان می‌دهد. ابتدا خطاهای نحوی را برطرف کنید، سپس مقایسه کنید.