实现 Python 服务在执行完毕后主动向前端发送信息,以便前端(例如 Vue.js 应用)可以更新显示

可以通过多种方法实现 Python 服务在执行完毕后主动向前端发送信息,以便前端(例如 Vue.js 应用)可以更新显示。下面介绍几种常见的方法:

1. 使用 WebSockets

WebSockets 是一种在客户端和服务器之间建立持久连接的通信协议,适用于实时更新。可以使用 websockets 库在 Python 中实现 WebSocket 服务器。

Python 服务器代码示例:
python 复制代码
import asyncio
import websockets

async def handler(websocket, path):
    while True:
        # 等待客户端请求
        message = await websocket.recv()
        print(f"Received message: {message}")

        # 执行某些操作...
        
        # 发送更新通知给前端
        await websocket.send("Update completed")

start_server = websockets.serve(handler, "localhost", 6789)

asyncio.get_event_loop().run_until_complete(start_server)
asyncio.get_event_loop().run_forever()
Vue.js 前端代码示例:
javascript 复制代码
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Waiting for update...'
    };
  },
  created() {
    this.connectWebSocket();
  },
  methods: {
    connectWebSocket() {
      const socket = new WebSocket('ws://localhost:6789');
      socket.onmessage = (event) => {
        this.message = event.data;
      };
    }
  }
};
</script>

2. 使用 HTTP Polling

HTTP Polling 是一种客户端定期向服务器发送请求以检查是否有新数据的技术。虽然不如 WebSockets 实时,但实现简单且兼容性好。

Python 服务器代码示例:
python 复制代码
from flask import Flask, jsonify
import time

app = Flask(__name__)

@app.route('/check_update', methods=['GET'])
def check_update():
    # 模拟一些处理
    time.sleep(5)
    return jsonify({'status': 'Update completed'})

if __name__ == '__main__':
    app.run(debug=True)
Vue.js 前端代码示例:
javascript 复制代码
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Waiting for update...'
    };
  },
  created() {
    this.checkForUpdate();
  },
  methods: {
    checkForUpdate() {
      setInterval(() => {
        fetch('/check_update')
          .then(response => response.json())
          .then(data => {
            this.message = data.status;
          });
      }, 5000); // 每5秒检查一次
    }
  }
};
</script>

3. 使用 Server-Sent Events (SSE)

SSE 允许服务器主动推送消息到客户端。它基于 HTTP 协议,适用于需要频繁更新但不需要双向通信的场景。

Python 服务器代码示例:
python 复制代码
from flask import Flask, Response
import time

app = Flask(__name__)

@app.route('/stream')
def stream():
    def event_stream():
        while True:
            time.sleep(1)
            yield f'data: Update completed\n\n'
    return Response(event_stream(), content_type='text/event-stream')

if __name__ == '__main__':
    app.run(debug=True)
Vue.js 前端代码示例:
javascript 复制代码
<template>
  <div>
    <p>{{ message }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Waiting for update...'
    };
  },
  created() {
    this.connectSSE();
  },
  methods: {
    connectSSE() {
      const eventSource = new EventSource('/stream');
      eventSource.onmessage = (event) => {
        this.message = event.data;
      };
    }
  }
};
</script>

选择哪种方法取决于您的具体需求和应用场景。如果需要双向通信和实时性,WebSockets 是最佳选择。如果只需要服务器向客户端推送更新且无需双向通信,SSE 是一个不错的选择。如果实现简单是优先考虑的,HTTP Polling 也可以满足需求。

相关推荐
m0_748554815 小时前
golang如何实现用户订阅偏好管理_golang用户订阅偏好管理实现总结
jvm·数据库·python
QQ1__8115175155 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态6 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子6 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室6 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI6 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing6 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者6 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册6 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李6 小时前
2026 年 Web 前端开发的 8 个趋势!
前端