WiX/mag

ویکس مگ / مجله آموزشی ویکس سِوِن

مدیریت خطا ری‌ اکت

مدیریت خطاها در ری‌ اکت: راهنمای جامع

پیمان باقری

پیمان باقری

برنامه نویس و متخصص وب

مدیریت خطاها یکی از ارکان اساسی در توسعه اپلیکیشن‌های ری‌ اکت است که تاثیر مستقیمی بر کیفیت و تجربه کاربری دارد. خطاهای پیش‌بینی‌نشده می‌توانند موجب اختلال در عملکرد اپلیکیشن شده و کاربران را از ادامه استفاده منصرف کنند. با استفاده از ابزارها و تکنیک‌های مدرن، مانند Error Boundaries، کتابخانه‌های مدیریت خطا و رویکردهای پیشگیرانه، می‌توان خطاها را به‌صورت موثر مدیریت و کاهش داد. این مقاله به بررسی جامع روش‌ها و بهترین شیوه‌های مدیریت خطا در ری‌ اکت می‌پردازد و راهکارهایی عملی برای تیم‌های توسعه ارائه می‌دهد.

 

اهمیت مدیریت خطاها در اپلیکیشن‌های ری‌ اکت

در اپلیکیشن‌های ری‌ اکت، مدیریت خطاها یکی از مهم‌ترین جنبه‌های طراحی و توسعه است، زیرا بروز خطاهای پیش‌بینی‌نشده می‌تواند عملکرد سیستم را مختل کرده و تجربه کاربران را تحت تأثیر قرار دهد. خطاها ممکن است در سطوح مختلف، از کامپوننت‌های UI گرفته تا درخواست‌های سرور و تعاملات کاربران، رخ دهند. بدون یک سیستم مدیریت خطای مناسب، این مشکلات می‌توانند به قطع عملکرد بخش‌های کلیدی برنامه و حتی از دست رفتن داده‌ها منجر شوند.

چرا مدیریت خطا مهم است؟

  1. پایداری سیستم: مدیریت مناسب خطاها باعث می‌شود که حتی در صورت وقوع مشکلات، سایر بخش‌های اپلیکیشن به درستی کار کنند. این موضوع به افزایش قابلیت اطمینان و پایداری نرم‌افزار کمک می‌کند.
  2. کاهش خطاهای غیرمنتظره: شناسایی و رسیدگی به خطاها در زمان توسعه، به کاهش خطاهای Runtime کمک می‌کند که معمولاً حل آن‌ها پیچیده‌تر و پرهزینه‌تر است.
  3. مستندسازی و رفع سریع‌تر مشکلات: مدیریت خطاها با ابزارهایی مانند Sentry و Rollbar به توسعه‌دهندگان امکان می‌دهد خطاها را سریع‌تر شناسایی و رفع کنند.

 

تأثیر تجربه کاربری و قابلیت نگهداری

تجربه کاربری (User Experience): یکی از پیامدهای مهم خطاهای مدیریت‌نشده، تأثیر منفی آن بر تجربه کاربری است. به عنوان مثال، اگر یک خطا باعث از کار افتادن یک کامپوننت حیاتی شود، ممکن است کاربر از ادامه کار با اپلیکیشن منصرف شود. یک تجربه کاربری مثبت نیازمند سیستمی است که خطاها را به شیوه‌ای مؤدبانه و بدون مزاحمت به کاربر اطلاع دهد (مثلاً نمایش پیام‌های خطای معنادار).

مدیریت مؤثر خطاها باعث می‌شود:

  • کاربران احساس اطمینان و امنیت بیشتری کنند.
  • تعامل با اپلیکیشن روان‌تر و جذاب‌تر باشد.
  • نرخ ریزش کاربران کاهش یابد.

قابلیت نگهداری (Maintainability): مدیریت ساختارمند خطاها نه تنها تجربه کاربران را بهبود می‌بخشد، بلکه توسعه و نگهداری اپلیکیشن را برای تیم‌ها آسان‌تر می‌کند. این قابلیت از طریق موارد زیر تقویت می‌شود:

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

