รำลึกอดีตให้ฟังหน่อยนึงว่าหลังจากเข้าไปร่วมงาน NWA แล้วผมก็โดนเวทล้างสมองของ Sirn ให้หันมามอง Pylons เลยลองเล่นดูนิดหน่อย แต่ก็ไม่วายโดนรับน้องจนได้
ถ้าเราติดตั้ง Pylons ด้วย easy_install โดยไม่ระบุเวอร์ชัน ตัว Easy_install จะลง เป็นเวอร์ชัน 0.9.7rc1 ให้โดยอัตโนมัติ ซึ่งใน 0.9.7 นั่นมันจะมี Breaking Change อยู่จำนวนหนึ่ง แต่ในวิกิของ Pylons ยังไม่มีข้อมูลนี้
บังเอิญว่าผมดันไปเลือกใช้ 0.9.7 โดยไม่รู้อิโหน่อิเหน่ ค้นวิธีแก้ยังไงก็ไม่เจอ สถานการณ์แบบนี้ผมเรียกว่า ซวย ครับ
หนึ่งใน Breaking Change ที่โดนแน่ๆคือเรื่อง Webhelper แต่นั่นเป็นเรื่องที่เราจะไม่พูดกันครั้งนี้ เพราะครั้งนี้เราจะบอกถึง Breaking Change ที่ทำให้ผมเซ้งเซ็งอีกเรื่องแทน นั่นคือ Routing เป็นยังไงมาติดตามดู
เนื่องจากเป็นเด็กใหม่ เราก็ต้องทำตัวเป็นเด็กใหม่ที่ดีด้วยการศึกษาตาม Getting started ที่เค้าทำมาให้ หลังจากกำลังภายในของผมเริ่มหมดไปกับการถาม sirn และ vsatayamas ไปแล้ว ผมก็ฟันฝ่าตัว Getting Started มาจนถึงการทำ controller และ action แล้วล่ะ
จากใน Docs หลังจากสร้าง HelloController เสร็จแล้วก็ต้องก็สร้าง method index ขึ้นมา หลังจากทำขั้นตอนดังกล่าวผมก็เปิดด้วยความกระหยิ่มยิ้มย่อง เข้าหน้า http://localhost:5000/hello ตามสเต็ปเป๊ะๆๆๆ สิ่งที่โผล่ขึ้นมาต้อนรับเป็นข้อความอันคุ้นเคย
404 Not Found
ความคิดที่แว่บเข้ามาในหัว “นั่นไง โดนเข้าแล้ว”
เป็นที่ Routing ชัวร์ๆ อีแบบนี้ ก็เลยเปิดดูใน config/routes.py ก็มีบรรทัดแบบนี้อยู่แล้ว
map.connect(‘/{controller}/{action}’)
map.connect(‘/{controller}/{action}/{id}’)
อ่านคร่าวๆ หมายความว่าจะได้ Route URL ในลักษณะนี้
/{controller}/{action}/{id}
แล้วถ้าไม่ระบุ action ก็ต้อง route แบบนี้
/{controller}/{action}
แล้วผิดตรงไหน ลองไปลองมาก็เลยฉุกคิดได้นิดนึง เปลี่ยนไปเข้า http://localhost:5000/hello/index แทน ปรากฏว่าหรามาเลยครับ Hello world!!!
เลยตะหงิดๆ ขึ้นไปดูในคู่มือของ Routes ได้ความว่า ใน Routes รุ่นใหม่ที่มาพร้อมกับ Pylons 0.97 จะมีเรื่อง minimization เข้ามา คือจะไม่มีการ map url แบบครึ่งๆกลางๆแล้ว
ดังนั้นจากที่คิดว่า /{controller}/{action} จะได้ map ไปผูกกับ controller ที่ระบุแล้วกำหนด action เป็น index เองถ้าไม่กำหนด ก็หมดสิทธิทำแบบนี้แล้ว
อธิบายเป็นภาษาคนก็คือ ต้องระบุ action ทุกครั้งด้วยนะจ๊ะเด็กโง่
แต่เฮ้ย ชาวบ้านชาวเมืองเค้าไม่เห็นต้องระบุ action ก็ยังเรียก index ให้ Pylons จะยอมน้อยหน้าได้ไง ขนาด ASP.NET MVC ยังทำได้เลย ถ้า Pylons ทำไม่ได้ย้ายกลับนะเฟร้ย
เลยไปค้นๆมา ได้ความว่ามันก็มีทางเปิดใช้ minimization เพื่อให้ Routes ทำงานตามพฤติกรรมเดิม โดยในไฟล์ Routes.py จะมีบรรทัดนึงที่เขียนว่า
map.minimization = False
ก็แก้เป็น True ซะก็สิ้นเรื่อง ง่ายมะๆ
แต่ช้าก่อน ถ้ามันง่ายขนาดนั้น แล้วไม่เปิดใช้ไว้ตั้งแต่แรกฟระ ความจริงปรากฏว่า Routes รุ่นถัดไปจะไม่ยอมให้เปิดการทำงานของ Minimization แล้ว วิธีแก้ที่ยั่งยืนกว่าคือ เพิ่มกฏเอง
ฟังดูเหมือนจะยาก แต่แค่เพิ่มเข้าไปบรรทัดนึงเท่านั้นเอง
map.connect(‘/{controller}’, action=’index’)
แบบนี้ ถ้าเข้า http://localhost:5000/hello ก็จะวิ่งไป index ให้แล้ว
ก็ง่ายๆเช่นนี้แล
ด้วยรักและไพลอนส์
ปล. แต่ว่าเข้า http://localhost:5000/hello/ ก็ยัง 404 นะ

