<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://kb.pathosting.co.th/index.php?action=history&amp;feed=atom&amp;title=Resync_Member_%28Discuz%29</id>
	<title>Resync Member (Discuz) - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://kb.pathosting.co.th/index.php?action=history&amp;feed=atom&amp;title=Resync_Member_%28Discuz%29"/>
	<link rel="alternate" type="text/html" href="https://kb.pathosting.co.th/index.php?title=Resync_Member_(Discuz)&amp;action=history"/>
	<updated>2026-05-09T12:56:33Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.7</generator>
	<entry>
		<id>https://kb.pathosting.co.th/index.php?title=Resync_Member_(Discuz)&amp;diff=328&amp;oldid=prev</id>
		<title>Admin: Created page with &quot;category:Discuz เนื่องจากได้อัพเกรด Discuz ให้ลูกค้ารายหนึ่ง จากเวอร์ชั่น X1 ...&quot;</title>
		<link rel="alternate" type="text/html" href="https://kb.pathosting.co.th/index.php?title=Resync_Member_(Discuz)&amp;diff=328&amp;oldid=prev"/>
		<updated>2010-11-07T16:16:49Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;&lt;a href=&quot;/Category:Discuz&quot; title=&quot;Category:Discuz&quot;&gt;category:Discuz&lt;/a&gt; เนื่องจากได้อัพเกรด Discuz ให้ลูกค้ารายหนึ่ง จากเวอร์ชั่น X1 ...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;[[category:Discuz]]&lt;br /&gt;
เนื่องจากได้อัพเกรด Discuz ให้ลูกค้ารายหนึ่ง จากเวอร์ชั่น X1 เป็น X1.5 ปรากฏว่ามีปัญหาเข้าสู่ระบบกันไม่ได้ เวลาล๊อคอินจะขึ้นว่ารหัสผ่านไม่ถูกต้อง หลังจากที่ตรวจสอบ พบว่าสมาชิกที่ไม่สามารถล๊อคอินได้ จะไม่มีข้อมูลอยู่ในตาราง '''members''' (แต่จะมีข้อมูลอยู่ในตาราง '''common_member''' เท่านั้น). ดังนั้นวิธีการแก้ไขปัญหา คือ คัดลอกสมาชิกจาก common_member ไปยัง members เพื่อให้มีข้อมูลในทั้ง 2 ตาราง แล้วรัน query เพื่อปรับข้อมูลสมาชิกที่ uid ไม่ตรงกัน.&lt;br /&gt;
&lt;br /&gt;
== คัดลอกสมาชิกจาก common_member ไปยัง members ==&lt;br /&gt;
Query สำหรับคัดลอกสมาชิกที่หายไป (ยังไม่สามารถใช้รหัสผ่านเก่าได้ เพราะไม่รู้กระบวนการเข้ารหัสแบบเดิม) query นี้จะกำหนดรหัสผ่านใหม่โดยการสุ่มเลย ดังนั้นสำหรับสมาชิกที่มีปัญหา จะต้องกดลืมรหัสผ่านที่หน้าเว็บ เพื่อขอรหัสผ่านใหม่ เพื่อนำมาใช้ล๊อคอิน&lt;br /&gt;
 INSERT INTO `members`&lt;br /&gt;
 (&lt;br /&gt;
   `uid`, &lt;br /&gt;
   `username`, &lt;br /&gt;
   `password`,  &lt;br /&gt;
   `email`,  &lt;br /&gt;
   `regdate`,  &lt;br /&gt;
   `salt`&lt;br /&gt;
 )&lt;br /&gt;
 SELECT&lt;br /&gt;
   `common_member`.`uid`, &lt;br /&gt;
   `common_member`.`username`, &lt;br /&gt;
   MD5(CONCAT(MD5(MD5(RAND())), SUBSTR(MD5(`common_member`.`username`), 1, 6))) AS `password`, &lt;br /&gt;
   `common_member`.`email`, &lt;br /&gt;
   `common_member`.`regdate`, &lt;br /&gt;
   SUBSTR(MD5(`common_member`.`username`), 1, 6) AS `salt`&lt;br /&gt;
 FROM `common_member`&lt;br /&gt;
 LEFT JOIN `members` USING (`username`)&lt;br /&gt;
 WHERE `members`.`uid` IS NULL;&lt;br /&gt;
หมายเหตุ: query นี้ใช้ username ในการสร้าง salt ดังนั้นเพื่อความปลอดภัยยิ่งขึ้น สามารถเปลี่ยนตรงส่วนของการสร้าง salt ในสไตล์ของคุณเอง เพื่อให้คนอื่นเดาไม่ได้&lt;br /&gt;
&lt;br /&gt;
== ปัญหา UID ไม่ตรงกัน ==&lt;br /&gt;
มีสมาชิกอีกส่วนหนึ่ง ที่มีข้อมูลอยู่ในทั้งสองตาราง แต่ '''uid''' ไม่ตรงกัน สำหรับกลุ่มนี้ ก็จะล๊อคอินไม่ได้เหมือนกัน (แต่จะคนละอาการกัน คือล๊อคอินแล้ว redirect ไปที่อีกหน้านึง แล้วให้ใส่ code ใหม่) อันนี้สามารถแก้ไขได้ง่ายๆ เพียงใช้ query เดียว เพื่ออัพเดท '''uid''' ของตาราง '''members''' ให้ตรงกับ '''uid''' ของตาราง '''common_member'''&lt;br /&gt;
 UPDATE `members`&lt;br /&gt;
 JOIN `common_member` ON (common_member.username=members.username)&lt;br /&gt;
 SET members.uid = common_member.uid&lt;br /&gt;
 WHERE common_member.uid &amp;lt;&amp;gt; members.uid&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ข้อมูลอื่นๆ ที่ใช้สำหรับการแก้ปัญหา ==&lt;br /&gt;
=== ไฟล์ config ===&lt;br /&gt;
ต้องดูไฟล์พวกนี้ เพื่อใช้ table prefix&lt;br /&gt;
* ไฟล์ config ของ discuz คือ '''config_global.php'''&lt;br /&gt;
* ไฟล์ config ของ ucenter คือ '''config_ucenter.php'''&lt;br /&gt;
=== การใช้ salt ในการเข้ารหัส password ของ ucenter ===&lt;br /&gt;
 $password = md5( md5($original-password) . $salt );&lt;br /&gt;
=== Query ===&lt;br /&gt;
==== เช็คว่ามี member กี่คน ที่ไม่มีข้อมูลใน ตาราง members ====&lt;br /&gt;
 SELECT count(*) FROM `common_member`&lt;br /&gt;
 LEFT JOIN `members` USING (`uid`)&lt;br /&gt;
 WHERE `members`.`uid` IS NULL;&lt;br /&gt;
=== อื่นๆ ===&lt;br /&gt;
* เหมือนว่า '''common_member.password''' จะไม่ได้ถูกใช้เลย ดังนั้นไม่ต้องสนใจก็ได้&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
</feed>