ข้ามไปที่เนื้อหาหลัก

บทความ

กำลังแสดงโพสต์จาก พฤษภาคม, 2018

แก้ปัญหา Control Panel ของ Xampp เปิดไม่ขึ้น - Xampp control panel is not showing

หลังจากดับเบิ้ลคลิกเปิดโปรแกรม Xamp Server หน้าจอแว๊บๆ แต่ไม่ปรากฏอะไรออกมาเลย หลังจากพยายามคลิกอยู่นาน เจ้า Xampp Control Panel ก็ไม่ขึ้นมาให้เห็น ก็เลยตัดสินใจไปค้นใน Google ด้วยคีย์เวิร์ดนี้ " Xampp control panel is not showing " แล้วก็ได้วิธีแก้จาก StackOverFlow.Com เจ้าเก่าเจ้าเดิม ก็มีคนบอกเอาไว้ว่า ก็ไปสั่งให้มันเต็มจอซะสิ!! ดังนั้นก็ไม่รีรอ รีบกดคีย์พิฆาตทันที Ctrl + Alt + Delete เนื่องจากระบบปฏิบัติการที่ใช้เป็น Windows 10 ดังนั้นหน้าตาก็จะต่างจากในกระทู้นิดหน่อย ให้เลื่อนหา xamp-control-panel.exe  จากนั้นก็คลิกขวา แล้วสั่ง Expand ให้คลิกขวาเลือก XAMPP Control Panel เวอร์ชั่นที่เปิดหน้าต่างไม่ขึ้นนั้น แล้วเลือกคำสั่ง Maximize หน้าต่าง Xampp Control Panel ก็จะเด้งขึ้นมาเต็มหน้าจอ พร้อมให้เรากดปุ่ม Start เพื่อเริ่มใช้งานเว็บเซิร์ฟเวอร์ได้ตามปกติ ---------- สำหรับ Windows 10 ให้คลิกที่เมนู Options ด้านบนสุด แล้วคลิกเลือก Always on top และ คลิกออก อีกครั้ง เมนู Maximize จะปรากฏออกมา PHP  CI  MANIA   -  PHP Code ...

แก้ปัญหา JavaScript ไม่สามารถแสดงใน TEXTAREA ได้

ทำไม View Code แล้วเห็น และใน Textarea กลับไม่แสดงค่าอะไรเลย??? สังเกตว่าเปิด Console แล้วตรวจสอบโครงสร้าง HTML ก็มีโค้ด JavaScript อยู่นะ แต่ทำไมใน <textarea></textarea> ถึงว่างเปล่าไม่มีอะไรออกมาเลย??? ก็เลยลองค้นด้วยคีย์เวิร์ดง่ายๆ "how to display javascript in textarea" (จริงๆก็ไม่ง่ายๆนะ ค้นหาด้วยคีย์เวิร์ดหลายคำมาก กว่าจะลงตัวที่ประโยคนี้) ก็ได้พบหนทางสว่าง นั่นก็คง ต้องแปลงวงเล็บเปิด-ปิดของ script ให้เป็นตัวโค้ดพิเศษก่อน ซึ่งนอกจากใช้ htmlentities() ก็ยังมี htmlspecialchars() ให้เรียกใช้อีกฟังก์ชั่น  หลังจากนั้น ลอง CTRL + F5 เพื่อรีเฟรชหนักๆ ก็ปรากฏโค้ดออกมาในที่สุด (ดีใจจนน้ำตาแทบไหล ปิดงานได้สักที TT__TT ) ขอให้ทุกคนมีความสุขในการเขียนโปรแกรม PHP และสนุกไปกับการแก้บั๊กนะครับ ^O^ อ้างอิง https://stackoverflow.com/questions/6130097/how-come-when-i-display-javascript-in-a-textarea-it-executes PHP  CI  MANIA   -  PHP Code Generator  โปรแกรมช่วยสร้างโค้ด ลดเวลาการเขียนโปรแกรม เขียนโปรแกรมง่ายและสะดวก...

PHP - มาลองเขียนโค้ดแก้โจทย์ปัญหาด้วยการวนลูปหาค่าตัวแปรแต่ละตัว

