1. المٌقدمة الأولي :دورة إختبار ثغرات حقن قواعد البيانات SQLI الإحترافية لعام 2017 عام 2018
    تٌعد ثغرات حقن قواعد البينات الثغرة رقم واحد فى العالم والمصنفة تحت بند الإخطر
    والفريق التابع له بإختراق أكبر المواقع الصهيونية قرائة الموضوع
  2. المٌقدمة الثانية : دورة إختبار ثغرات حقن قواعد البيانات SQLI الإحترافية لعام 2017 عام 2018
    في هذه المٌثقدمة الثانية والأخيرة سوف نتعرف على قواعد علم حقن قواعد البيانات
    حتى يتثنى لنا علم يٌساعدنا على القيام بعمليات الحقن بالطرق الصحيحه قرائة الموضوع
  3. دورة كشف دمج والتلغيم حصريا على أرض عراق تيم(2017)
    بعد ماقمت بعمل دورة الكشف دمج والتلغيم وستكملت الدوره وتحتوي على 12 درس
    كانت دروس حصريا على عراق تيم وشرح واضح جدا ومفهوم الى المبتدأ والى المبدع قرائة الموضوع

Net Dynamic API Call - شرح مبسط

الموضوع في 'حماية الأجهزة' بواسطة unCoder, بتاريخ ‏23 مارس 2013.

كاتب الموضوع : unCoder المشاهدات : 616 الردود : 0 ‏23 مارس 2013
حالة الموضوع:
مغلق
  1. غير متصل

    unCoder
    rank
    Developer

    عضو منذ:
    ‏3 ديسمبر 2012
    عدد المشاركات:
    الإعجابات المتلقاة:
    0
    نقاط الجائزة:
    الإقامة:

    [​IMG]

    DotNet Dynamic API Invoking

    الموضوع في البداية قصير وسلس وكل مايوجد به هو معلومة واحدة أتمتى أن اوصلها
    بطريقة سهلة

    كما نعلم فأن الـ apis عندما نقوم بإستخدامها اول عمل لود لها في الكود فستكون واضحة جدا كما إنها ستحمل بالإمبورت تيبل ممايساعد الحمايات على كشفنا
    الغرض من الموضوع ليس تخطي الحمايات لكن الطريقة مفيدة أيضا من هذه الناحية

    في هذه الطريقة سنقوم بإستخدام الطريقة الداينميكية للإستدعاء وهي الطريقة اللتي يتم عملها في الرن تايم أي والبرنامج يعمل فنبتعد عن الشبهات




    [​IMG]


    أولا يجب أن نحمل كلاس الـ

    [ System.Runtime.InteropServices ]

    ثم نحدد الـ api اللذي نريد إستدعائه ونعرف البروتو تايب الخاص به على شكل
    function delegate

    في هذا المثال سأختار دالة Beep

    كود PHP:
    Public Delegate Function bep(ByVal dwFreq As UIntegerByVal dwDuration As UInteger) As Boolean
    ثم نحتاج لجلب أدرس الدالة عن طريق الدالة GetProcAddress
    وجلب عنوان المكتبة ايضا عن طريق LoadLibraryA

    نحتاج لتعريف هذه الدوال أولا

    كود PHP:
        <DllImport("kernel32.dll"SetLastError:=True)> _
        
    Private Shared Function GetProcAddress(ByVal hModule As IntPtrByVal procName As String) As UIntPtr
        End 
    Function
        <
    DllImport("kernel32.dll"SetLastError:=True)> _
        
    Public Shared Function LoadLibrary(ByVal lpFileName As String) As IntPtr
      
        End 
    Function
    ثم نجلب نضع بوينتر لادرس الدالة في الديليجيت اللذي قمنا بتعريفه سابقا للدالة
    ثم نقوم بعمل الداينميك إنفوك ونضع فيه البارمترات

    كود PHP:
            Dim _AP As bep
            _AP 
    Marshal.GetDelegateForFunctionPointer(haddrGetType(bep))
            
    _AP.DynamicInvoke(CType(1000UInteger), CType(1000UInteger))
    الكود كامل

    VB.NET

    كود PHP:
       Public Delegate Function bep(ByVal dwFreq As UIntegerByVal dwDuration As UInteger) As Boolean

        
    <DllImport("kernel32.dll"SetLastError:=True)> _
        
    Private Shared Function GetProcAddress(ByVal hModule As IntPtrByVal procName As String) As UIntPtr
        End 
    Function
        <
    DllImport("kernel32.dll"SetLastError:=True)> _
        
    Public Shared Function LoadLibrary(ByVal lpFileName As String) As IntPtr
        End 
    Function

        Public Function 
    Inv0ke()
            
    Dim haddr As Integer GetProcAddress(LoadLibrary("kernel32"), "Beep")

            
    Dim _AP As bep
            _AP 
    Marshal.GetDelegateForFunctionPointer(haddrGetType(bep))
            
    _AP.DynamicInvoke(CType(1000UInteger), CType(1000UInteger))

        
    End Function
    c#

    كود PHP:
    [DllImport("kernel32"CharSet CharSet.AnsiExactSpelling trueSetLastError true)]
         static 
    extern IntPtr GetProcAddress(IntPtr hModulestring procName);

        [
    DllImport("kernel32"SetLastError=trueCharSet CharSet.Unicode)]
        static 
    extern IntPtr LoadLibrary(string lpFileName);


            public 
    delegate bool bep(uint dwFrequint dwDuratio);


            
    void inv0ke()
            {
                
    IntPtr hAddr GetProcAddress(LoadLibrary("kernel32"), "Beep");

                
    bep xx = (bep)Marshal.GetDelegateForFunctionPointer(hAddr,typeof(bep));
                
    xx.DynamicInvoke((uint)1000, (uint)1000);
                
            }
    [​IMG]

    أتمنى أن ينال الشرح على إعجابكم ويفيدكم الموضوع

    والسلام عليكم ورحمة الله وبركاته

     


    جاري تحميل الصفحة...
الوسوم:
حالة الموضوع:
مغلق

مشاركة هذه الصفحة

جاري تحميل الصفحة...