مدیریت خطاها در ری‌ اکت نه‌تنها برای افزایش کارایی و اطمینان برنامه ضروری است، بلکه نقشی کلیدی در رضایت کاربران و قابلیت گسترش و نگهداری پروژه ایفا می‌کند.

 

Error Boundaries در ری‌ اکت: مدیریت خطا در کامپوننت‌ها

تعریف و نحوه عملکرد Error Boundaries

Error Boundaries یکی از ویژگی‌های مهم ری‌ اکت است که به توسعه‌دهندگان امکان می‌دهد خطاهای رخ‌داده در زیرمجموعه‌ای از کامپوننت‌ها را مدیریت کنند. این کامپوننت‌ها، به جای مختل کردن کل اپلیکیشن، تنها بخش آسیب‌دیده را جدا می‌کنند و از نمایش خطاهای پیش‌بینی‌نشده جلوگیری می‌کنند.

نحوه عملکرد: Error Boundaries تنها خطاهای رخ‌داده در مرحله رندرینگ، لایف‌سایکل متدها و متدهای فرزند کامپوننت‌ها را می‌گیرند. این خطاها به صورت مؤثر شناسایی شده و کامپوننت جایگزینی (معمولاً یک UI fallback) نمایش داده می‌شود. با این حال، Error Boundaries نمی‌توانند خطاهای رخ‌داده در event handlers یا promiseها را مدیریت کنند.

تفاوت Error Boundaries با سایر روش‌های مدیریت خطا

  • Error Boundaries برای مدیریت خطاهای مرتبط با UI استفاده می‌شوند و خطاهای ساختاریافته را مدیریت می‌کنند. این در حالی است که سایر روش‌ها (مانند try-catch یا مدیریت خطا در promiseها) برای سناریوهای خاص‌تر و سطح کد مناسب هستند.
  • برخلاف try-catch که باید به صورت دستی پیاده‌سازی شود، Error Boundaries به صورت خودکار خطاهای موجود در محدوده زیرشاخه‌های خود را مدیریت می‌کنند.

مراحل پیاده‌ سازی Error Boundaries

برای ایجاد یک Error Boundary، باید یک کامپوننت کلاسی طراحی کنید که دو متد خاص در آن پیاده‌سازی شده باشد:

1. استفاده از getDerivedStateFromError

این متد یک متد استاتیک است که قبل از رندر شدن کامپوننت فراخوانی می‌شود. این متد وضعیت (state) کامپوننت را بر اساس خطای رخ‌داده تنظیم می‌کند:

static getDerivedStateFromError(error) {
  return { hasError: true };
}

2. استفاده از componentDidCatch

این متد خطاهای رخ‌داده را دریافت کرده و امکان لاگ کردن آن‌ها یا ارسال به سرویس‌های خطایابی (مانند Sentry) را فراهم می‌کند:

componentDidCatch(error, errorInfo) {
  console.log("Error:", error, errorInfo);
  // ارسال خطا به سرویس‌های مدیریت خطا
}

مثال کامل:

class ErrorBoundary extends React.Component {
  constructor(props) {
    super(props);
    this.state = { hasError: false };
  }

  static getDerivedStateFromError(error) {
    return { hasError: true };
  }

  componentDidCatch(error, errorInfo) {
    console.error("Logged Error:", error, errorInfo);
  }

  render() {
    if (this.state.hasError) {
      return <h1>Something went wrong.</h1>;
    }
    return this.props.children;
  }
}

استفاده از Error Boundary:

<ErrorBoundary>
  <MyComponent />
</ErrorBoundary>

بهترین روش‌ها برای استفاده از Error Boundaries

1. استفاده از UIهای Fallback مؤثر:

  • نمایش پیام‌های دوستانه و شفاف به کاربران به جای پیام‌های مبهم یا عمومی.
  • ارائه دکمه‌هایی مانند “تلاش مجدد” یا “بازگشت به صفحه اصلی” برای بهبود تجربه کاربری.

2. دسته‌بندی استراتژیک کامپوننت‌ها:

  • استفاده از چندین Error Boundary در بخش‌های مختلف اپلیکیشن برای جلوگیری از تأثیر خطاها بر کل برنامه.
  • جدا کردن کامپوننت‌های حیاتی از کامپوننت‌هایی که خطاهای بیشتری تولید می‌کنند.

