تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
اريد طريقة الغاء البرنامج بعد وقت محدد
#1
السلام عليكم


شباب انا عاوز طريقة انه البرنامج ينلغي بعد فتره


اوضح اكثر

انا عندي برنامج

سويته اليوم ابيه بعد 5 ايام يتقفل نهائي ويجيني مسج بوكس يقول لي تم الغاء البرنامج



وشكرا


ارجو الرد
الرد }}}}
تم الشكر بواسطة:
#2
رد يا اخوان
الرد }}}}
تم الشكر بواسطة:
#3
إقتباس : Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click
'اولا يتم عمل ملف فى نسخة الويندوز ويتم قراءة هذا الكود بهذة الطريقة

Dim KeyName As String = "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion"
Dim valueName As String = "manduh"
Dim inwin1 As String = "in"
Dim Value As Object = inwin
inwin = Registry.GetValue(KeyName, valueName, Value.ToString())
'اذا لم يكن هناك ملف فىالنسخة يتم الاتى
If inwin = "" Then
'هنا تم عمل تاريخ نهاية النسخة بعد 15يوما
Dim MpTryApi As String = Now.AddDays(15D)
'تم عمل جدول فى قاعدة البيانات يتم تخزين فية التاريخ
Dim datess As String
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
Dim da1 As New OleDbDataAdapter("SELECT * from testing_pro where (id=1) ", DataAccess.con)
Dim dt1 As New DataTable
da1.Fill(dt1)
datess = dt1.Rows(0).Item("datess").ToString
DataAccess.con.Close()

'تم استعراض التاريخ الموجود فى قاعدة البيانات
'وعند عمل قادة البيانات يتم عمل اول صف ويشمل على خانة التاريخ خالية
'فى حالة ان التاريخ يكون فارغ يتم الاتى
If datess = "" Then
'فى حالة انه فارغ يتم اضافة تاريخ اليوم وهذا التاريخ عندما يتم تشغيل البرنامج الاول مرة

Dim idtest As String = "1"
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
DataAccess.cmd.Connection = DataAccess.con
DataAccess.cmd.CommandText = "UPDATE testing_pro SET datess='" & datenaw & "' WHERE id=" & idtest
DataAccess.cmd.ExecuteNonQuery()
DataAccess.con.Close()
'فى حالة ان التاريخ موجود يكون استخدم البرنام من قبل
'يتم اضافة سطر جديد
ElseIf datess >= Date.Today.ToString("yyyy/MM/dd") Then

If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
DataAccess.cmd.Connection = DataAccess.con
DataAccess.cmd.CommandText = "INSERT INTO testing_pro( datess)" & _
" VALUES ( '" & datenaw & "')"
DataAccess.cmd.ExecuteNonQuery()
DataAccess.con.Close()
'بعد ذلك يتم احتساب عدد الايام المستخدمة للبرنامج عن طريق حساب عدد الايام من التواريخ الموجود فى قاعدة البيانات
Dim dateend As DateTime
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If

Dim da2 As New OleDbDataAdapter("SELECT * from testing_pro order by id ", DataAccess.con)
Dim dt2 As New DataTable
da2.Fill(dt2)
dateend = dt2.Rows(0).Item("datess").ToString
DataAccess.con.Close()

Dim danew As Integer

danew = DateDiff(DateInterval.Day, CDate(dateend), CDate(datenaw))
'فى حالة ان عدد الايام 15 ايام يتم الاتى

If danew = "15" Then
'ويتم هنا اضافة قيمة فى نسخة الويندوز
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Return
'فى حالة ان عدد الايام أكبر 16 ايام يتم الاتى

ElseIf danew > "16" Then
'ويتم هنا اضافة قيمة فى نسخة الويندوز
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Return
' عندما يقوم العميل بتغيير التاريخ الى اقل من التاريخ الاول يتم الاتى

