شـريـط الاهـداءات | |
قسم الشروحات و البرامج المستخدمة في عمل السيرفرات الخاصة [ قسم متخصص فى شروحات و البرامج في عمل السيرفرات الخاصة ] [ يرجى عدم وضع الأسئلة والاستفسارات في هذا القسم ] |
|
أدوات الموضوع | انواع عرض الموضوع |
20-03-2013, 10:52 AM | #1 | ||||||||||||
testing
|
بسم الله الرحمن الرحيم
طبعا كلنا عارفين ان مفيش حاجة آمنة 100% و أي حاجة عرضة للسرقة بس احنا بنعمل الأسباب و بنحاول اننا نمنع السرقة أو نصعبها. في نهاية الموضوع ده هنخلي الـ Password System بتاعك معقد أكتر من النظام الحالي بحيث ان لاقدر الله لو حد سرق الداتابيز بتاعتك مش هيقدر يطلع أي بيانات لأي أكونت ..يعني لو ما عملش بيها سيرفر هيبلها و يشرب ميتها. الصورة النهائية للي هنعملو : ملاحظة مهمة جدا : لازم تاخد نسخ احتياطية من الـ SRO_VT_ACCOUNT وملفات الموقع www أولا: لازم نعرف ايه اللي بيحصل لما تكتب الباسوورد و تيجي تخش الجيم.. انتا بتكتب الباسوورد عادي جدا..الـ GatewayServer بيحولها لـ MD5 Hash ( و دا نوع من أنواع التشفير) عشان يطابقها بالموجودة في الداتابيز ..لو مضبوطة يبقى المستخدم يخش..لو غلط يقولو غلط. عشان كده في خطوات عمل السيرفر بيقولك انك تكتب الباسوورد و تحطها في الموقع دا عفوا ,,, لايمكنك مشاهده الروابط لانك غير مسجل لدينا [ للتسجيل اضغط هنا ] و هيطلعلك Hash و هوا دا اللي تحطو في TB_User في الداتابيز.. --- ثانيا: لا قدر الله لو الداتابيز بتاعتك اتسرقت.. اللي أخدها بيعمل ايه؟ بالنسبة للـ Account Database مش هتفيده غير TB_User .. ببساطة هيخش على موقع زي دا : عفوا ,,, لايمكنك مشاهده الروابط لانك غير مسجل لدينا [ للتسجيل اضغط هنا ] و هتدخل الهاش اللي عندك و تعمله Decrypt زي الصورة كده : طبعا دي طريقة من الطرق اللي ممكن تفك بيها الـ MD5 ..القصد ان الـ MD5 دي ضعيفة جدا و ممكن أي حد يفكها. --- ثالثا: ايه نظام التشفير الجديد اللي هيتم في الموضوع ده؟ ببساطة هنشفر الباسوورد مرة تاني بحيث ان لو حد قدر يفك تشفير الباسوورد (و دا صعب جدا) هتطلعلو md5 hash ..يعني مش هتفيدو بحاجة و لازم يفك تشفير الـ MD5 عشان يعرف الباسوورد. نظام التشفير اللي هنعملوا اسمه SHA1 و دا أقوى من الـ MD5 بس زي ما قولت هيبقى فيه تشفير ثنائي..يعني كأنك عامل باسوورد من 30 حرف و رقم زي كده : كود:
d6df873a6b1bc0043cc0cec9d4aabeda --- رابعا : نبدأ الشرح : الحاجات اللي هنغيرها : -SQL Stored procedures -SQL TB_User design -PHP code الـ Stored procedures اللي مسؤولة عن الحوار ده اتنين : CertifyUser_ : خاصة بالـ SMC Login CertifyTB_User_ :خاصة بالـ Ingame Login ببساطة هنخش على CertifyUser_ و ندور على الحقول الخاص بالباسوورد : هنلاقيه انه szPassword@ هنضيف متغير جديد و نسميه encpassword@ زي الصورة كده : دلوقتي عشان نخلي الـ SMC يقرا المتغير الجديد ..ننزل تحت شوية و هنلاقي السطر دا : كود:
if (not exists(select JID from TB_User where JID = @nUserJID and password = @szPassword)) و هنعمل نفس الحكاية في CertifyTB_User_ زي الصورة كدا : و تدوس Execute كده خلصنا الجزء الأول تاني حاجة هنخلي الـ TB_User يقرا الـ Binary data اللي هتبقا الباسووردات متخزنة على شكلها أول حاجة لازم نعدل على حاجة في الـ Tools ->Options نشيل علامة الصح من Prevent saving changes that require table re-creation نيجي بعدين للـ TB_User ندوس right click و نختار Design هيطلع المربع دا ..نختار Password و نغيرها من varchar لـ (varbinary(20 و ندوس Save كده خلصنا الجزء التاني نيجي لجزء الـ PHP الجزء دا مهم عشان اللي بيعمل أكونت أو بيغير الباسوورد أو بيخش عالموقع بالأكونت بتاعو كل موقع و حسب الملفات بتاعتو بس كلهم في الاخر بيعملو Query للتعديل على TB_User ف انتا تدور عندك في ملفات الـ Classes/Inlcudes/Register الخ على الـ Query دا بالنسبة للـ Register هيبقى زي كدا : كود:
$this->con->sql = "INSERT INTO dbo.TB_User (StrUserID, password, Email, reg_ip) VALUES ('$this->username', '$this->password', '$this->Email', '$ip');"; كود:
$this->con->sql = "INSERT INTO dbo.TB_User (StrUserID, password, Email, reg_ip) VALUES ('$this->username', (CONVERT(varbinary(max), (select hashbytes('sha1','$this->password')) , 2)), '$this->Email', '$ip');"; ببساطة تغير 'this->password$' أو غيره (حسب اسم المتغير اللي المبرمج عاملو) الى كود PHP:
خامسا: ازاي تغير باسوورد عن طريق الـ SQL ؟ أولا تخش عادي عالموقع دا عفوا ,,, لايمكنك مشاهده الروابط لانك غير مسجل لدينا [ للتسجيل اضغط هنا ] و تكتب الباسوورد اللي انتا عايزها و تجيب الهاش بتاعها و لنفترض 123456 هيطلع الهاش دا :e10adc3949ba59abbe56e057f20f883e و عن طريق كويري زي كده : كود:
update TB_User set password= (CONVERT(varbinary(max), (select hashbytes('sha1','e10adc3949ba59abbe56e057f20f883e')) , 2)) where StrUserID='MyAccountID' بس كده.. --- سادسا : بالنسبة لأصحاب السيرفرات اللي عندهم أكونتات و عايزين يعملوا الموضوع دا عندهم : أولا هتاخد backup من الداتابيز و ملفات الموقع بعدين تعمل الكويري دا : كود:
update TB_User set password= (CONVERT(varbinary(max), (select hashbytes('sha1',password)) , 2)) بعديها تبدأ تعمل الخطوات اللي فوق زي ما هيا كده --- سابعا: كام ملاحظة كده : -الموضوع دا مش منقول من أي مكان..و لو في يوم من الأيام حد لقيه في موقع عربي أو أجنبي يبقى منقول من هنا. -اللي عايز ينقله ينقله بشرط ذكر المصدر. -الموضوع دا مجرب و شغال 100% و سيرفر Perfection شغال بيه حاليا. -لو حد عنده أي استفسار أو مشكلة بخصوص الموضوع دا يسأل في الردود و أنا مش هتأخر عليه. -أتقدم بالشكر لـ Sebastian عشان هوا اللي ساعدني في الحوار دا. في أمان الله |
||||||||||||
|
20-03-2013, 11:01 AM | #2 | ||||||||||||
|
يشرفنى الرد الأول لموضوعك الرائعة بجد مبدع
تسلم أيدك وفى أنتظار المزيد بإذن الله |
||||||||||||
|
20-03-2013, 01:48 PM | #3 | ||||||||||||
|
عالمى يا واد
|
||||||||||||
|
20-03-2013, 01:53 PM | #4 | ||||||||||||
|
موضوع رائع
|
||||||||||||
|
20-03-2013, 02:49 PM | #5 | ||||||||||||
Never ForGive
|
بـــــــــرنس والله |
||||||||||||
|
20-03-2013, 02:56 PM | #6 | ||||||||||||
|
الله عليك ! :) مجهود رائع |
||||||||||||
|
20-03-2013, 03:17 PM | #7 | ||||||||||||
|
Nice
|
||||||||||||
|
20-03-2013, 04:00 PM | #8 | ||||||||||||
|
تسلم ايدك والله ينور عليك
|
||||||||||||
|
20-03-2013, 06:22 PM | #9 | ||||||||||||
|
Awesome
|
||||||||||||
|
20-03-2013, 11:16 PM | #10 | ||||||||||||
|
تمام اسطورة |
||||||||||||
|
20-03-2013, 11:37 PM | #11 | ||||||||||||
|
برنس من يومك
|
||||||||||||
|
20-03-2013, 11:54 PM | #12 | ||||||||||||
|
تسلم
|
||||||||||||
|
21-03-2013, 01:21 AM | #13 | ||||||||||||
|
لا يا رجل تعملو من غيرى ايو بس انا فى الاول وى اخر لزم اقولك الله ينور بس ماشى مش خصاره فى الناس دى :) |
||||||||||||
|
21-03-2013, 04:10 AM | #14 | ||||||||||||
|
Thanks Brother
|
||||||||||||
|
21-03-2013, 09:13 AM | #15 | ||||||||||||
|
موضوع شديد
|
||||||||||||
|
يتصفح الموضوع حالياً : 1 (0 عضو و 1 زائر) | |
|
|