วิธีเชื่อมต่อระบบยืนยันตัวตนจากแอปกับ OCPP Central System
ในยุคที่สถานีชาร์จรถยนต์ไฟฟ้ากำลังขยายตัว แอปมือถือและแดชบอร์ดผู้ดูแลเป็นเครื่องมือสำคัญในการควบคุมระบบ แต่เราจะ ยืนยันตัวตนผู้ใช้ และเชื่อมโยงการสั่งงานของผู้ใช้กับสถานีชาร์จ (EVSE) อย่างปลอดภัยได้อย่างไร?
บทความนี้จะแนะนำวิธีผสานระบบยืนยันตัวตนจากแอปเข้ากับ OCPP Central System (CSMS) ได้อย่างราบรื่น
🧩 ภาพรวมของระบบ
องค์ประกอบหลัก:
- แอปมือถือ / แดชบอร์ด – ผู้ใช้ล็อกอินและควบคุมการชาร์จ
- Central System API (Flask) – REST API สำหรับเชื่อมต่อกับระบบ
- OCPP WebSocket Server – ติดต่อกับ EVSE ผ่าน OCPP 1.6
- MongoDB – เก็บข้อมูลผู้ใช้และสถานีชาร์จ
📊 แผนภาพ Sequence Diagram: เริ่มชาร์จจากแอป
sequenceDiagram
participant User as Mobile App
participant API as Flask API Server
participant CSMS as OCPP Central System
participant EVSE as Charger (EVSE)
User->>API: POST /api/login (username, password)
API-->>User: JWT token + idTag
User->>API: POST /api/start_charging (evse_id, connector_id, token)
API->>CSMS: RemoteStartTransaction(idTag, connectorId)
CSMS->>EVSE: RemoteStartTransaction.req
EVSE-->>CSMS: RemoteStartTransaction.conf
CSMS-->>API: status = Accepted
API-->>User: {"status": "Accepted"}
🔑 1. การยืนยันตัวตนผู้ใช้ด้วย JWT
เราใช้ Flask-JWT-Extended สำหรับจัดการ token authentication
ติดตั้ง
pip install flask flask-jwt-extended pymongo werkzeug
ตัวอย่างโค้ด API /signup และ /login:
@flask_app.route("/api/signup", methods=["POST"])
def signup():
...
token = create_access_token(identity=user["username"])
return jsonify(access_token=token, idTag=user["idTag"])
@flask_app.route("/api/login", methods=["POST"])
def login():
...
token = create_access_token(identity=user["username"])
return jsonify(access_token=token, idTag=user["idTag"])
⚡ 2. การสั่งเริ่มชาร์จจาก API ไปยัง EVSE
@flask_app.route("/api/start_charging", methods=["POST"])
@jwt_required()
def start_charging():
cp = connected_charge_points.get(evse_id)
payload = call.RemoteStartTransactionPayload(id_tag=id_tag, connector_id=connector_id)
future = asyncio.run_coroutine_threadsafe(cp.call(payload), main_loop)
result = future.result(timeout=10)
return jsonify({"status": result.status})
🧠 แนวปฏิบัติที่แนะนำ
- เก็บรหัสผ่านแบบเข้ารหัส (
generate_password_hash) - ใช้ JWT พร้อมกำหนดอายุ token
- ใช้
idTagเชื่อมโยงกับบัญชีผู้ใช้หรือยานพาหนะ - ใช้สิทธิ์ผู้ใช้ (
role: user, admin, root) ควบคุมการเข้าถึง - ใช้ QR code สำหรับจับคู่กับ EVSE
🛠️ เครื่องมือที่ใช้
| เครื่องมือ | หน้าที่ |
|---|---|
| Flask | พัฒนา REST API |
| Flask-JWT | จัดการ token auth |
| PyMongo | เชื่อมต่อ MongoDB |
| asyncio | ประมวลผล async / WebSocket |
| OCPP 1.6 | ติดต่อกับสถานีชาร์จ (EVSE) |
🚀 ฟีเจอร์เพิ่มเติมที่คุณสามารถเพิ่มได้
- สแกน QR code เพื่อเชื่อมต่อ EVSE →
ocpp://CP001?connector=1 - ส่งคำสั่ง update firmware หรือขอ diagnostic log
- รองรับหลาย role: ผู้ใช้ทั่วไป, เจ้าหน้าที่, แอดมิน
ต้องการ source code ตัวอย่าง, Postman collection หรือให้เราช่วย set up โปรเจกต์ของคุณ?
แค่แจ้งมา แล้วเราจะช่วยต่อยอดให้คุณได้ทันที! 🙌
Get in Touch with us
Related Posts
- การสร้างระบบติดตาม OEE แบบเรียลไทม์สำหรับโรงงานอุตสาหกรรม
- ความเชื่อเรื่อง Enterprise Software ราคาเป็นล้านกำลังจะจบลง มื่อ Open‑Source + AI กำลังแทนที่ระบบองค์กรราคาแพง
- วิธี Cache ข้อมูล Ecommerce โดยไม่แสดงราคาหรือสต็อกที่ล้าสมัย
- การนำ AI เข้าสู่ระบบ Legacy: บูรณาการ ERP, SCADA และระบบ On-Premise ด้วย Machine Learning
- ราคาของความฉลาด: AI ต้องใช้เงินเท่าไหร่กันแน่
- ทำไม RAG App ของคุณถึงพังใน Production (และวิธีแก้ไข)
- AI-Assisted Programming ในยุค AI: บทเรียนจาก *The Elements of Style* ที่ช่วยให้คุณเขียนโค้ดได้ดีกว่าด้วย Copilot
- มายาคติ AI แทนที่มนุษย์: ทำไมองค์กรยังต้องการวิศวกรและระบบซอฟต์แวร์จริงในปี 2026
- NSM vs AV vs IPS vs IDS vs EDR: ระบบความปลอดภัยของคุณขาดอะไรอยู่?
- ระบบ Network Security Monitoring (NSM) ผสานพลัง AI
- วิธีสร้างระบบ Enterprise ด้วย Open-Source + AI
- AI จะมาแทนที่บริษัทพัฒนาซอฟต์แวร์ในปี 2026 หรือไม่? ความจริงที่ผู้บริหารองค์กรต้องรู้
- วิธีสร้าง Enterprise System ด้วย Open-Source + AI (คู่มือเชิงปฏิบัติ ปี 2026)
- การพัฒนาซอฟต์แวร์ด้วย AI — สร้างเพื่อธุรกิจ ไม่ใช่แค่เขียนโค้ด
- Agentic Commerce: อนาคตของระบบการสั่งซื้ออัตโนมัติ (คู่มือฉบับสมบูรณ์ ปี 2026)
- วิธีสร้าง Automated Decision Logic ใน SOC ยุคใหม่ (ด้วย Shuffle + SOC Integrator)
- ทำไมเราจึงออกแบบ SOC Integrator แทนการเชื่อมต่อเครื่องมือแบบตรง ๆ (Tool-to-Tool)
- การพัฒนาระบบสถานีชาร์จ EV ด้วย OCPP 1.6 คู่มือสาธิตการใช้งานจริง: Dashboard, API และสถานีชาร์จ EV
- การเปลี่ยนแปลงทักษะของนักพัฒนาซอฟต์แวร์ (2026)
- Retro Tech Revival: จากความคลาสสิกสู่ไอเดียผลิตภัณฑ์ที่สร้างได้จริง