ElseIf danew < "0" Then
'ويتم هنا اضافة قيمة فى نسخة الويندوز
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Return
ElseIf danew < "15" Then
'الان يجد البرنامج ان عدد الايام اقل من 15 يوما
'واجهتى مشكلة هنا انه عندما يقوم العميل باعادة تغير التاريخ قبل تشغيل البرنامج
'يستطيع تشغيل البرنامج اكثر من 15 يوما
'تم هنا الحماية ايضا عن طريق عدد مرات تشغيل البرنامج
'من خلال احتساب عدد مراة العمل الافتراضية للبرنامج

Dim countdate As Integer = "0"
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
Dim da3 As New OleDbDataAdapter("SELECT COUNT(datess) AS datess FROM testing_pro ", DataAccess.con)
Dim dt3 As New DataTable
da3.Fill(dt3)
countdate = dt3.Rows(0).Item("datess").ToString
DataAccess.con.Close()
'تم احتساب مجموع عمليات الدخول على البرنامج من خلال جمع عدد التاوريخ الموجود فى قاعدة البيانات

'وليكون عدد الدخول على البرنامج 3مرات فى اليوم يكون المجموع مرات الدخول اسناء الفترة التجريبية 45مرة

If countdate = "45" Then
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Application.Exit()
ElseIf countdate < "30" Then
MsgBox(countdate)
Form1.Show()
Me.Hide()
End If
End If

End If
lodeng.Close()
ElseIf inwin = "Micros" Then
MsgBox(" عفوا تم استخدام النسخة التجريبية من قبل")
Application.Exit()

End If
End Sub

ملحوظة :-
الرد }}}}
تم الشكر بواسطة: السحاب
#4
(24-05-14, 10:13 PM)alktab كتب :
إقتباس : Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click
'اولا يتم عمل ملف فى نسخة الويندوز ويتم قراءة هذا الكود بهذة الطريقة

Dim KeyName As String = "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion"
Dim valueName As String = "manduh"
Dim inwin1 As String = "in"
Dim Value As Object = inwin
inwin = Registry.GetValue(KeyName, valueName, Value.ToString())
'اذا لم يكن هناك ملف فىالنسخة يتم الاتى
If inwin = "" Then
'هنا تم عمل تاريخ نهاية النسخة بعد 15يوما
Dim MpTryApi As String = Now.AddDays(15D)
'تم عمل جدول فى قاعدة البيانات يتم تخزين فية التاريخ
Dim datess As String
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
Dim da1 As New OleDbDataAdapter("SELECT * from testing_pro where (id=1) ", DataAccess.con)
Dim dt1 As New DataTable
da1.Fill(dt1)
datess = dt1.Rows(0).Item("datess").ToString
DataAccess.con.Close()

'تم استعراض التاريخ الموجود فى قاعدة البيانات
'وعند عمل قادة البيانات يتم عمل اول صف ويشمل على خانة التاريخ خالية
'فى حالة ان التاريخ يكون فارغ يتم الاتى
If datess = "" Then
'فى حالة انه فارغ يتم اضافة تاريخ اليوم وهذا التاريخ عندما يتم تشغيل البرنامج الاول مرة

Dim idtest As String = "1"
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
DataAccess.cmd.Connection = DataAccess.con
DataAccess.cmd.CommandText = "UPDATE testing_pro SET datess='" & datenaw & "' WHERE id=" & idtest
DataAccess.cmd.ExecuteNonQuery()
DataAccess.con.Close()
'فى حالة ان التاريخ موجود يكون استخدم البرنام من قبل
'يتم اضافة سطر جديد
ElseIf datess >= Date.Today.ToString("yyyy/MM/dd") Then

If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
DataAccess.cmd.Connection = DataAccess.con
DataAccess.cmd.CommandText = "INSERT INTO testing_pro( datess)" & _
" VALUES ( '" & datenaw & "')"
DataAccess.cmd.ExecuteNonQuery()
DataAccess.con.Close()
'بعد ذلك يتم احتساب عدد الايام المستخدمة للبرنامج عن طريق حساب عدد الايام من التواريخ الموجود فى قاعدة البيانات
Dim dateend As DateTime
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If