มาลองเขียนโค้ดแก้โจทย์ปัญหาด้วยการวนลูปกันดูครับ ด้านล่างนี้คือโค้ดเริ่มต้นที่ผมมีให้ครับ ลองไปต่อกันดู หรือถ้าใจร้อน จะเลื่อนลงไปล่างสุดเพื่อดูโค้ดที่ผมเขียนเอาไว้เลยก็ย่อมได้ ^O^ <?php $worm     = 7; $clock     = 6; $flower = 2; $check1 = ($worm + $worm + $worm == 21); $check2 = ($clock + $clock + $worm == 19); $check3 = ($flower + $clock + $worm == 15); $result = "???"; echo "<br/>$worm + $worm + $worm = 21 (", $check1 ? 'true' : 'false',")"; echo "<br/>$clock + $clock + $worm = 19 (", $check2 ? 'true' : 'false', ")"; echo "<br/>$flower + $clock + $worm = 15 (", $check3 ? 'true' : 'false', ")"; if($check1 == true && $check2 == true && $check3 == true){     $result = "($worm-$flower) + ($flower *2) * $clock = <b>".( ($worm-$flower) + ($flower *2) * $clock) . "</b>"; } ...

บันทึกการผจญภัยครั้งใหม่ : ทดลองรัน GO Lang Mobile บนมือถือ Android

ลองเขียน Go Lang Mobile ต้องตั้งค่าอะไรบ้าง? เริ่มจากดาวน์โหลด และติดตั้ง Go https://golang.org/doc/install ดาวน์โหลดและติดตั้ง GoLang Mobile https://github.com/golang/go/wiki/Mobile#tools พอถึงขั้นตอน  Building and deploying to Android รันไม่ผ่าน!! https://developer.android.com/ndk/guides/ ต้องไปติดตั้ง Android Studio ก่อนเพื่อโหลด NDK https://developer.android.com/studio/ หลังจากนั้นก็หา PATH ndk-bundle บน Windows 10 ไม่เจอ https://stackoverflow.com/questions/27522184/android-ndk-default-location ต้องรัน NDK ก่อนเริ่มคำสั่ง Building อีกครั้ง https://stackoverflow.com/questions/42430609/gomobile-command-error-no-android-ndk-path-is-set/42914874  หลังจาก Building เสร็จจะได้ไฟล์ basic.apk ที่โฟลเดอร์ชื่อ Users ของ Windows 7 หลังจากนั้นก็ลองคำสั่งเกี่ยวกับ Android Debug Bridge (adb) ซึ่งจะไม่พบเพราะไม่ได้เซ็ต PATH ของ Android SDK https://stackoverflow.com/questions/2517493/adb-command-not-found-in-linux-environment พอลองรันดู ปรากฏ...

มาฝึกแฮกเว็บ ก่อนที่เว็บเราจะถูกแฮก!! (PHP Web Application Security)

รวมบทความแนะนำวิธีการแฮกเว็บไซต์และการป้องกัน PHP Web Application Security  สรุป PHP Web Application Security  Nebula เลเวล 09: มาลองแฮกช่องโหว่ใน PHP เข้าใจ Web Security: จัดเก็บ JWT ไว้ใน local storage หรือ cookies ดี? SQL Injection เทคนิค การHack Web 2. String Based SQL Injection สิ่งที่ทุกคนต้องรู้ ในการเขียนโปรแกรมด้วย PHP กับ MySQL หากไม่อยากให้ระบบที่เขียนนั้นถูก HACK ได้ !!!  Testing for SQL Injection (OTG-INPVAL-005) Cross Site Scripting (XSS) Cross-site Scripting (XSS) วิธีการยอดนิยมที่แฮคเกอร์รู้จักกันดี บทเรียน hack มั่ว (ตอนที่ 1) การ xss วิธีตรวจสอบเว็บไซต์ที่โดน Hack #9 https://www.owasp.org/index.php/Cross-site_Scripting_(XSS) Cross Site Request Forgery (CSRF) การโจมตีเว็บแบบ Cross Site Request Forgery ทำความเข้าใจกับ CSRF (Cross Site Request Forgery) ตอนที่ 1 ทำเว็บไซต์ให้ปลอดภัย Codeigniter Security https://www.owasp.org/index.php/Testing_for_CSRF_(OTG-SESS-005) ใครที่มีเรื่องราวน่าสนใจ แบ่งปันกัน...

PHP กับการเข้ารหัสข้อมูลรหัสผ่านด้วย md5() และ password_hash()

