ผลต่างระหว่างรุ่นของ "คู่มือการพัฒนาซอฟต์แวร์บนเว็บบราวซ์เซอร์ให้รองรับ UA ด้วยภาษา PHP"
ไปยังการนำทาง
ไปยังการค้นหา
Photchanan (คุย | มีส่วนร่วม) |
Acappella7 (คุย | มีส่วนร่วม) |
||
(ไม่แสดง 12 รุ่นระหว่างกลางโดยผู้ใช้ 2 คน) | |||
แถว 6: | แถว 6: | ||
<!--T:1--> | <!--T:1--> | ||
+ | <!-- | ||
+ | |||
+ | <!--T:16--> | ||
User/Pass สำหรับเข้าเซิร์ฟเวอร์ใน workshop [[https://คน.ไทย/วิกิ/list-user-ws.jpg User]] | User/Pass สำหรับเข้าเซิร์ฟเวอร์ใน workshop [[https://คน.ไทย/วิกิ/list-user-ws.jpg User]] | ||
# HOST: https://ws.kon.in.th | # HOST: https://ws.kon.in.th | ||
แถว 11: | แถว 14: | ||
# user: userX | # user: userX | ||
# pass: eaiuserX | # pass: eaiuserX | ||
+ | |||
+ | <!--T:17--> | ||
+ | --> | ||
== Preparing to Support UA in PHP == <!--T:2--> | == Preparing to Support UA in PHP == <!--T:2--> | ||
แถว 31: | แถว 37: | ||
# Text Editor (Code Editor) เช่น Notepad, Atom | # Text Editor (Code Editor) เช่น Notepad, Atom | ||
− | === Application Architecture | + | === Source code === <!--T:19--> |
+ | * Source code ที่ใช้ใน workshop นี้ [[https://github.com/THNICF/UA-Workshop-12062021 source code]] | ||
+ | |||
+ | == Application Architecture == <!--T:6--> | ||
[[File:App-archetiect-3.png|400px]] | [[File:App-archetiect-3.png|400px]] | ||
[[File:App-archetiect-2.png|400px]] | [[File:App-archetiect-2.png|400px]] | ||
แถว 39: | แถว 48: | ||
=== [[สร้างฐานข้อมูลที่รองรับ IDN และ EAI]] === <!--T:8--> | === [[สร้างฐานข้อมูลที่รองรับ IDN และ EAI]] === <!--T:8--> | ||
− | ''' | + | '''CREATE TABLE IF NOT EXISTS accounts ( ''' |
''' `id` int(11) NOT NULL AUTO_INCREMENT, | ''' `id` int(11) NOT NULL AUTO_INCREMENT, | ||
''' `username` varchar(50) NOT NULL, | ''' `username` varchar(50) NOT NULL, | ||
แถว 50: | แถว 59: | ||
=== [[แก้ไขให้ระบบลงทะเบียนรองรับการใส่อีเมล EAI]] === <!--T:9--> | === [[แก้ไขให้ระบบลงทะเบียนรองรับการใส่อีเมล EAI]] === <!--T:9--> | ||
แก้ไขไฟล์ register.html จาก | แก้ไขไฟล์ register.html จาก | ||
− | ''' | + | '''<input type="email" name="email" placeholder="Email" id="email" required> |
<!--T:10--> | <!--T:10--> | ||
เป็น | เป็น | ||
− | ''' | + | '''<input type=[["text"]] name="email" placeholder="Email" id="email" required> |
=== [[แก้ไขให้ระบบลงทะเบียนตรวจสอบอีเมล EAI ได้]] === <!--T:11--> | === [[แก้ไขให้ระบบลงทะเบียนตรวจสอบอีเมล EAI ได้]] === <!--T:11--> | ||
แก้ไขไฟล์ register.php จาก | แก้ไขไฟล์ register.php จาก | ||
− | ''' | + | '''if (!filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) { |
'''
exit('Email is not valid!');
| '''
exit('Email is not valid!');
| ||
''' } | ''' } | ||
แถว 64: | แถว 73: | ||
<!--T:12--> | <!--T:12--> | ||
เป็น | เป็น | ||
− | ''' | + | ''' if (preg_match('/^[ก-๛a-zA-Z0-9_+&*-]+(?:\.[ก-๛a-zA-Z0-9_+&*-]+)*@(?:[ก-๛a-zA-Z0-9-]+\.)+[ก-๛a-zA-Z]{2,16}$/u', $_POST['email']) == 0) { |
''' exit('Email is not valid!');
| ''' exit('Email is not valid!');
| ||
''' } | ''' } | ||
แถว 70: | แถว 79: | ||
=== [[แก้ไขให้ระบบลงทะเบียนสามารถส่งอีเมล EAI ได้ด้วย PHPMailer]] === <!--T:13--> | === [[แก้ไขให้ระบบลงทะเบียนสามารถส่งอีเมล EAI ได้ด้วย PHPMailer]] === <!--T:13--> | ||
แก้ไขไฟล์ PHPMailer/src/PHPMailer.php จาก | แก้ไขไฟล์ PHPMailer/src/PHPMailer.php จาก | ||
− | ''' | + | ''' case 'php': |
''' default: | ''' default: | ||
''' return filter_var($address, FILTER_VALIDATE_EMAIL) !== false; | ''' return filter_var($address, FILTER_VALIDATE_EMAIL) !== false; | ||
แถว 76: | แถว 85: | ||
<!--T:14--> | <!--T:14--> | ||
เป็น | เป็น | ||
− | ''' | + | ''' case 'php': |
''' default: | ''' default: | ||
− | ''' return (bool) preg_match( | + | ''' return (bool) preg_match("/^[ก-๛a-zA-Z0-9_+&*-]+(?:\.[ก-๛a-zA-Z0-9_+&*-]+)*@(?:[ก-๛a-zA-Z0-9-]+\.)+[ก-๛a-zA-Z]{2,16}$/u", $address); |
+ | |||
+ | Regular expression ข้างต้นสามารถใช้ตรวจสอบรูปแบบ email ภาษาไทยได้ หากต้องการตรวจสอบ email ภาษาอื่นๆอาจต้องพิจารณาใช้ regular expression รูปแบบอื่นที่ไม่เจาะจง เช่น | ||
+ | * something@something ^(.+)@(.+)$ | ||
<!--T:15--> | <!--T:15--> | ||
+ | แก้ไขจาก | ||
+ | ''' $this->punyencodeAddress | ||
+ | |||
+ | <!--T:16--> | ||
+ | เป็น | ||
+ | ''' //...$this->punyencodeAddress... | ||
+ | (Comment บรรทัดเหล่านี้เพื่อให้โค้ดไม่ทำงาน) | ||
+ | |||
+ | |||
+ | แก้ไขไฟล์ PHPMailer/src/SMTP.php จาก | ||
+ | ''' 'MAIL FROM:<' . $from . '>' . $useVerp, | ||
+ | |||
+ | <!--T:18--> | ||
+ | เป็น | ||
+ | ''' 'MAIL FROM:<' . $from . '> SMTPUTF8', | ||
+ | |||
+ | |||
+ | <!--T:19--> | ||
[[Category: EAI]] | [[Category: EAI]] | ||
</translate> | </translate> |
รุ่นแก้ไขปัจจุบันเมื่อ 14:17, 24 มีนาคม 2565
คู่มือนี้ได้จัดทำขึ้นมาเพื่อใช้เป็นแนวทางในการพัฒนาซอฟต์แวร์บนเว็บบราวซ์เซอร์เพื่อให้รองรับโดเมนภาษาไทย (IDN) และอีเมลภาษาไทย (EAI) โดยใช้ภาษา PHP
เนื้อหา
Preparing to Support UA in PHP
ระบบที่ใช้ในการพัฒนา
- ระบบฐานข้อมูล
- MySQL
- PHPMyAdmin
- ระบบบนเว็บบราวซ์เซอร์
- ระบบลงทะเบียน (Registration)
- ระบบ Login
- ระบบแสดงผล Profile
- ระบบส่งอีเมล
- PHPMailer
Software ที่ใช้ในการพัฒนา
- Filezilla [Win] [Mac]
- Web Browser เช่น Firefox, Chrome, Safari
- Text Editor (Code Editor) เช่น Notepad, Atom
Source code
- Source code ที่ใช้ใน workshop นี้ [source code]
Application Architecture
Developing Applications to Support UA in PHP
สร้างฐานข้อมูลที่รองรับ IDN และ EAI
CREATE TABLE IF NOT EXISTS accounts ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(50) NOT NULL, `password` varchar(255) NOT NULL, `email` varchar(100) NOT NULL, `activation_code` varchar(50) DEFAULT '', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
แก้ไขให้ระบบลงทะเบียนรองรับการใส่อีเมล EAI
แก้ไขไฟล์ register.html จาก
<input type="email" name="email" placeholder="Email" id="email" required>
เป็น
<input type="text" name="email" placeholder="Email" id="email" required>
แก้ไขให้ระบบลงทะเบียนตรวจสอบอีเมล EAI ได้
แก้ไขไฟล์ register.php จาก
if (!filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) { exit('Email is not valid!'); }
เป็น
if (preg_match('/^[ก-๛a-zA-Z0-9_+&*-]+(?:\.[ก-๛a-zA-Z0-9_+&*-]+)*@(?:[ก-๛a-zA-Z0-9-]+\.)+[ก-๛a-zA-Z]{2,16}$/u', $_POST['email']) == 0) { exit('Email is not valid!'); }
แก้ไขให้ระบบลงทะเบียนสามารถส่งอีเมล EAI ได้ด้วย PHPMailer
แก้ไขไฟล์ PHPMailer/src/PHPMailer.php จาก
case 'php': default: return filter_var($address, FILTER_VALIDATE_EMAIL) !== false;
เป็น
case 'php': default: return (bool) preg_match("/^[ก-๛a-zA-Z0-9_+&*-]+(?:\.[ก-๛a-zA-Z0-9_+&*-]+)*@(?:[ก-๛a-zA-Z0-9-]+\.)+[ก-๛a-zA-Z]{2,16}$/u", $address);
Regular expression ข้างต้นสามารถใช้ตรวจสอบรูปแบบ email ภาษาไทยได้ หากต้องการตรวจสอบ email ภาษาอื่นๆอาจต้องพิจารณาใช้ regular expression รูปแบบอื่นที่ไม่เจาะจง เช่น
- something@something ^(.+)@(.+)$
แก้ไขจาก
$this->punyencodeAddress
เป็น
//...$this->punyencodeAddress...
(Comment บรรทัดเหล่านี้เพื่อให้โค้ดไม่ทำงาน)
แก้ไขไฟล์ PHPMailer/src/SMTP.php จาก
'MAIL FROM:<' . $from . '>' . $useVerp,
เป็น
'MAIL FROM:<' . $from . '> SMTPUTF8',