Dim da2 As New OleDbDataAdapter("SELECT * from testing_pro order by id ", DataAccess.con)
Dim dt2 As New DataTable
da2.Fill(dt2)
dateend = dt2.Rows(0).Item("datess").ToString
DataAccess.con.Close()

Dim danew As Integer

danew = DateDiff(DateInterval.Day, CDate(dateend), CDate(datenaw))
'فى حالة ان عدد الايام 15 ايام يتم الاتى

If danew = "15" Then
'ويتم هنا اضافة قيمة فى نسخة الويندوز
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Return
'فى حالة ان عدد الايام أكبر 16 ايام يتم الاتى

ElseIf danew > "16" Then
'ويتم هنا اضافة قيمة فى نسخة الويندوز
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Return
' عندما يقوم العميل بتغيير التاريخ الى اقل من التاريخ الاول يتم الاتى

ElseIf danew < "0" Then
'ويتم هنا اضافة قيمة فى نسخة الويندوز
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Return
ElseIf danew < "15" Then
'الان يجد البرنامج ان عدد الايام اقل من 15 يوما
'واجهتى مشكلة هنا انه عندما يقوم العميل باعادة تغير التاريخ قبل تشغيل البرنامج
'يستطيع تشغيل البرنامج اكثر من 15 يوما
'تم هنا الحماية ايضا عن طريق عدد مرات تشغيل البرنامج
'من خلال احتساب عدد مراة العمل الافتراضية للبرنامج

Dim countdate As Integer = "0"
If Not DataAccess.con.State = ConnectionState.Open Then
DataAccess.con.Open()
End If
Dim da3 As New OleDbDataAdapter("SELECT COUNT(datess) AS datess FROM testing_pro ", DataAccess.con)
Dim dt3 As New DataTable
da3.Fill(dt3)
countdate = dt3.Rows(0).Item("datess").ToString
DataAccess.con.Close()
'تم احتساب مجموع عمليات الدخول على البرنامج من خلال جمع عدد التاوريخ الموجود فى قاعدة البيانات

'وليكون عدد الدخول على البرنامج 3مرات فى اليوم يكون المجموع مرات الدخول اسناء الفترة التجريبية 45مرة

If countdate = "45" Then
Value = inwin1
Registry.SetValue(KeyName, valueName, Value)
MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
Application.Exit()
ElseIf countdate < "30" Then
MsgBox(countdate)
Form1.Show()
Me.Hide()
End If
End If

End If
lodeng.Close()
ElseIf inwin = "Micros" Then
MsgBox(" عفوا تم استخدام النسخة التجريبية من قبل")
Application.Exit()

End If
End Sub

ملحوظة :-



بسم الله الرحمان الرحيم

الله يزيدك علم انشاء الله


بس حاي اسال الحين هذا الكود احطه في الفورم لود ام ان احطه في مكان ثاني

وثاني شي هل انسخ الكود كما هو او اشيل الكلام العربي الي فيه ولو تقدر اخوي صمم ليه على 7 ايام وعطني الكود جاهز اذا ما عليك امر وشكرا
الرد }}}}
تم الشكر بواسطة:
#5
تفضل هذا كود اسهل من السابق

ادرج المكتبة
إقتباس :Imports Microsoft.Win32

ومن ثم ضع هذا الكود في اللود او البتن المهم يجب تفعيله عند تشغيل البرنامج !

إقتباس : Dim regKey As String

regKey = My.Computer.Registry.GetValue("HKEY_CURRENT_USER\MyAppvBsQ", "TRI", Nothing)

If (regKey Is Nothing) Then

Dim MpTryApi As String = Now.AddDays(30D)
My.Computer.Registry.SetValue("HKEY_CURRENT_USER\MyAppvBsQ", "TRI", MpTryApi)

ElseIf regKey = Date.Now Then

MsgBox("انتهت الفترة التجريبية للبرنامج")
Me.Close()
End If

ويتم التحكم بالايام من خلال هذا الكود

