نودجیاس یکی از محبوبترین تکنولوژیهای سمت سرور میباشد که در سالهای اخیر درخواست نیرو برای این تکنولوژی بسیار بالا رفته است. توی این پست در مورد هشت مهارت ضروری که هر توسعه دهنده نودجیاس باید داشته باشه، صحبت میکنیم.
زمانی که شروع به یادگیری یک تکنولوژی میکنید، سعی کنید نحوه کار اون تکنولوژی رو درک کنید و خیلی زود سراغ فریمورکها یا ابزارهای اون تکنولوژی نرید. همچنین باید با ماژولهای مهم و کاربردی نودجیاس کار کرده باشید. از جمله ماژولهای: Buffer، Events، File system، HTTP، OS، Path، Process، Stream و ...
استفاده از فریمورکها باعث میشه که خیلی از کارها رو خودمون از صفر ننویسیم و از کدهای آماده اون فریمورک استفاده کنیم. یکی از محبوب ترین فریمورکهای نودجیاس، express هست. فریمورک express خیلی سریع و مینیمال هستش که کلی پکیج برای این فریمورک نوشته شده که میتونیم توی پروژههای خودمون استفاده کنیم.
امنیت در وب همیشه یه مورد خیلی مهم برای وبسایتها و وب اپلیکیشنها بوده. ریسکهای امنیتی متعددی وجود داره از جمله: Injection، XXE، BAC، XSS و ... که باید به صورت عمیق یادشون بگیرید.
با نحوه احراز هویت امن آشنا بشید. passport یک میانافزار محبوب برای احراز هویت با طرحهای مختلف هستش که میتونید ازش استفاده کنید.
همچنین با نحوه رمزگذاری در bcrypt که نام یک الگوریتم هشینگ هست آشنا بشید. برای این کار یک پکیجی در npm وجود داره به همین اسم bcrypt که این کارو براتون انجام میده.
ضمنا دستور npm audit
نیازمندیهای پروژه را از نظر آسیبپذیریِ امنیتی (security vulnerability) بررسی و ارزیابی میکند و اگر مشکلی وجود داشت، اون رو گزارش میده.
اگرچه عمدهای از کار یک توسعه دهنده نودجیاس در بکاند هست اما بعضی مواقع ممکنه پیش میاد که نیاز باشه یک سری تغییرات فرانت رو هم انجام بدید. یا کلا شما باید با فرانت آشنا باشید و بدونید که توی فرانت هم چه اتفاقاتی میافته. سه زبان اصلی در فرانتاند وجود داره که باید یاد بگیرید. HTML و CSS و JavaScript. همچنین فریمورکهایی برای جاوااسکریپت ساخته شدن که فرایند ساخت یک وبسایت یا وب اپلیکیشن رو سادهتر میکنن. فریمورکها یا کتابخونههایی مثل React و Vuejs
کدهای نودجیاس شما برای ساخت یک وب اپلیکیشن کافی نیست و باید یک پایگاه داده برای ذخیره اطلاعات داشته باشید. گزینههای زیادی برای پایگاه دادهها وجود داره اما اغلب بهترین راه برای تعامل اونها در نودجیاس استفاده از ORM ها هستش.
یکی از گزینههای محبوب Sequelize هست که به شما یک API ثابت میده تا بدون توجه به نوع پایگاه داده SQL که به اون متصل شدید، ارتباط برقرار کنید. حتی شما میتونید در صورت نیاز خیلی ساده پایگاه دادتون رو عوض کنید. این فوق العادس.
اگر گزینه NoSQL رو ترجیح میدید، Mongoose یک ODM برای MongoDB هست. اینجا شما باید براساس نوع پروژتون پایگاه داده مناسب رو انتخاب کنید.
برای مدیریت کردن پکیجها در نودجیاس ما دو ابزار داریم. یکی npm و یکی هم yarn که yarn یک سری قابلیتهای جالبی داره مثل: حالت آفلاین، عملکرد شبکه، حالت ارتجاعی شبکه، استفاده از ایموجیها در کنسول که از هر کدوم که دوست داشتید میتونید استفاده کنید.
شما نمیخواید وب اپلیکیشن خودتون رو از سیستم شخصیتون ارائه بدید، پس بهتره با یک پلتفرم ابری که میتونه در اون مستقر کنید راحت بشید. اسمهای بزرگ همیشه گزینههای خوبی هستن، مثل AWS یا Azure، اما بعضی وقتا ممکنه پیکربندی زیرساخت بیشتری نسبت به آنچه که میخواید با اون برخورد کنید، نیاز داشته باشه. خیلی از ارائه دهندگان ابری کوچکتر، خودشون رو با یک تجربه راحت توسعه دهنده سازگار میکنن. در حال حاضر، Heroku و Netlify تنها تعدادی از گزینه های زیادی هستن که میتونید برنامههای نودجیاس تون رو به راحتی روی پلتفرم ابری مستقر کنید.
هر برنامه نویسی باید کار با سورس کنترل رو بلد باشه، اونم سورس کنترل گیت. گیت یک سورس کنترل رایگان و منبع باز هست که همه ازش استفاده میکنن. به عنوان یه برنامه نویس باید به صورت حرفهای این ابزار رو یاد بگیرید. با دستورات مهم این ابزار مثل: commit، checkout، merge، push، pull، و ... آشنا بشید.
خلاصه سعی کنید توی هر کدوم از این موارد متخصص بشید و یک زمانی رو برای یادگیری هر کدوم در نظر بگیرید. برای برنامه ریزی هم میتونید به این شکل عمل کنید. مثلا سه ماه رو در نظر بگیرید، توی این سه ماه یک موضوع رو به صورت عمیق یادبگیرید و یک موضوع هم به صورت سطحی. برای مثال من در فصل پاییز تمرکز اصلیم رو روی نودجیاس میذارم و یک نیم نگاهی هم به دیتابیسها میندازم و توی این مدت در موردشون مطالعه میکنم.