เข้ารหัสข้อมูลรหัสผ่านด้วย password_hash() สำหรับการเข้ารหัสด้วย md5() เพียงอย่างเดียวสามารถถอดรหัสได้แล้วด้วยฐานข้อมูลที่มีข้อมูลรหัสจำนวนมหาศาลดังนั้น PHP จึงได้สร้างฟังก์ชั่นใหม่ขึ้นมารองรับการเข้ารหัสที่ดีกว่าเดิม แต่นั่นก็ไม่ใช่เหตุผลให้เราทิ้งฟังก์ชั่น md5() ไปเลยเสียทีเดียว เพราะยังมีประโยชน์ในการเข้ารหัสที่ได้รหัสเหมือนเดิมทุกครั้ง และใช้แค่ 32 หลักเท่านั้น แต่เพื่อความปลอดภัยของรหัส เราก็จำเป็นจะต้องทำการผสมผสานข้อมูลใหม่ เพื่อให้เมื่อแกะออกมาแล้วไม่สามารถเข้าใจมันได้ด้วยนั่นเอง โค้ดตัวอย่างการเข้ารหัส md5() ก่อนเรียกใช้ password_hash() อีกครั้ง <?php header('Content-Type: text/html; charset=utf-8'); function utf8_strrev($str) { preg_match_all('/./us', $str, $ar); return join('', array_reverse($ar[0])); } function pass_encrypt($pass, $show = false) { //you secret word $key1    = 'asdfasf'; $key2    = 'asdfasdf'; $loop    = 1; $reverse = utf8_strrev($pass); if ($show == true) { echo '<br...

PHP กับการแทนที่ข้อความ มาดูกันว่ามีฟังก์ชั่นอะไรให้ใช้บ้าง

PHP Replace Function 1. str_replace() Replace all occurrences of the search string with the replacement string 2. substr_replace() Replace text within a portion of a string 3. strtr() Translate characters or replace substrings 4. preg_replace() Perform a regular expression search and replace แต่ละฟังก์ชั่นแตกต่างกันอย่างไร เริ่มจาก => 1. str_replace()   เรามักจะคุ้นเคยกับการใช้เพื่อแทนที่คำบางคำให้เป็นคำอื่น เช่น echo str_replace("ผศ.ดร.", "", "ผศ.ดร.สมบูรณ์  ใจดี"); ก็จะได้ผลลัพธ์ที่แทนที่ ผศ.ดร. เป็นค่าว่าง = สมบูรณ์  ใจดี หรือ ใช้ตัดเครื่องหมายคอมม่าในตัวเลขออกไป echo str_replace(",", "", "1,234,654.00"); ก็จะได้แต่ตัวเลข 1234654.00 เพื่อเอาไปบันทึกในฐานข้อมูล นอกจากนี้ยังสามารถนำไปใช้แทนที่คำหยาบได้ด้วย ยกตัวอย่าง $rough = array("a", "e", "i", "o", "u", "A", "E", "I", "O", "U"); $c...

PHP Codeigniter กับการใช้งาน Template Parser Class แล้วไม่สามารถเรียกใช้ตัวแปรด้านนอก Variable Pairs ที่กำหนดไว้ได้

มาดัดแปลงฟังก์ชั่น Template Engine ใน CodeIgniter กัน โค้ดด้านล่างนี้เป็นส่วนของ View ที่มาจากเว็บไซต์ CodeIgniter https://www.codeigniter.com/userguide3/libraries/parser.html โดยจะมี Controller  ที่ทำหน้าที่รับส่งค่าดังนี้ เมื่อลองรันทดสอบบนหน้าเว็บบราวเซอร์ จะเห็นว่าข้อมูลในอาร์เรย์จะแทรกลงไปในตำแหน่งวงเล็บที่ตรงกับ Key ของข้อมูลแต่ละตัว และในส่วนของ {blog_entries} .......... {/blog_entries} จะพิเศษตรงที่ มีการวนลูปตามจำนวนอาร์เรย์ให้เราเรียบร้อย โดยที่เราไม่ต้องเขียนคำสั่งวนลูปอีกเลย แต่ปัญหามีอยู่ว่า ในบล็อก  {blog_entries} .......... {/blog_entries}  ไม่สามารถเรียกใช้ {site_url} ซึ่งเราได้สร้างอาร์เรย์รับค่าเอาไว้แล้ว หน้า controllers/Welcome.php <?php defined('BASEPATH') OR exit('No direct script access allowed'); class Welcome extends CI_Controller { public function index() { $this->load->helper('url'); $this->load->library('parser'); $data = array( 'site_url' => si...

PHP การกำหนดรูปแบบทศนิยม ตามค่าที่มี หากทศนิยมเป็น 0 ให้ตัดทิ้ง

การตัดทศนิยมที่มีค่าเป็นศูนย์ออกจากตัวเลข จากในรูปก็คือถ้า .00 ก็จะตัดทิ้ง แต่ถ้ามีทศนิยมมาด้วย ก็ให้คงเอาไว้ วิธีง่ายๆที่ใช้ก็คือ การ +0 เข้าไปเท่านั้นเองก็จะได้ผลลัพธ์ที่ต้องการ โดยไม่ต้องไปเสียเวลา explode() แล้วมา implode() ใหม่ แต่ถ้ารูปสึกว่า 9166.7 เลขทศนิยมหลักเดียวแบบนี้ไม่สวย จะใส่ number_format() ครอบไว้อีกทีก็ย่อมได้ แต่ทีนี้ถ้าเจอกับเลขที่ไม่มีทศนิยมล่ะ?? ก็กลายเป็น 1255.00 อีก ดังนั้นก็เพิ่มฟังก์ชั่นสำหรับตรวจสอบเข้าไป function is_decimal( $val ) {     return is_numeric( $val ) && floor( $val ) != $val; } เวลาใช้ก็เรียกแบบนี้     if(is_decimal($val)){         $val = number_format($val, 2);     }else{         $val = number_format($val);     } ทีนี้เลข  9166.7  ก็จะเป็น  9,166.70 เหมือนเดิม และเลข 1255.00 ก็กลายเป็น  1,255 เท่านั้น :: อ้างอิง :: Remove useless zero digits from decimals ...

ขั้นตอนแก้ปัญหา - สั่งพิมพ์ PDF แล้วเกิดข้อความแจ้งเตือนข้อผิดพลาด TCPDF error Line Number: 18650

สั่งพิมพ์เอกสาร PDF ด้วย TCPDF แล้วปรากฏข้อความแจ้ง Error Message: Undefined offset: 132 Filename: tcpdf /tcpdf.php Line Number: 18650 ความผิดปกติก็คือ สามารถพิมพ์เอกสารได้ปกติ แต่มีอยู่รายการเดียว ที่ไม่สามารถพิมพ์ได้ ดังนั้นจึงโฟกัสไปที่ข้อมูลในเอกสารชุดนั้น เริ่มต้นจากการค้นหาจุดที่เกิดข้อผิดพลาด เนื่องจากไม่มีแจ้งว่าโค้ดบรรทัดไหนที่เราเขียนผิดพลาด แต่ข้อความแจ้งถึงส่วนข้างในไลบรารี่ TCPDF ที่เรานำมาใช้เท่านั้น 1. echo () เท่านั้นที่จะคลี่คลายข้อสงสัย หาจุดที่คิดว่าน่าจะเกิดข้อผิดพลาด แล้ววางโค้ดไปเลย อาจจะเริ่มจาก echo 11111; จนไปถึง echo 99999;  หรือจะ echo 'AAAAAA';  ถึงจุดที่ 'ZZZZZ'; ก็ได้ 2. มารันหน้าเว็บเพื่อดูผลลัพธ์กัน ว่าข้อความที่ echo ออกมาจะโผล่ตรงไหนบ้าง ในตัวอย่างข้อความ error ปรากฏขึ้นระหว่าง 5 กับ 6  ให้กลับไปดูโค้ดที่ตำแหน่งช่วงนั้น และปรับสโคปให้เหลือแคบที่สุดจนเจอต้นตอ 3. เมื่อรู้ว่าเกิดจาก writHTMLCell() ก็มาดูว่าอะไรที่ถูกเขียนออกมาแล้วทำให้ PDF ของเราทำงานผิดพลาด แต่ก่อนจะลัดไปถึงขั้นตอนที่ 7 เราลองมาไล่ดูใน Go...

ค้นหาในเว็บไซต์

เนื้อเพลงที่ได้รับความนิยม ในรอบสัปดาห์

แจกโค้ด PHP : รวมลิงค์ แจกฟรี!! ตัวอย่างโปรเจ็กต์ ที่พัฒนาด้วย PHP

       สำหรับหลายท่านที่ขอโค้ดเข้ามาทาง Inbox ของเฟซบุ๊กแฟนเพจ หรือถามถึงระบบต่างๆหลังไมค์มานั้น ส่วนใหญ่ก็มีแจกอยู่แล้วในเว็บบอร์ด ThaiCreate.Com นะครับ  และด้านล่างนี้ก็เป็น Source Code PHP ระบบต่างๆ ที่มีเหล่าผู้ใจดีแจกฟรี!! ให้นำไปลองใช้ลองศึกษากันครับ แจกฟรี  !! ตัวอย่างการ  PHP  Booking # จองห้องประชุม  ผ่านเว็บครับ http://www.thaicreate.com/php/forum/090558.html ระบบแบบสอบถาม https://www.thaicreate.com/php/forum/099342.html แจก code!! การทำประเมินออนไลน์มี ไว้สำหรับพัฒนาต่อยอด https://www.thaicreate.com/php/forum/102203.html แจกฟรี PHP CodeIgniter CMS ให้ทุกท่านได้ลอง (รองรับ Responsive) http://www.thaicreate.com/php/forum/122929.html โดย : https://www.cszcms.com/ แจก PHP : ระบบยืม-คืนเอกสาร (จากตัวอย่าง เอกสารข้อมูลวัตถุดิบสินค้า) http://www.thaicreate.com/php/forum/103428.html แจกระบบ PHP Shopping Cart ระบบตะกร้าสินค้า ระบบสั่งซื้อ มีระบบตัดสต๊อก, สั่งซื้อวัตถุดิบคงเหลือ ht...

แก้ปัญหา Xampp เข้าผ่าน IP จากเครื่องอื่นไม่ได้ โดยการเปิด Firewall เชื่อมต่อ httpd ได้

กรณีที่ติดตั้ง Xampp แล้วเปิดจากเครื่องอื่นๆผ่าน IP ไม่ได้ ให้ทำการเปิด Firewall ในเครื่องที่ติดตั้ง xampp เพื่ออนุญาตให้เครื่องอื่นเข้าถึงได้ คลิกเมนู ค้นหา แล้วพิมพ์คำว่า firewall แล้วเลือกเมนู Firewall & network protection คลิกที่เมนู Allow an app through firewall คลิกที่ปุ่ม Change settings เลือกทั้ง Private และ Public (ถ้าไม่มีให้กดที่ปุ่ม Allow another app... เพื่อเพิ่ม httpd.exe ใน Path เฉพาะของเรา กรณีที่ไม่ได้ติดตั้ง) (สามารถเปิดดูรายละเอียด Path ของรายการที่แสดงได้ โดยคลิกปุ่ม Details...)   จากนั้นกด OK   ลองเข้าจากอีกเครื่องด้วย IP อีกครั้ง ก็จะพบว่าสามารถเข้าถึงหน้าเว็บที่ต้องการได้เรียบร้อย ที่มา : https://www.youtube.com/watch?v=KIYpkDy34DY   บทความที่เกี่ยวข้อง แก้ปัญหาการเปิด Firewall ทำให้ Client เชื่อมต่อ MySQL ไม่ได้ http://blog.phpcodemania.com/2021/04/xampp-ip-firewall-httpd.html   PHP  CI  MANIA   - PHP Code Generator  โปรแกรมช่วยสร้างโค้ด "ลดเวลาการเขียนโปรแกรม" ราคาสุดคุ้ม    http://fastcoding...

ระบบวัสดุคงเหลือ - การตีราคาสินค้าคงเหลือด้วยวิธีราคาทุน (Inventory Costs Method)

การตีราคาสินค้าคงเหลือด้วยวิธีราคาทุน (Inventory Costs Method) หลังจากได้อ่านบทความในเว็บต่างๆก็สรุปได้ดังนี้ 1. FIFO เข้าก่อน-ออกก่อน เหมาะสำหรับการตัดสต๊อกที่ใช้สำหรับของที่มีวันที่หมดอายุกำกับไว้ อาจจะเนื่องด้วยพนักงานสต๊อกจะต้องคอยเช็ควันที่หมดอายุบนสินค้าเสมอๆอยู่แล้ว 2. LIFO เข้าหลัง-ออกก่อน เหมาะสำหรับการตัดสต๊อกสินค้าที่ตกเทรนเร็วแบบคอมพิวเตอร์ หรือสินค้าเทคโนโลยีอื่นๆ ซึ่งส่วนใหญ่จะทำโปรโมชั่นมาล่อตาล่อใจให้ลูกค้าซื้อรุ่นใหม่ๆ ดังนั้นพนักงานก็ต้องตัดสต๊อกตัวที่ใหม่ที่สุดออกก่อน เพราะทิ้งไว้นานไปราคาทุน ณ ปัจจุบันจะไม่ตรงกับราคาที่ขายไป 3. Weighted Average ถัวเฉลี่ยน้ำหนัก เหมาะกับสินค้าที่ไม่มีวันหมดอายุกำกับ และราคาขึ้นลงไม่มากนัก (คอมพิวเตอร์หรือสินค้าเทคโนโลยีจะขึ้นลงทีเป็นหลักร้อยหลักพัน) ซึ่งเหมาะกับการนำมาใช้ทำสต๊อกวัสดุคงเหลือของสำนักงาน ปัญหาของการใช้ Weighted Average หรือการถัวเฉลี่ยราคาทุนต่อหน่วย จะมีอยู่ 2 รูปแบบ 1. แบบ Periodic Inventory เป็นการคิดราคาทุนถัวเฉลี่ยของสินค้าคงเหลือปลายงวด นั่นก็คือ บันทึกการรับเข้าด้วยราคาต่อหน่...

แก้ปัญหาการเปิด Firewall ทำให้ Client เชื่อมต่อ MySQL ไม่ได้

"Allow programs to communicate through Windows Firewall" เดิมทีปิด FireWall เอาไว้ โปรแกรมสามารถเชื่อมต่อฐานข้อมูลได้ปกติ หลังจากเปิด Windows Firewall โปรแกรมไม่สามารถเชื่อมต่อฐานข้อมูล MySQL จากเครื่อง Client ได้ แต่เชื่อมผ่าน Localhost ได้ ให้เข้าไปเปิดที่ Control panel > Windows Firewall > Allow a program or feature through Windows Firewall เพื่อกำหนดให้ MySQL ที่เราติดตั้งไว้สามารถทำงานผ่าน Firewall ได้ หลังจากกด OK ลองกลับไปหน้าล็อกอินผ่านโปรแกรมจัดการฐานข้อมูลที่เครื่อง Client อีกครั้ง ท่านใดใช้เครื่องมือจัดการฐานข้อมูลที่เครื่อง Client เชื่อมต่อไปยัง Server แล้วเชื่อมต่อไม่ได้ ลองตรวจสอบการตั้งค่า Windows Firewall ดูนะครับ ข้อสังเกต ไม่ได้เกิดจากการตั้ง Host name ของ MySQL User เพราะตั้งเป็น % เรียบร้อย (คือเชื่อมต่อได้จากทุก iP) แต่ถ้าตั้งค่า Host name แล้วแต่ยังไม่ได้จะมีข้อความแจ้งเตือนอีกแบบ Access denied for '.....'@ 'เลขไอพีหรือComputername' ซึ่งถ้าสั่งคิวรี่คำสั่ง flush...

PHP CI MANIA : ตอนที่ 11 วิธีสร้างแบบฟอร์มบันทึกข้อมูลแบบ Master - Detail เพิ่ม/ลบ/แก้ไข รายการย่อยได้

การสร้างแบบฟอร์มแบบ Master & Detail ก็คือการทำงานกับตาราง 2 ตาราง โดยที่จะมีการบันทึกข้อมูลหลักส่วนที่ 1 และมีแบบฟอร์มสำหรับบันทึกข้อมูลรายการ ในส่วนที่ 2 ดังภาพ ส่วนของการตั้งค่าจะอยู่ในแท็ป " ตั้งค่า" ส่วนที่ 4 ด้านล่างสุด "ข้อมูลตารางรายการ (Detail)" 1. เลือกตารางที่จะใช้บันทึกรายการ เช่นหน้าเว็บนี้คือการบันทึกประวัติ Resume ดังนั้นก็จะมีตารางเก็บผลงานต่างๆ นั่นก็คือตาราง tb_portfolio ที่เลือกในภาพ 2. จะปรากฏข้อมูลฟิลด์ของตารางที่เลือกเพิ่มมาด้านล่าง 3. ดูในส่วนของตารางหลัก (Master) ใน tb_resume จะมีฟิลด์ที่เป็น Primary Key ชื่อว่า resume_id ดังที่เลือกไว้ในภาพ 4. จากนั้นก็ย้ายมาด้านตารางรายการ (Detail) เราจะต้องเลือก Foreign Key หรือง่ายๆก็คือ เลือกฟิลด์ที่เราจะเอาไอดีของตารางหลัก มาใส่อ้างอิงในแต่ละรายการนั่นเอง 5. หลังจากนั้นก็กำหนดรูปแบบช่อง INPUT เหมือนกับที่กำหนดให้ตารางหลัก ในบทที่ผ่านๆมา คือ ช่องวันที่ ช่องอัพโหลดไฟล์ ช่องตัวเลข หรือการ JOIN ต่างๆ 6. หลังจากนั้นให้คลิกสร้างไฟล์ Models, Views, JS และ Controller...

ขั้นตอนการเปิด Error ใน CodeIgniter 4 เมื่อข้อความ Whoops!

ขั้นตอนการเปิด Error ใน CodeIgniter 4 Whoops! We seem to have hit a snag. Please try again later... เมื่อเกิดข้อผิดพลาด CodeIgniter 4 จะไม่แสดง Error message ออกมาให้เห็น เพราะตั้งค่าไว้ให้รันในโหมดเว็บเซิร์ฟเวอร์จริง (Production Server) เพื่อค้นหาวิธีการเปิดข้อความ Error จึงลองค้นหาใน Google ด้วยคำว่า "how to debug codeigniter 4" ก็ได้วิธีมาว่า ให้แก้ไขค่าที่ไฟล์ env โดยแก้ไขชื่อไฟล์เป็น .env หากใช้ Notepad++ ก็ให้คลิกขวา แล้วเลือก Edit with Notepad++ เลื่อนหาบรรทัด CI_ENVIRONMENT และทำการเปลี่ยนค่า ให้ลบเครื่องหมาย # ด้านหน้าออก และเปลี่ยนค่า production เป็น development กลับไปที่หน้าเว็บบราวเซอร์ แล้วกดรีเฟรชหน้าเว็บอีกครั้ง (F5) ก็จะปรากฏข้อความแสดง error ออกมาให้ Debug กันได้ง่ายขึ้น * หมายเหตุ * กรณีนำไปใช้บนเว็บโฮสติ้ง หรือบนเว็บเซิร์ฟเวอร์จริง (Production Server) ให้ทำการแก้ไขค่าเป็น production ก่อนอัพโหลด ที่มา :  https://stackoverflow.com/questions/60501607/how-to-debug-codeigniter-4 PHP  CI  MANIA   - PHP Code Generator  โป...

การส่งค่าผ่านแบบฟอร์มและลิงค์ไปยังไฟล์ PHP และการรับค่าผ่านตัวแปรต่างๆ

การรับค่าจากแบบฟอร์มนั้น PHP จะใช้ตัวแปรอยู่ 3 แบบด้วยกัน คือ  $_GET, $_POST, $_REQUEST ซึ่งแต่ละแบบจะมีการส่งค่าดังนี้ 1. $_GET จะส่งค่าผ่าน URL เราจะเห็นพารามิเตอร์ที่ส่งไปต่อท้าย URL ของหน้านั้นๆ 2. $_POST จะส่งแบบไม่แสดงพารามิเตอร์ให้เห็นส่วนใหญ่จะใช้กับการส่งค่าใน HTML FORM 3. $_REQUEST จะเป็นตัวแปรที่ใช้รับค่าได้ทั้งที่ส่งมาแบบ $_GET และ $_POST สำหรับขั้นตอนการค้นหาข้อมูลเพื่อนำมาทดสอบ เราจะใช้คีย์เวิร์ดดังนี้ เข้าไปที่เว็บไซต์ www.google.co.th แล้วค้นหาคำว่า "php การรับค่า ฟอร์ม" จากนั้นก็ลองนำซอร์สโค๊ดตัวอย่างมาทดลองดูว่าได้ผลอย่างไรบ้างและแตกต่างกันอย่างไร การส่งค่าผ่าน HTML FORM และ เมนูลิงค์ต่างๆ <html>    <head>        <meta content="text/html; charset=utf-8" http-equiv="Content-Type" />        <title>ทดสอบ การรับค่าผ่านฟอร์ม คำนวณพื้นที่สี่เหลี่ยม</title>    </head>    <body>    | <a href="form-reque...

PHP + Fullcalendar กับ MySQL

หลักการทำงาน เรียกข้อมูลจากตาราง tb_event ด้วยฟังก์ชั่นของ MySQLi ข้อมูลจากฐานข้อมูลจะถูกวนลูปเก็บไว้ใน $data และจะถูกส่งไปที่ Fullcalendar ด้วยการแปลงข้อมูลจาก PHP ให้อยู่ในรูปแบบ JSON อาร์เรย์ด้วยฟังก์ชั่น json_encode()

การลิงค์เชื่อมโยง การเลื่อนสกอร์บาร์ หรือการกระโดดไปยังจุดต่างๆบนหน้าเว็บที่ต้องการด้วย JavaScript

สำหรับการเลื่อนหน้าจอไปยังจุดต่างๆนั้น จะเกี่ยวข้องกับ  HTML Links ซึ่งปกติเราจะใช้แท็ก <a> และกำหนดแอตทริบิวต์ name="xxxx" ชื่อที่เราต้องการกำหนดจุดไว้ เช่น เราสร้าง <a name="top"></a> ไว้บนส่วนของหัวข้อ เมื่อเราอ่านบทความจนถึงหน้าท้าย เราสามารถสร้างลิงค์ หรือจุดเชื่อมโยงกลับขึ้นไปด้านบนที่หัวข้อได้ง่ายๆดังนี้ <a href="#top">กลับไปยังด้านบน</a> ซึ่งเราสามารถสร้างฟังก์ชั่นด้วย JavaScript แบบง่ายๆได้ดังนี้ <script> function jump(h){     var url = location.href;               //Save down the URL without hash.     location.href = "#"+h;                 //Go to the target element.     history.replaceState(null,null,url);   //Don't like hashes. Changing it back. } </script> การเรียกใช้งาน <button onclick="jump('top')">กลับไปยังด้านบน</button> แต่ถ้าอยากให้มีเลื่อนหน้าจอแบบหน่ว...

MySQL คำสั่ง SQL จัดเรียงคำตามตัวอักษร ภาษาไทย ในฟิลด์ที่กำหนด Collation เป็น utf-8

การจัดเรียงข้อมูลตามลำดับตัวอักษรไทย   CONVERT( name USING tis620 ) ASC การเรียงลำดับตัวอักษรแบบ tis-620 ในการเขียนโปรแกรม PHP เพื่อแสดงข้อมูลจากฐานข้อมูล MySQL การเขียนคำสั่ง SQL ให้จัดเรียงลำดับนั้น เราจะใช้ ORDER BY  และกำหนดฟิลด์ที่ต้องการจัดเรียงลำดับ เช่น ในตัวอย่างนี้จะเป็นการจัดเรียงตามลำดับตัวอักษรของชื่อเมนู นั่นก็คือฟิลด์ name นั่นเอง แต่ในขั้นตอนการสร้างฐานข้อมูลนั้น เราได้กำหนด Charset ของตารางและฟิลด์เป็นการจัดเรียง Collation แบบ utf-8 เอาไว้เพื่อให้รองรับภาษาแบบมาตรฐาน ดังนั้นเมื่อเขียนโปรแกรมสั่ง ORDER BY name ASC ก็จะมีการจัดเรียงที่จะให้คำที่มีสระนำหน้าอยู่หลัง ฮ. นกฮุก ไปเสียหมด จะเห็นว่าชื่อเมนูหรือสินค้าที่มี ข นำหน้าจะมาเป็นลำดับแรก ทั้งที่จริงๆแล้ว มีสินค้าที่เป็น ก อยู่หลายรายการ เพียงแต่ว่ามีสระนำหน้าอยู่เท่านั้นเอง จากรูปด้านบน จะมีรายการที่เป็น ก อยู่ 3 รายการ คือเมนู โกโก้ ต่างๆ แต่เพราะมีสระโอ นำหน้า จึงทำให้การจัดเรียงแบบ utf-8 ให้อยู่ในลำดับท้าย เพื่อแก้ไขปัญหานี้ การเขียนโปรแกรมเพื่อ ORDER BY จะต้...

ค้นหาบล็อกนี้