استراتيجيات لمنع إنشاء العمليات الفرعية بشكل فعال وإلغاء الأذونات (بايثون)


هل هناك أي طريقة فعالة لمنع العملية من إنتاج أطفال وإلغاء أذوناتها؟ أسعى إلى اتباع نهج قوي لمنع قدرة العملية تمامًا على إنشاء عمليات فرعية، وإذا أمكن، تقييد أذوناتها وإنهائها مع أطفالها. هل لديك أي اقتراحات أو استراتيجيات يمكن أن تكون فعالة لهذا الغرض؟

ما حاولت:

import psutil
import sys
import ctypes
import time<

def is_admin():
    try:
        return ctypes.windll.shell32.IsUserAnAdmin()
    except Exception as e:
        print(f'Error checking admin privileges: {e}')
        return False

def run_as_admin():
    try:
        ctypes.windll.shell32.ShellExecuteW(None, "runas", sys.executable, " ".join(sys.argv), None, 1)
    except Exception as e:
        print(f'Error restarting as administrator: {e}')
        sys.exit(1)

def block_child_creation(process_name):
    try:
        for process in psutil.process_iter(['pid', 'name']):
            if process.info['name'].lower() == process_name.lower():
                # Suspend the process
                process.suspend()
                print(f'The process with PID {process.pid} has been suspended.')

                # Terminate the process and its children
                for child in process.children(recursive=True):
                    child.kill()
                psutil.wait_procs(process.children(), timeout=5)
                process.kill()
                process.wait(5)
                print(f'The process with PID {process.pid} and its children have been terminated.')

                break  # No need to continue searching after blocking the process

        # Verificar novamente se o processo foi encerrado
        for process in psutil.process_iter(['pid', 'name']):
            if process.info['name'].lower() == process_name.lower():
                print(f'The process {process_name} is still running.')
            else:
                print(f'No process with the name {process_name}.')
                break
    except psutil.NoSuchProcess:
        print(f'No process with the name {process_name} found.')
    except Exception as e:
        print(f'An unexpected error occurred: {e}')

def main():
    try:
        if not is_admin():
            print("Restarting as administrator!")
            run_as_admin()

        global nome_processo
        nome_processo = input("Enter the name of the process you want to block and terminate with child creation: ")

        block_child_creation(nome_processo)

    except KeyboardInterrupt:
        print("\nTermination process interrupted by the user.")
    except Exception as e:
        print(f'An unexpected error occurred: {e}')

if __name__ == "__main__":
    main()

الحل 1

فكرة لا تجيب

في محاولة لمنع عملية من الإنشاء، يمكنك إما محاولة قتل جميع عملياتها الفرعية بشكل متكرر.
ملاحظة: أضف تأخيرًا حتى لا يحتوي جهاز الكمبيوتر الخاص بالمستخدم على شاشة الموت الزرقاء (شاشة الموت الزرقاء).

إذا لم ينجح ذلك أو كنت لا تزال تريد ترك بعض العمليات/العمليات الفرعية، فحاول:
تحاول معرفة الأشياء، يرجى الانتظار حتى تنتهي هذه الإجابة أو ربما شيء ما …

コメント

タイトルとURLをコピーしました