Dim MpTryApi As String = Now.AddDays(30D)

لاحظ اللون الاحمر هذا عدد الايام ويمكن تعديلها للفترة التي تريدها

الكود يقوم بحفظ تاريخ استخدام البرنامج وإذا قضت الفترة المحددة يتوقف عن العمل
الرد }}}}
تم الشكر بواسطة: ماستر
#6
إقتباس :مرحبتين تلاته
إلى : alktab
السلام عليكم
اخى الكريم
كيف تقوم باادراج هذه المكتبه بالظبط لانى مبتدأ
http://vb4arb.com/vb/thread-2997.html

تفضل

الرد }}}}
تم الشكر بواسطة: aftfm , ماستر , الشاكي لله
#7
وهذا كود آخر
منقول


كود :
Dim T As Boolean
    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        T = False
        Dim RegX As Microsoft.Win32.RegistryKey
        RegX = Microsoft.Win32.Registry.CurrentUser

        Dim S As String() = RegX.GetSubKeyNames
        For Each A As String In S
            If A = "smp3" Then
                T = True
            End If
        Next
        If T = True Then RegX = Microsoft.Win32.Registry.CurrentUser.OpenSubKey("smp3", True)
        Dim x As Integer = RegX.GetValue("val")
        x = x + 1
        RegX.SetValue("val", x)
        If x = 5 Or x > 5 Then
            MsgBox("لقد انتهت مدتك لاستخدام البرنامج , يرجى الاتصال بفريق الدعم لمعرفة كيفية الشراء")
            Application.Exit()

        Else

            RegX = Microsoft.Win32.Registry.CurrentUser.CreateSubKey("smp3")
            RegX.SetValue("val", 1)
        End If

    End Sub
الرد }}}}
تم الشكر بواسطة: الشاكي لله
#8
(25-05-14, 08:32 PM)alktab كتب :
إقتباس :مرحبتين تلاته
إلى : alktab
السلام عليكم
اخى الكريم
كيف تقوم باادراج هذه المكتبه بالظبط لانى مبتدأ
http://vb4arb.com/vb/thread-2997.html

تفضل


اخوي للاسف ما يضبط الكود

كود :
Dim regKey As String

        regKey = My.Computer.Registry.GetValue("HKEY_CURRENT_USER\MyAppvBsQ", "TRI", Nothing)
        If (regKey Is Nothing) Then
            Dim MpTryApi As String = Now.AddSeconds(30S)
            My.Computer.Registry.SetValue("HKEY_CURRENT_USER\MyAppvBsQ", "TRI", MpTryApi)
        ElseIf regKey = Date.Now Then
            MsgBox("انتهت الفترة التجريبية للبرنامج")
            Me.Close()
        End If

لو تلاحض اني غيرات AddDays الى AddSeconds وحطيت بدال m حطيت s والكود طلع بدون اخطاء لاكن مافي مفعول وتاكدت من المكتبه ولا فاد وش الحل ضروري
الرد }}}}
تم الشكر بواسطة:
#9
أنصحك أن تبتعد عن استخدام الريجستري.....تماما
لأنه و غالبا .....هذا هو اول مكان يبحث فيه الهاكرز

هناك فكرة أفضل لحماية البرامج

و هي أن تستخدم ملف تحفظ فيه البيانات و هذا ما يفعله الجميع الأن

و النقطة الهامة هي :

أنك تنسخ من هذا الملف اكتر من نسخة في اكتر من مكان علي جهاز العميل

و هذه النسخ ستعمل بمثابة Shadow للنسخة الاصلية من الملف
و بالتالي تستطيع أن تتأكد أكثر من مرة أن برنامجك تم تفعيله بشكل جيد.
أو أن البرنامج صلاحيته قد انتهت و بالتالي تقوم بإغلاق البرنامج الخاص بك

