Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 108,065

HOME > PHP > PHP Forum > สอบถามวิธีกาหนดเวลาการ Login เข้าทำงานกรณีที่ไม่มีการเคลื่อนไหวให้ระบบแจ้งว่า Login ใหม่ จะต้องเขียนยังไงบ้างค่ะ



 

สอบถามวิธีกาหนดเวลาการ Login เข้าทำงานกรณีที่ไม่มีการเคลื่อนไหวให้ระบบแจ้งว่า Login ใหม่ จะต้องเขียนยังไงบ้างค่ะ

 



Topic : 119804



โพสกระทู้ ( 251 )
บทความ ( 0 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์




user ขอบ login ค้างไว้ค่ะ โดยไม่มีความเคลื่อนไหวในการทำงานเลย

ก้อเลยอยากจะถามพี่ๆ ว่าต้องเขียน code ยังไงให้ user ที่ไม่มีความเคลื่อนไหวในการทำงานเลย
ให้ถูกระบบ logout ออกไปอันโนมัติ



Tag : PHP, Ms SQL Server 2008







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2015-11-09 15:58:32 By : paphun View : 773 Reply : 5
 

 

No. 1



โพสกระทู้ ( 74,047 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ผมว่าตัวอย่างนี้สามารถ Apply ได้ครับ => PHP ทำระบบ Login และป้องกันการ ล็อกอิน ซ้ำซ้อนใน User เดียวกัน (MySQLi , Duplicate Session)

Code (PHP)
	//*** Reject user not online
	$intRejectTime = 20; // Minute
	$sql = "UPDATE member SET LoginStatus = '0', LastUpdate = '0000-00-00 00:00:00'  WHERE 1 AND DATE_ADD(LastUpdate, INTERVAL $intRejectTime MINUTE) <= NOW() ";
	$query = mysqli_query($con,$sql);


คุณจะต้องคิด Logic ให้ได้ครับ เช่น ในกรณีที่ Login ครั้งแรกให้ Insert ลงใน Table และตามอัพเดดเวลาเรื่อย ๆ เมื่อคลิกไปหน้าต่าง ๆ และใช้ Code นี้ Apply ในกรณีที่ไม่มีการเคลื่อนไหว 20 นาที

ในตัวอย่างจะเป็น MySQL แต่ใช้ Concept เดียวกันครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-09 16:25:03 By : mr.win
 


 

No. 2



โพสกระทู้ ( 251 )
บทความ ( 0 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์


กระจ่างเลยค่ะ
ขอบคุณมากมายก่ายกอง เลยค่ะคุณพี่


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-12 09:28:30 By : paphun
 

 

No. 3



โพสกระทู้ ( 1,636 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

วิธีการแจ่มมากครับ แต่ขอแก้ statement ให้หน่อยนะครับ
Code (SQL)
UPDATE member SET LoginStatus = '0', LastUpdate = '0000-00-00 00:00:00'  
WHERE 1 
AND DATE_ADD(LastUpdate, INTERVAL $intRejectTime MINUTE) <= NOW()


แก้เป็น
Code (SQL)
UPDATE member SET LoginStatus = 0  
WHERE LoginStatus<>0 
AND DATE_ADD(LastUpdate, INTERVAL $intRejectTime MINUTE) <= NOW()


LastUpdate เก็บไว้อย่างนั้นครับ เอาไว้อ้างอิงได้
และไม่มีผลกับการ ตรวจสอบ

และ DATE_ADD(LastUpdate, INTERVAL $intRejectTime MINUTE) <= NOW()
อย่างเดียว โดยไม่มี LoginStatus=0 ก็จะมีการพยายามทำการแก้ไข record ที่ตรงตามเงือนไขครับ
เป็นการกำหนดให้มันผ่านไปไม่ต้องสนใจ LoginStatus=0 ลดเวลาการทำงานลงไปอีกหน่อย
และ ถ้า loginStatus เป็นตัวเลข ไม่ต้องใส่ quote ครับ เพราะตรวจสอบ ตัวเลข เร็วกว่า ตรวจสอบ text ครับ
ถ้ามีสมาชิกเป็น หมื่นเป็นแสน จะไม่มีปัญหา เน็ตล่ม เพราะมานั่งตรวจสอบ login logout นับ view นี่แหล่ะครับ

หลายเวปเดี้ยงเพราะ เก็บสถิติพวกนี้ แต่ไม่คำนึงถึงระยะเวลาการทำงานของ database นะครับ


ประวัติการแก้ไข
2015-11-12 10:09:13
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-12 10:08:20 By : NewbiePHP
 


 

No. 4



โพสกระทู้ ( 74,047 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook


แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2015-11-12 10:23:27 By : mr.win
 


 

No. 5



โพสกระทู้ ( 1 )
บทความ ( 0 )



สถานะออฟไลน์
Facebook

บนโฮสจริงมันไม่เปลี่ยนค่าให้อะครับ ตั้งไว้ 1 นาที ก็ยังไม่ออกจากระบบให้เลย
แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2019-06-28 16:19:46 By : ntp
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : สอบถามวิธีกาหนดเวลาการ Login เข้าทำงานกรณีที่ไม่มีการเคลื่อนไหวให้ระบบแจ้งว่า Login ใหม่ จะต้องเขียนยังไงบ้างค่ะ
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: Voake, Comcube, รับทำเว็บไซต์ รับเขียนโปรแกรม

Load balance : Server 01
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2020 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 08-9968-0655 อัตราราคา คลิกที่นี่