چالش‌ها و محدودیت‌های Error Boundaries

1. عدم پشتیبانی از خطاهای Event Handlers:

Error Boundaries نمی‌توانند خطاهای رخ‌داده در Event Handlers را مدیریت کنند. برای این موارد باید از try-catch استفاده کرد.

2. خطاهای خارج از UI:

خطاهای رخ‌داده در async functions یا promiseها خارج از محدوده Error Boundaries هستند و باید به صورت جداگانه مدیریت شوند.

3. پیاده‌سازی دستی:

در حالی که ری‌ اکت ابزارهایی برای مدیریت خطاها ارائه می‌دهد، توسعه‌دهنده باید به صورت دستی آن‌ها را در جای مناسب پیاده‌سازی کند.

Error Boundaries ابزاری بسیار قدرتمند برای مدیریت خطاهای UI در اپلیکیشن‌های ری‌ اکت هستند. با این حال، برای مدیریت جامع‌تر خطاها در کل اپلیکیشن، ترکیب این ابزار با سایر روش‌های مدیریت خطا (مانند try-catch و promise handling) ضروری است. با استفاده از تکنیک‌ها و ابزارهای پیشرفته، می‌توان تجربه کاربری را بهبود داده و از تأثیرات منفی خطاها بر عملکرد اپلیکیشن جلوگیری کرد.

 

مدیریت خطاهای خارج از Error Boundaries

1. مدیریت خطا در Event Handlers

خطاهای رخ‌داده در Event Handlers توسط Error Boundaries پوشش داده نمی‌شوند. برای مدیریت این دسته از خطاها، می‌توانید از روش‌های زیر استفاده کنید:

استفاده از try-catch:

در Event Handlers، می‌توانید به صورت مستقیم از ساختار try-catch برای گرفتن و مدیریت خطاها استفاده کنید:

handleClick = () => {
  try {
    // کدی که ممکن است خطا ایجاد کند
  } catch (error) {
    console.error("Error in event handler:", error);
    // مدیریت خطا یا نمایش پیام به کاربر
  }
};

ارائه پیام مناسب به کاربران:

نمایش پیام‌های کاربردی در هنگام وقوع خطا می‌تواند تجربه کاربری را بهبود دهد. به عنوان مثال، نمایش یک toast یا alert که خطای رخ‌داده را توضیح می‌دهد.

2. مدیریت خطا در کدهای Asynchronous

خطاهایی که در کدهای ناهمگام (Asynchronous) رخ می‌دهند، باید به صورت دستی مدیریت شوند. Error Boundaries این نوع خطاها را نیز پوشش نمی‌دهند. روش‌های معمول برای مدیریت این خطاها عبارت‌اند از:

استفاده از بلوک catch در Promiseها:

اگر از Promiseها استفاده می‌کنید، می‌توانید از متد .catch برای گرفتن و مدیریت خطاها استفاده کنید:

fetchData()
  .then(response => {
    // پردازش داده‌ها
  })
  .catch(error => {
    console.error("Error in fetching data:", error);
    // مدیریت خطا
  });

استفاده از async/await همراه با try-catch:

این روش خوانایی بهتری دارد و خطاها را در سطوح مختلف مدیریت می‌کند:

const fetchData = async () => {
  try {
    const response = await fetch("https://api.example.com/data");
    const data = await response.json();
    // پردازش داده‌ها
  } catch (error) {
    console.error("Error in async function:", error);
    // مدیریت خطا
  }
};

مدیریت خطاهای عمومی:

می‌توانید یک handler عمومی برای مدیریت خطاهای ناهمگام تنظیم کنید، به خصوص در پروژه‌های بزرگ. به عنوان مثال، افزودن یک لایه مدیریت خطا در Redux Middleware یا Context API.

3. مدیریت خطا در Server-Side Rendering (SSR)

خطاهای مربوط به Rendering در سمت سرور باید به طور جداگانه مدیریت شوند، زیرا این خطاها می‌توانند بر تجربه کلی کاربر تأثیر بگذارند و حتی باعث عدم بارگذاری صفحه شوند. در این موارد، رویکردهای زیر مفید هستند:

استفاده از Error Handling Middleware:

اگر از فریم‌ورکی مانند Next.js استفاده می‌کنید، می‌توانید از Middlewareها یا متدهای خاص برای گرفتن و مدیریت خطاها در سمت سرور استفاده کنید. به عنوان مثال:

export default async function handler(req, res) {
  try {
    const data = await fetchData();
    res.status(200).json(data);
  } catch (error) {
    console.error("Server-side error:", error);
    res.status(500).json({ error: "Internal Server Error" });
  }
}

نمایش صفحات خطای سفارشی:

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

  • Next.js: صفحه‌ای مانند pages/500.js برای خطاهای داخلی تعریف کنید.
  • React Server Rendering: رندر کردن یک UI جایگزین هنگام بروز خطا.

لاگ خطاها:

ذخیره‌سازی و ارسال لاگ خطاها به سرویس‌هایی مانند Sentry می‌تواند به شما در رفع مشکلات سمت سرور کمک کند.

مدیریت خطاهای خارج از Error Boundaries نیازمند استفاده از روش‌های مستقیم‌تر مانند try-catch، Promise Handling، یا استفاده از ابزارهای SSR-specific است. با این روش‌ها، می‌توانید اطمینان حاصل کنید که تمام سناریوهای بالقوه خطا در اپلیکیشن به درستی مدیریت می‌شوند و تجربه کاربری به حد مطلوبی حفظ می‌شود.

 

ابزارها و روش‌های تکمیلی برای مدیریت خطا در ری اکت

1. استفاده از کتابخانه‌های آماده

کتابخانه‌های مدیریت خطا ابزارهای پیشرفته‌ای برای ردیابی، گزارش‌گیری و مانیتورینگ خطاها ارائه می‌دهند. برخی از محبوب‌ترین کتابخانه‌ها عبارت‌اند از:

Sentry

یک ابزار قدرتمند برای ثبت و مانیتور کردن خطاها. امکانات Sentry شامل:

  • ردیابی خطاها با ارائه اطلاعات دقیق (مانند Stack Trace و متغیرهای محیطی).
  • تشخیص خطاهای تکراری و گروه‌بندی آنها.
  • مانیتورینگ عملکرد برای شناسایی مشکلات مرتبط با کارایی.
  • ادغام آسان با ری‌ اکت از طریق یک SDK ساده:
import * as Sentry from "@sentry/react";

Sentry.init({
  dsn: "https://your-dsn-link",
});

Bugsnag

یک ابزار دیگر برای مدیریت خطاها که قابلیت‌های مشابهی با Sentry ارائه می‌دهد. Bugsnag همچنین امکان اولویت‌بندی خطاها و ارائه گزارشات بلادرنگ را فراهم می‌کند.

LogRocket

این ابزار علاوه بر مدیریت خطا، قابلیت‌های مانیتورینگ کاربران را نیز فراهم می‌کند. LogRocket می‌تواند ویدئوهایی از رفتار کاربران ضبط کرده و اطلاعات خطا را با رفتار دقیق کاربر مرتبط کند.

2. لاگ‌گیری خطاها و ارسال به ابزارهای مانیتورینگ

یکی از روش‌های تکمیلی مدیریت خطا، ذخیره لاگ‌ها و ارسال آنها به ابزارهای مانیتورینگ است. این کار به شما کمک می‌کند تا اطلاعات دقیق‌تری از خطاهای رخ‌داده داشته باشید:

استفاده از ابزارهای لاگ‌ گیری

  • Logstash: برای جمع‌آوری و پردازش لاگ‌ها.
  • Graylog: ابزاری برای تجزیه و تحلیل لاگ‌ها.
  • Elastic Stack (ELK): برای ذخیره و تجزیه و تحلیل داده‌های لاگ.

ارسال لاگ‌ها به ابزارهای مانیتورینگ

لاگ‌های جمع‌آوری‌شده را می‌توانید به سرویس‌های مانیتورینگ مانند New Relic یا Datadog ارسال کنید. این سرویس‌ها به شما امکان می‌دهند تا مشکلات را در زمان واقعی ردیابی کنید.

3. مدیریت خطاها در Redux یا Context API

مدیریت خطاها در ابزارهای مدیریت state مانند Redux یا Context API می‌تواند یک رویکرد سازمان‌یافته برای مدیریت خطاها باشد.

مدیریت خطاها در Redux

در اپلیکیشن‌هایی که از Redux برای مدیریت state استفاده می‌کنند، می‌توانید خطاها را در Reducers یا Middleware مدیریت کنید:

  • در Reducer ها:
const errorReducer = (state = null, action) => {
  switch (action.type) {
    case "ERROR_OCCURRED":
      return action.payload;
    case "CLEAR_ERROR":
      return null;
    default:
      return state;
  }
};
  • در Middleware ها:

نوشتن Middleware سفارشی برای ثبت خطاها:

const errorLogger = (store) => (next) => (action) => {
  try {
    return next(action);
  } catch (error) {
    console.error("Caught error:", error);
    throw error;
  }
};

مدیریت خطاها در Context API

در Context API می‌توانید یک Context جداگانه برای مدیریت خطاها تعریف کرده و خطاها را در سطح کل برنامه مدیریت کنید:

const ErrorContext = React.createContext();

const ErrorProvider = ({ children }) => {
  const [error, setError] = React.useState(null);

  const handleError = (error) => {
    setError(error);
    console.error("Context Error:", error);
  };

  return (
    <ErrorContext.Provider value={{ error, handleError }}>
      {children}
    </ErrorContext.Provider>
  );
};

استفاده از ابزارهای پیشرفته مانند Sentry و Bugsnag، همراه با لاگ‌گیری ساختاریافته و مدیریت خطاها در ابزارهای state management، رویکردی جامع برای مدیریت خطاها ارائه می‌دهد. این تکنیک‌ها به شما کمک می‌کنند تا مشکلات را به سرعت شناسایی و برطرف کنید و تجربه کاربری بهتری ارائه دهید.

 

نکات پیشرفته برای مدیریت خطاها در ری‌ اکت

  1. ایجاد پیام‌های خطای کاربرپسند

یکی از جنبه‌های مهم مدیریت خطا، نحوه نمایش پیام‌های خطا به کاربران است. پیام‌های خطای مؤثر و کاربرپسند می‌توانند تجربه کاربری را بهبود بخشند و از سردرگمی کاربران جلوگیری کنند:

  • شفافیت: پیام‌های خطا باید ساده و به زبان کاربر باشند. به جای اصطلاحات فنی، توضیحات روشنی ارائه دهید.
    مثال:

    • نامناسب: Unhandled exception occurred in the application.
    • مناسب: متأسفیم، مشکلی پیش آمده است. لطفاً بعداً دوباره امتحان کنید.
  • ارائه راه‌حل: در صورت امکان، راهنمایی لازم برای رفع مشکل را ارائه دهید. مثلاً:
    • “در صورت بروز این خطا، اینترنت خود را بررسی کرده و صفحه را دوباره بارگذاری کنید.”
  • طراحی بصری: استفاده از پیام‌های خطا با طراحی جذاب (مانند استفاده از آیکون‌ها و رنگ‌های مناسب) می‌تواند تجربه کاربر را بهبود دهد.
  1. محدود کردن عمق و تعداد کامپوننت‌های Error Boundary

استفاده مؤثر از Error Boundaries نیازمند توجه به ساختار کامپوننت‌ها است:

  • محدود کردن عمق: Error Boundaries نباید در تمام سطوح اپلیکیشن تکرار شوند. برای جلوگیری از پیچیدگی، تنها در نقاط کلیدی (مانند صفحات اصلی یا کامپوننت‌های حیاتی) از آنها استفاده کنید.
  • تفکیک وظایف: در صورت نیاز به چندین Error Boundary، آنها را بر اساس نقش و وظیفه هر بخش تفکیک کنید. برای مثال:
    • یک Error Boundary برای مدیریت خطاهای مرتبط با فرم‌ها.
    • یک Error Boundary دیگر برای مدیریت خطاهای مربوط به بارگذاری داده‌ها.

این روش باعث می‌شود که خطاهای بخش‌های مختلف به صورت جداگانه مدیریت شوند و از تداخل در نمایش پیام‌ها جلوگیری شود.

  1. استفاده از رویکردهای پیشگیرانه

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

تست‌های جامع

اجرای تست‌های گسترده در مراحل توسعه به شناسایی زودهنگام مشکلات کمک می‌کند:

  • تست واحد (Unit Testing): برای اطمینان از عملکرد صحیح توابع و ماژول‌های جداگانه.
  • تست یکپارچگی (Integration Testing): بررسی تعامل بین کامپوننت‌ها.
  • تست سرتاسری (End-to-End Testing): شبیه‌سازی تجربه کاربر و بررسی کل سیستم.

Code Review

بررسی کدها توسط اعضای تیم می‌تواند اشتباهات رایج را کاهش دهد و کیفیت کد را بهبود بخشد.

Static Analysis Tools

ابزارهایی مانند ESLint و Prettier می‌توانند به شناسایی مشکلات و استانداردسازی کد کمک کنند.

نظارت مداوم (Monitoring)

استفاده از ابزارهای مانیتورینگ مانند Sentry یا Datadog برای شناسایی و بررسی خطاهای بلادرنگ، امکان پیشگیری از بروز مشکلات بزرگ‌تر را فراهم می‌کند.

  1. توصیه‌های کلی برای پروژه‌های واقعی

  • مستندسازی فرآیندها: مستندسازی رفتارهای مورد انتظار برای خطاها و نحوه مدیریت آنها، از تکرار مشکلات جلوگیری می‌کند.
  • آزمایش در شرایط واقعی: اجرای پروژه در محیط‌های شبیه‌سازی‌شده به تولید، به شناسایی خطاهایی که فقط در شرایط واقعی ظاهر می‌شوند، کمک می‌کند.
  • مدیریت مناسب Log‌ها: ذخیره لاگ‌های خطاها و استفاده از ابزارهای مناسب برای نظارت و تجزیه‌وتحلیل آنها ضروری است.
  • تیم‌محور بودن فرآیندها: اطمینان حاصل کنید که تمامی اعضای تیم توسعه‌دهنده با سیستم مدیریت خطا آشنا هستند و می‌توانند آن را به درستی پیاده‌سازی و نگهداری کنند.
  • سازگاری با مقیاس: استراتژی مدیریت خطا باید قابلیت تطبیق با رشد و مقیاس اپلیکیشن را داشته باشد.

این نکات پیشرفته با تمرکز بر پیام‌های کاربرپسند، ساختاردهی مؤثر به Error Boundaries، و استفاده از رویکردهای پیشگیرانه، به بهبود مدیریت خطاها در اپلیکیشن‌های ری‌ اکت کمک می‌کنند. این روش‌ها می‌توانند تأثیر مثبتی بر تجربه کاربری، کاهش خطاهای بحرانی، و بهبود قابلیت نگهداری اپلیکیشن داشته باشند.

 

جمع بندی:

مدیریت خطاها در ری‌ اکت شامل ترکیب تکنیک‌های پیشرفته، ابزارهای مناسب و استراتژی‌های دقیق برای تضمین پایداری و قابلیت نگهداری اپلیکیشن است. از Error Boundaries برای خطاهای کامپوننتی گرفته تا استفاده از ابزارهایی مانند Sentry و رویکردهای پیشگیرانه مانند تست‌های جامع، همه این موارد به تیم‌های توسعه کمک می‌کنند تا اپلیکیشنی با عملکرد بهتر و تجربه کاربری عالی ارائه دهند. اجرای این استراتژی‌ها نه‌تنها احتمال وقوع خطا را کاهش می‌دهد بلکه به مدیریت سریع و موثر مشکلات پیش‌آمده کمک می‌کند.

 

مطالعه بیشتر در رفرنس های خارجی:

Error Boundaries (reactjs.org)

React.js Error Boundaries (geeksforgeeks.org)

لیست کامل مقالات ” ری اکت ” ویکس سِوِن در لینک زیر :

ری اکت چیست؟