[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"academy-blogs-th-1-1-all-ep-125-tls-wss-certificate-management-for-websocket-all--*":3,"academy-blog-translations-fi5y0zd7vudw30e":74},{"data":4,"page":62,"perPage":62,"totalItems":62,"totalPages":62},[5],{"alt":6,"collectionId":7,"collectionName":8,"content":9,"cover_image":10,"cover_image_path":11,"created":12,"created_by":13,"expand":14,"id":68,"keywords":69,"locale":44,"published_at":70,"scheduled_at":13,"school_blog":66,"short_description":71,"slug":72,"status":64,"title":6,"updated":73,"updated_by":13,"views":67},"EP.125 TLS \u002F WSS และ Certificate Management สำหรับ WebSocket (Production & Enterprise)","sclblg987654321","school_blog_translations","\u003Cp>ถ้า EP.124 คือการ “ล็อกประตูด้วย Authentication”\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>EP.125 คือการ “เสริมเกราะทั้งอาคาร” ด้วย TLS และ Certificate ที่ถูกต้อง\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>เพราะ WebSocket ที่ ไม่มี WSS = ข้อมูลสามารถถูกดักฟัง แก้ไข หรือปลอมแปลงได้ง่ายกว่าที่คิด แม้ระบบภายในจะ Auth ดีแค่ไหนก็ตาม\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🎯 เป้าหมายของบทความนี้\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>หลังอ่านจบ คุณจะเข้าใจ:\u003C\u002Fp>\u003Cul>\u003Cli>ความแตกต่างระหว่าง HTTPS vs WSS\u003C\u002Fli>\u003Cli>TLS Handshake ทำงานอย่างไรกับ WebSocket\u003C\u002Fli>\u003Cli>การจัดการ Certificate ในระบบ Production\u003C\u002Fli>\u003Cli>การทำ Zero-downtime Certificate Renewal\u003C\u002Fli>\u003Cli>Best Practices สำหรับ WebSocket ระดับ Enterprise\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔍 HTTPS vs WSS ต่างกันอย่างไร?\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cfigure class=\"table\">\u003Ctable>\u003Cthead>\u003Ctr>\u003Cth>Protocol\u003C\u002Fth>\u003Cth>ใช้กับ\u003C\u002Fth>\u003Cth>ความปลอดภัย\u003C\u002Fth>\u003C\u002Ftr>\u003C\u002Fthead>\u003Ctbody>\u003Ctr>\u003Ctd>HTTP\u003C\u002Ftd>\u003Ctd>Web ธรรมดา\u003C\u002Ftd>\u003Ctd>❌ ไม่เข้ารหัส\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>HTTPS\u003C\u002Ftd>\u003Ctd>REST \u002F Web\u003C\u002Ftd>\u003Ctd>✅ TLS\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>WS\u003C\u002Ftd>\u003Ctd>WebSocket\u003C\u002Ftd>\u003Ctd>❌ ไม่เข้ารหัส\u003C\u002Ftd>\u003C\u002Ftr>\u003Ctr>\u003Ctd>WSS\u003C\u002Ftd>\u003Ctd>WebSocket\u003C\u002Ftd>\u003Ctd>✅ TLS\u003C\u002Ftd>\u003C\u002Ftr>\u003C\u002Ftbody>\u003C\u002Ftable>\u003C\u002Ffigure>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>❗ WebSocket ที่เป็น \u003Ccode inline=\"\">ws:\u002F\u002F\u003C\u002Fcode> ไม่ปลอดภัย แม้เว็บหลักจะเป็น \u003Ccode inline=\"\">https:\u002F\u002F\u003C\u002Fcode> ก็ตาม\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧠 ความจริงที่หลายคนพลาด\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cul>\u003Cli>HTTPS ≠ WSS\u003C\u002Fli>\u003Cli>TLS ไม่ถูกแชร์อัตโนมัติ ระหว่าง HTTP และ WebSocket\u003C\u002Fli>\u003Cli>ถ้า WebSocket ใช้ \u003Ccode inline=\"\">ws:\u002F\u002F\u003C\u002Fcode> → ข้อมูลจะวิ่งแบบ Plain Text\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>เพิ่มเติมที่สำคัญ:\u003C\u002Fp>\u003Cul>\u003Cli>Browser จะ block \u003Ccode inline=\"\">ws:\u002F\u002F\u003C\u002Fcode> หากหน้าเว็บโหลดผ่าน \u003Ccode inline=\"\">https:\u002F\u002F\u003C\u002Fcode>\u003C\u002Fli>\u003Cli>ระบบ Production ทุกระบบ ต้องใช้ \u003Ccode inline=\"\">wss:\u002F\u002F\u003C\u002Fcode> เท่านั้น\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>👉 ไม่มีข้อยกเว้นสำหรับระบบจริง\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔐 TLS Handshake กับ WebSocket ทำงานอย่างไร?\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ลำดับการทำงานจริง:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">Client\n  ↓ TLS Handshake\nServer\n  ↓ Certificate Verification\nSecure Channel Established\n  ↓ HTTP Upgrade (101 Switching Protocols)\nWebSocket Connected (Encrypted)\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>📌 TLS ทำงานก่อน WebSocket เสมอ\u003Cbr>WebSocket จะถูกสร้างขึ้นก็ต่อเมื่อ Secure Channel พร้อมแล้วเท่านั้น\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>📜 Certificate คืออะไร (ในมุม WebSocket)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Certificate ทำหน้าที่หลัก 3 อย่าง:\u003C\u002Fp>\u003Col>\u003Cli>ยืนยันตัวตนของ Server (Authentication)\u003C\u002Fli>\u003Cli>เข้ารหัสข้อมูล (Confidentiality)\u003C\u002Fli>\u003Cli>ป้องกัน Man-in-the-Middle Attack\u003C\u002Fli>\u003C\u002Fol>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ข้อสำคัญ:\u003C\u002Fp>\u003Cul>\u003Cli>WebSocket ใช้ Certificate เดียวกับ HTTPS\u003C\u002Fli>\u003Cli>ไม่มี Certificate แยกสำหรับ WebSocket โดยเฉพาะ\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧩 ตัวอย่างตั้งค่า WSS ใน Go (พื้นฐาน Production)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-go\">server := &amp;http.Server{\n    Addr: \":443\",\n    Handler: router,\n    TLSConfig: &amp;tls.Config{\n        MinVersion: tls.VersionTLS12,\n    },\n}\n\nlog.Fatal(server.ListenAndServeTLS(\n    \"\u002Fcert\u002Ffullchain.pem\",\n    \"\u002Fcert\u002Fprivkey.pem\",\n))\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ แนะนำ:\u003C\u002Fp>\u003Cul>\u003Cli>TLS 1.2+ เท่านั้น\u003C\u002Fli>\u003Cli>หากเป็นระบบใหม่ ควรเปิด TLS 1.3 ด้วย\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔄 Certificate Rotation คืออะไร?\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>ปัญหาที่พบบ่อย\u003C\u002Fh3>\u003Cul>\u003Cli>Certificate มีวันหมดอายุ\u003C\u002Fli>\u003Cli>Restart Server = WebSocket หลุดทั้งหมด ❌\u003C\u002Fli>\u003Cli>ผู้ใช้ reconnect พร้อมกัน → Load พุ่ง\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>เป้าหมายของระบบที่ดี\u003C\u002Fh3>\u003Cblockquote>\u003Cp>เปลี่ยน Certificate ได้\u003Cbr>โดยไม่กระทบ WebSocket Connection ที่กำลังใช้งานอยู่\u003C\u002Fp>\u003C\u002Fblockquote>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>♻️ Zero-downtime Certificate Renewal (แนวคิดที่ใช้จริง)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>แนวทางระดับ Production:\u003C\u002Fp>\u003Cul>\u003Cli>ทำ TLS Termination ที่ Load Balancer \u002F Reverse Proxy\u003C\u002Fli>\u003Cli>Reload Certificate แบบ Runtime\u003C\u002Fli>\u003Cli>Rolling Update ทีละ Instance (หากจำเป็น)\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🏗️ Best Practice Architecture\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext\">Client\n  ↓ WSS\nLoad Balancer \u002F Reverse Proxy (TLS Termination)\n  ↓ WS (Internal)\nWebSocket Servers\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>ข้อดีของโครงสร้างนี้\u003C\u002Fh3>\u003Cul>\u003Cli>เปลี่ยน Certificate ที่ Load Balancer ได้\u003C\u002Fli>\u003Cli>WebSocket Server ไม่ต้อง restart\u003C\u002Fli>\u003Cli>Scale ง่าย\u003C\u002Fli>\u003Cli>ลดความซับซ้อนของ Certificate Management\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🌱 Let’s Encrypt สำหรับ WebSocket\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Let’s Encrypt:\u003C\u002Fp>\u003Cul>\u003Cli>ฟรี\u003C\u002Fli>\u003Cli>Trusted โดย Browser\u003C\u002Fli>\u003Cli>Auto-renew\u003C\u002Fli>\u003Cli>ใช้ได้ทั้ง HTTPS และ WSS\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch3>Tools ที่นิยม\u003C\u002Fh3>\u003Cul>\u003Cli>Certbot\u003C\u002Fli>\u003Cli>acme.sh\u003C\u002Fli>\u003Cli>Kubernetes cert-manager\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔧 ตัวอย่าง Certbot Renewal (แนวคิด)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-bash\">certbot renew --quiet\nsystemctl reload nginx\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>📌 Reload ≠ Restart\u003Cbr>WebSocket Connection จะไม่ถูกตัด\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>☁️ Kubernetes + cert-manager (Production Grade)\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>แนวทางที่ใช้จริง:\u003C\u002Fp>\u003Cul>\u003Cli>cert-manager + Let’s Encrypt\u003C\u002Fli>\u003Cli>Auto renew\u003C\u002Fli>\u003Cli>Zero downtime\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ตัวอย่าง Certificate Resource:\u003C\u002Fp>\u003Cpre>\u003Ccode class=\"language-plaintext language-yaml\">apiVersion: cert-manager.io\u002Fv1\nkind: Certificate\nspec:\n  secretName: ws-tls\n  dnsNames:\n    - ws.example.com\n\u003C\u002Fcode>\u003C\u002Fpre>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>Ingress \u002F Gateway จะ reload cert ให้โดยอัตโนมัติ\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🛑 Common Mistakes ที่ควรเลี่ยง\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>❌ ใช้ self-signed certificate ใน production\u003Cbr>❌ เปิด TLS version ต่ำ\u003Cbr>❌ Hard-code path certificate\u003Cbr>❌ Restart server ทุกครั้งที่ renew cert\u003Cbr>❌ ไม่ทดสอบ renewal ล่วงหน้า\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🧪 Checklist ก่อนขึ้น Production\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>✅ ใช้ \u003Ccode inline=\"\">wss:\u002F\u002F\u003C\u002Fcode> เท่านั้น\u003Cbr>✅ TLS 1.2+ (แนะนำ 1.3)\u003Cbr>✅ Auto certificate renewal\u003Cbr>✅ No server restart on renew\u003Cbr>✅ ใช้ Load Balancer \u002F Reverse Proxy\u003Cbr>✅ Test renewal ก่อน cert หมดอายุจริง\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🚀 ท้าให้ลอง!\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ลอง Audit ระบบ WebSocket ของคุณ:\u003C\u002Fp>\u003Cul>\u003Cli>เชื่อมต่อด้วย \u003Ccode inline=\"\">wss:\u002F\u002F\u003C\u002Fcode>\u003C\u002Fli>\u003Cli>ตรวจ TLS version ที่ใช้จริง\u003C\u002Fli>\u003Cli>จำลอง certificate ใกล้หมดอายุ\u003C\u002Fli>\u003Cli>Renew cert โดยไม่ restart server\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>ถ้าทำได้ครบ 👉 ระบบของคุณ พร้อม Production จริงแล้ว 🔥\u003C\u002Fp>\u003Cp>&nbsp;\u003C\u002Fp>\u003Chr>\u003Cp>&nbsp;\u003C\u002Fp>\u003Ch2>🔮 EP ถัดไป EP.126 DDoS Protection &amp; Rate Limiting สำหรับ WebSocket\u003C\u002Fh2>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cp>เราจะเจาะลึก:\u003C\u002Fp>\u003Cul>\u003Cli>Connection Flood\u003C\u002Fli>\u003Cli>Rate Limit ต่อ IP \u002F User\u003C\u002Fli>\u003Cli>ป้องกัน Bot &amp; Abuse\u003C\u002Fli>\u003Cli>WebSocket Security ในสนามจริง\u003C\u002Fli>\u003C\u002Ful>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cdiv class=\"raw-html-embed\">\u003Cdiv style=\"margin:0 0 6px 0; font-weight:700;\">อ่านบทความ Series อื่นๆ:\u003C\u002Fdiv>\n\u003Cul style=\"list-style:none; padding:0; margin:0; line-height:1.4;\">\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fblogs\u002Fcategories\u002FGolang\" title=\"Golang The Series\">Golang The Series\u003C\u002Fa>\u003C\u002Fli>\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fblogs\u002Fcategories\u002FJS2GO\" title=\"JS2GO\">JS2GO\u003C\u002Fa>\u003C\u002Fli>\n  \u003Cli style=\"margin:0;\">\u003Ca href=\"\u002Fblogs\u002Fcategories\u002FTailwind%20CSS\" title=\"10 Ep ที่จะให้คุณเป็นมือโปร Tailwind CSS ในชั่วข้ามคืน\">10 Ep ที่จะให้คุณเป็นมือโปร Tailwind CSS ในชั่วข้ามคืน\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\u003C\u002Fdiv>\u003Cp>&nbsp;\u003C\u002Fp>\u003Cdiv class=\"raw-html-embed\">\n  \u003Cp style=\"margin:0 0 6px 0;\">\u003Cstrong>Follow Us:\u003C\u002Fstrong>\u003C\u002Fp>\n  \u003Cul style=\"list-style:none; padding:0; margin:0; line-height: 0.4;\">\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#1877F2\" aria-hidden=\"true\">\n        \u003Cpath d=\"M22 12.07C22 6.48 17.52 2 11.93 2S2 6.48 2 12.07c0 5 3.66 9.14 8.44 9.93v-7.02H7.9v-2.91h2.54V9.41c0-2.5 1.49-3.88 3.77-3.88 1.09 0 2.24.2 2.24.2v2.46h-1.26c-1.24 0-1.63.77-1.63 1.56v1.87h2.78l-.44 2.91h-2.34V22c4.78-.79 8.44-4.93 8.44-9.93Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.facebook.com\u002Fsuperdev.academy.th\" target=\"_blank\" rel=\"nofollow noopener\" title=\"Follow Superdev Academy on Facebook\">Facebook: Superdev Academy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#FF0000\" aria-hidden=\"true\">\n        \u003Cpath d=\"M23.5 6.2a3 3 0 0 0-2.1-2.1C19.5 3.5 12 3.5 12 3.5s-7.5 0-9.4.6A3 3 0 0 0 .5 6.2 31.5 31.5 0 0 0 0 12a31.5 31.5 0 0 0 .5 5.8 3 3 0 0 0 2.1 2.1c1.9.6 9.4.6 9.4.6s7.5 0 9.4-.6a3 3 0 0 0 2.1-2.1A31.5 31.5 0 0 0 24 12a31.5 31.5 0 0 0-.5-5.8ZM9.75 15.02V8.98L15.5 12l-5.75 3.02Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.youtube.com\u002F@SuperdevAcademy\" target=\"_blank\" rel=\"nofollow noopener\" title=\"Watch on YouTube\">YouTube: Superdev Academy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#E4405F\" aria-hidden=\"true\">\n        \u003Cpath d=\"M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5Zm10 2H7a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3Zm-5 3.5A5.5 5.5 0 1 1 6.5 13 5.5 5.5 0 0 1 12 7.5Zm0 2A3.5 3.5 0 1 0 15.5 13 3.5 3.5 0 0 0 12 9.5Zm5.75-2.75a1.25 1.25 0 1 1-1.25 1.25 1.25 1.25 0 0 1 1.25-1.25Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.instagram.com\u002Fsuperdevacademy\u002F?hl=en target=\" _blank\"=\"\" rel=\"nofollow noopener\" title=\"See behind-the-scenes on Instagram\">Instagram: Superdev Academy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#000000\" aria-hidden=\"true\">\n        \u003Cpath d=\"M21 8.12a6.86 6.86 0 0 1-4.8-2V16a6 6 0 1 1-6-6 5.9 5.9 0 0 1 1.63.23V8.05a9.08 9.08 0 0 1-1.63-.15V4.5a6.86 6.86 0 0 0 4.8 2.05V6.5a6.86 6.86 0 0 0 4.8 1.62ZM9.2 12.5A3.5 3.5 0 1 0 12.7 16V9.94a6 6 0 0 1-1.63-.27v3.95a3.5 3.5 0 0 1-1.87 3.17 3.5 3.5 0 0 1-4.78-3.23 3.5 3.5 0 0 1 4.78-3.06Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.tiktok.com\u002F@superdevacademy\" target=\"_blank\" rel=\"nofollow noopener\" title=\"Watch short tips on TikTok\">TikTok: @superdevacademy\u003C\u002Fa>\n    \u003C\u002Fli>\n\n    \u003Cli style=\"display:flex; align-items:center; gap:6px; margin:0;\">\n      \n      \u003Csvg width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"#111827\" aria-hidden=\"true\">\n        \u003Cpath d=\"M12 2a10 10 0 1 0 10 10A10.01 10.01 0 0 0 12 2Zm6.93 6h-3.26a15.6 15.6 0 0 0-1.39-3.62A8.03 8.03 0 0 1 18.93 8ZM12 4c.73.93 1.7 2.74 2.2 4H9.8C10.3 6.74 11.27 4.93 12 4ZM8.72 4.38A15.6 15.6 0 0 0 7.32 8H4.07a8.03 8.03 0 0 1 4.65-3.62ZM4.07 16h3.25a15.6 15.6 0 0 0 1.4 3.62A8.03 8.03 0 0 1 4.07 16ZM12 20c-.73-.93-1.7-2.74-2.2-4h4.4C13.7 17.26 12.73 19.07 12 20Zm3.28-.38A15.6 15.6 0 0 0 16.68 16h3.25a8.03 8.03 0 0 1-4.65 3.62ZM20 14h-3.54a13.8 13.8 0 0 1-.26-4H20a7.98 7.98 0 0 1 0 4Zm-12.2 0H4a7.98 7.98 0 0 1 0-4h3.54a13.8 13.8 0 0 1-.26 4Zm2 .5h4.4a17.8 17.8 0 0 1-.72-4.5c0-1.58.25-3.1.72-4.5H9.8a17.8 17.8 0 0 1 .72 4.5c0 1.58-.25 3.1-.72 4.5Z\">\u003C\u002Fpath>\n      \u003C\u002Fsvg>\n      \u003Ca href=\"https:\u002F\u002Fwww.superdevacademy.com\u002F\" target=\"_blank\" rel=\"noopener\" title=\"Visit the official website of Superdev Academy\">Official Website: Superdev Academy.com\u003C\u002Fa>\n    \u003C\u002Fli>\n  \u003C\u002Ful>\n\u003C\u002Fdiv>","cover_image_ep_1msbjluc3y.EnterpriseGuide.webp","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclblg987654321\u002Frn62rb24heeyiyo\u002Fcover_image_ep_1msbjluc3y.EnterpriseGuide.webp","2026-03-04 08:44:42.802Z","",{"keywords":15,"locale":38,"school_blog":48},[16,23,28,33],{"collectionId":17,"collectionName":18,"created":19,"created_by":13,"id":20,"name":21,"updated":22,"updated_by":13},"sclkey987654321","school_keywords","2026-03-04 08:44:41.631Z","sipxojme8z97ei7","WebSocket TLS","2026-04-10 16:12:48.685Z",{"collectionId":17,"collectionName":18,"created":24,"created_by":13,"id":25,"name":26,"updated":27,"updated_by":13},"2026-03-04 08:44:41.420Z","xjki2vhsm3f0jb4","WSS WebSocket","2026-04-10 16:12:48.600Z",{"collectionId":17,"collectionName":18,"created":29,"created_by":13,"id":30,"name":31,"updated":32,"updated_by":13},"2026-03-04 08:34:00.920Z","ecac9y661or1xka","WebSocket","2026-04-10 16:08:05.227Z",{"collectionId":17,"collectionName":18,"created":34,"created_by":13,"id":35,"name":36,"updated":37,"updated_by":13},"2026-03-04 08:20:11.547Z","ey3puyme01a9bsw","Go","2026-04-10 16:07:25.893Z",{"code":39,"collectionId":40,"collectionName":41,"created":42,"flag":43,"id":44,"is_default":45,"label":46,"updated":47},"th","pbc_1989393366","locales","2026-01-22 10:59:55.832Z","twemoji:flag-thailand","s8wri3bt4vgg2ji",true,"Thai","2026-04-10 15:42:46.614Z",{"category":49,"collectionId":50,"collectionName":51,"expand":52,"id":66,"views":67},"wqxt7ag2gn7xcmk","pbc_2105096300","school_blogs",{"category":53},{"blogIds":54,"collectionId":55,"collectionName":56,"created":57,"created_by":13,"id":49,"image":58,"image_alt":13,"image_path":59,"label":60,"name":61,"priority":62,"publish_at":63,"scheduled_at":13,"status":64,"updated":65,"updated_by":13},[],"sclcatblg987654321","school_category_blogs","2026-03-04 08:33:53.210Z","59ty92ns80w_15oc1implw.png","https:\u002F\u002Ftwsme-r2.tumwebsme.com\u002Fsclcatblg987654321\u002Fwqxt7ag2gn7xcmk\u002F59ty92ns80w_15oc1implw.png",{"en":61,"th":61},"Golang The Series",1,"2026-03-16 04:39:38.440Z","published","2026-04-25 02:32:15.470Z","fi5y0zd7vudw30e",234,"rn62rb24heeyiyo",[20,25,30,35],"2026-01-12 03:50:15.171Z","เจาะลึกการใช้งาน TLS และ WSS สำหรับ WebSocket ตั้งแต่ความแตกต่างของ HTTPS vs WSS, การทำงานของ TLS Handshake, การจัดการ Certificate, Let’s Encrypt ไปจนถึง Zero-downtime Renewal สำหรับระบบ Production และ Enterprise","ep-125-tls-wss-certificate-management-for-websocket","2026-04-25 02:47:45.054Z",{"th":72}]