PyQt6内嵌http.server Web 和Flask Web服务器方法详解

PyQt6 可以内嵌一个简单的 Web 服务器。虽然 PyQt6 本身不提供直接的 Web 服务器功能,但可以结合 Python 的标准库(如 http.server)或其他 Web 框架(如 Flask、FastAPI 等)来实现。

示例:使用 http.server内嵌 Web 服务器

以下是一个简单的例子,展示如何在 PyQt6 应用中内嵌一个基本的 Web 服务器:

import sys

from PyQt6.QtWidgets import QApplication, QMainWindow, QTextEdit

from PyQt6.QtCore import QThread, pyqtSignal

from http.server import BaseHTTPRequestHandler, HTTPServer

class SimpleHTTPRequestHandler(BaseHTTPRequestHandler):

def do_GET(self):

self.send_response(200)

self.send_header('Content-type', 'text/html')

self.end_headers()

self.wfile.write(b"Hello from PyQt6 Web Server!")

class WebServerThread(QThread):

def run(self):

server_address = ('', 8000)

httpd = HTTPServer(server_address, SimpleHTTPRequestHandler)

print("Web server running on port 8000...")

httpd.serve_forever()

class MainWindow(QMainWindow):

def init(self):

super().init()

self.setWindowTitle("PyQt6 Web Server Example")

self.text_edit = QTextEdit(self)

self.setCentralWidget(self.text_edit)

self.text_edit.setText("Web server is running...")

self.webserver_thread = WebServerThread()

self.webserver_thread.start()

if name == "main":

app = QApplication(sys.argv)

window = MainWindow()

window.show()

sys.exit(app.exec())

关键点:

  1. SimpleHTTPRequestHandler:这是一个简单的 HTTP 请求处理器,用于处理 GET 请求并返回响应。

  2. WebServerThread:这是一个 QThread 子类,用于在后台运行 Web 服务器,避免阻塞主线程。

  3. MainWindow:这是 PyQt6 的主窗口,启动时会在后台运行 Web 服务器。

运行效果:

  • 运行程序后,Web 服务器会在 http://localhost:8000上启动。

  • 访问该地址时,会看到 "Hello from PyQt6 Web Server!" 的响应。

  • PyQt6 应用的主窗口会显示 "Web server is running..."。

注意事项:

  • 这种方法适合简单的场景。如果需要更复杂的功能(如路由、模板渲染等),建议使用 Flask 或 FastAPI 等框架。

Pyqt6内嵌Flask框架完整的示例代码:

from flask import Flask, render_template_string

app = Flask(name)

@app.route('/')

def index():

return render_template_string('''

<h1>Hello, Flask in PyQt6!</h1>

<p>This is a Flask application embedded in PyQt6.</p>

''')

PyQt6 主程序 (main.py)

import sys

from PyQt6.QtWidgets import QApplication, QMainWindow

from PyQt6.QtWebEngineWidgets import QWebEngineView

from PyQt6.QtCore import QUrl

import threading

import time

from werkzeug.serving import make_server

from flask_app import app

class FlaskThread(threading.Thread):

def init(self, app):

threading.Thread.init(self)

self.server = make_server('127.0.0.1', 5000, app)

self.ctx = app.app_context()

self.ctx.push()

def run(self):

self.server.serve_forever()

def shutdown(self):

self.server.shutdown()

class MainWindow(QMainWindow):

def init(self):

super().init()

self.setWindowTitle("PyQt6 with Flask")

self.setGeometry(100, 100, 800, 600)

self.browser = QWebEngineView()

self.setCentralWidget(self.browser)

self.start_flask()

def start_flask(self):

self.flask_thread = FlaskThread(app)

self.flask_thread.start()

time.sleep(1)

self.browser.setUrl(QUrl("http://127.0.0.1:5000"))

def closeEvent(self, event):

self.flask_thread.shutdown()

event.accept()

if name == 'main':

qt_app = QApplication(sys.argv)

window = MainWindow()

window.show()

sys.exit(qt_app.exec())

打包命令

pyinstaller --onefile --windowed --add-data "flask_app.py;." main.py

通过以上步骤,你可以将 PyQt6 内嵌 Flask 的应用打包成一个独立的可执行文件,并在没有 Python 环境的电脑上运行。

相关推荐
IVEN_13 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang14 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮15 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling15 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮18 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽18 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健1 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞1 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽2 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers