نظارت بر فرآیندهای سیستم با استفاده از سی شارپ در ویندوز
برنامهنویسی سیستم یکی از جنبههای کلیدی توسعه نرمافزار است. در این مقاله، ما به بررسی یک برنامه کوچک نوشته شده در C# میپردازیم که به کاربر امکان میدهد.....
نظارت بر فرآیندهای سیستم با استفاده از سی شارپ در ویندوز
برنامهنویسی سیستم یکی از جنبههای کلیدی توسعه نرمافزار است. در این مقاله، ما به بررسی یک برنامه کوچک نوشته شده در C# میپردازیم که به کاربر امکان میدهد تمام فرآیندهای در حال اجرا در سیستم عامل ویندوز را لیست کند. این برنامه میتواند برای مدیریت سیستم، عیبیابی، یا حتی اهداف امنیتی مورد استفاده قرار گیرد.
کد نظارت بر فرآیندهای سیستم با استفاده از C# در ویندوز
using System;
using System.Diagnostics;
// Programmer: Ebrahim Shafiei (EbraSha)
class AbdalSecurityGroup
{
static void Main()
{
// List all running processes
foreach (Process process in Process.GetProcesses())
{
try
{
Console.WriteLine("Process: " + process.ProcessName + " ID: " + process.Id);
Console.WriteLine("Executable Path: " + process.MainModule.FileName);
Console.WriteLine("Executable ModuleName: " + process.MainModule.ModuleName);
Console.WriteLine("Executable BaseAddress: " + process.MainModule.BaseAddress);
}
catch (Exception e)
{
Console.WriteLine("Error accessing process details: " + e.Message);
}
}
Console.ReadLine();
}
}
توضیح کد فوق
این کد یک برنامه ساده در #C است که وظیفه آن فهرستبندی تمام فرآیندهای در حال اجرا در یک سیستم عامل ویندوز است. کلاس AbdalSecurityGroup
حاوی یک متد اصلی به نام Main
است که عملکرد اصلی برنامه را انجام میدهد.
در ابتدای این متد، یک حلقه foreach
استفاده شده است که بر روی تمام فرآیندهای در حال اجرا (بازیابی شده توسط Process.GetProcesses()
) اجرا میشود. برای هر فرآیند، کد سعی میکند اطلاعاتی مانند نام فرآیند (process.ProcessName
), شناسه فرآیند (process.Id
), مسیر اجرایی (process.MainModule.FileName
), نام ماژول اجرایی (process.MainModule.ModuleName
), و آدرس پایه اجرایی (process.MainModule.BaseAddress
) را چاپ کند.
در صورت بروز خطا در دسترسی به جزئیات فرآیند، یک بلاک catch
استفاده شده که پیغام خطا را چاپ میکند. این میتواند به دلایل امنیتی یا محدودیتهای دسترسی باشد. در نهایت، Console.ReadLine()
برای نگه داشتن پنجره کنسول تا زمانی که یک ورودی کاربر دریافت شود استفاده شده است.
این کد برای متخصصینی که درکی از برنامهنویسی #C و مدیریت فرآیندها در ویندوز دارند، مفید است و میتواند برای تشخیص و نظارت بر فرآیندهای در حال اجرا در سیستمهای تحت نظارت آنها استفاده شود.
دیدگاه های مربوط به این مقاله (برای ارسال دیدگاه در سایت حتما باید عضو باشید و پروفایل کاربری شما تکمیل شده باشد)