أما بخصوص الصلاحية المؤقتة عليك أن تسترجع الوقت او التاريخ الذي تم فيه إنشاء Directory الذي سيكون فيه برنامجك
ثم تضيف له وقت معين أنت تحدده
فإن كان الوقت الاجمالي رقم معين يمكن حينها ان تفعل ما تشاء
إما تغلق البرنامج أو ترسل رسالة للمستخدم أو ما تراه مناسبا لك في حينها
الرد }}}}
تم الشكر بواسطة:
#10
(26-05-14, 01:16 PM)hassan كتب :
(25-05-14, 08:32 PM)alktab كتب :
إقتباس :مرحبتين تلاته
إلى : alktab
السلام عليكم
اخى الكريم
كيف تقوم باادراج هذه المكتبه بالظبط لانى مبتدأ
http://vb4arb.com/vb/thread-2997.html

تفضل


اخوي للاسف ما يضبط الكود

كود :
Dim regKey As String

        regKey = My.Computer.Registry.GetValue("HKEY_CURRENT_USER\MyAppvBsQ", "TRI", Nothing)
        If (regKey Is Nothing) Then
            Dim MpTryApi As String = Now.AddSeconds(30S)
            My.Computer.Registry.SetValue("HKEY_CURRENT_USER\MyAppvBsQ", "TRI", MpTryApi)
        ElseIf regKey = Date.Now Then
            MsgBox("انتهت الفترة التجريبية للبرنامج")
            Me.Close()
        End If

لو تلاحض اني غيرات AddDays الى AddSeconds وحطيت بدال m حطيت s والكود طلع بدون اخطاء لاكن مافي مفعول وتاكدت من المكتبه ولا فاد وش الحل ضروري

خطأ بسيط في المقارنة فقط هنا
E
إقتباس :lseIf regKey = Date.Now Then
بدله الى
إقتباس : ElseIf regKey > Now Then
وهو مقارنة التاريخ المسجل للبرنامج إذا وجده اكبر من تاريخ اليوم سوف ينهي عمل البرنامج

شاهد الشرح هنا
http://www.gulfup.com/?1B8MQh


المثال مرفق بعد التعديل


الملفات المرفقة
.rar   WindowsApplication1.rar (الحجم : 61.44 ك ب / التحميلات : 50)
الرد }}}}
تم الشكر بواسطة:


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  [سؤال] طريقة لقص صورة في الpictureBox1 CLARO 4 52 منذ 47 دقيقة مضت
آخر رد: ali.alfoly
  [سؤال] كيف اجعل البرنامج يحفظ بيانات؟ The Light Fire 9 108 منذ 1 ساعه مضت
آخر رد: ali.alfoly
  [نقاش] الى كل خبير ومبتدأ نقاش بخصوص جعل البرنامج نسخة تجريبية 0theghost0 1 149 30-11-16, 11:21 PM
آخر رد: awidan76
  [نقاش] اسئلكم بالله / تسعيرة هذا البرنامج مصمم على فيجول استديو 2013 عزف الخواطر 3 111 30-11-16, 06:42 PM
آخر رد: عزف الخواطر
  [سؤال] مشكلة في إعادة تنفيذ البرنامج wael khlak 1 52 21-11-16, 11:48 PM
آخر رد: السرور
  خطا عند تشغيل البرنامج makky 10 135 19-11-16, 03:17 AM
آخر رد: أبو عمر
  [سؤال] طريقة عمل كشف حساب (دائن ومدين) اليوم مبتدئة وغداً محترفة 11 330 14-11-16, 08:26 AM
آخر رد: Genius Live
  طريقة تحزيم التطبيق اليوم مبتدئة وغداً محترفة 1 117 12-11-16, 08:16 AM
آخر رد: اليوم مبتدئة وغداً محترفة
  [VB.NET] طلب تعديل ع الكود ليصبح البرنامج جاهزاً 3asfa~mdmra 8 190 12-11-16, 02:30 AM
آخر رد: 3asfa~mdmra
  [سؤال] حذف او تحميل ملف بمسار محدد Program KSA 3 114 10-11-16, 08:17 PM
آخر رد: أبو عمر

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم