django-sse通讯

文章介绍了如何使用Vue前端框架构建一个表格,并通过Django后端的SSE(Server-SentEvents)实现实时数据推送。展示了在Vue组件中处理表单操作以及与后端交互,包括启动和停止数据采集以及显示动态更新的数据列表。
摘要由CSDN通过智能技术生成

前端VUE:

<template>
  <div class="common-layout">
    <el-container>
      <el-header
        ><el-row>
          <el-col :span="24"
            ><div>
              <strong style="font-size: larger">123</strong>
            </div></el-col
          >
        </el-row>
        <el-row>
          <el-col :span="24">
            <div>
              <el-button type="success" @click="startCollection"
                >启动</el-button
              >
              <el-button type="danger" @click="stopCollection">停止</el-button>
            </div></el-col
          >
        </el-row>
      </el-header>
      <el-main>
        <el-row>
          <el-col :span="24">
            <div>
              <el-table :data="tableData" border style="width: 100%">
                <el-table-column
                  prop="id"
                  label="ID"
                  align="center"
                  width="80"
                />
                <el-table-column
                  prop="地址"
                  label="地址"
                  align="center"
                  width="150"
                />
                <el-table-column
                  prop="值"
                  label="值"
                  align="center"
                  width="150"
                />
                <el-table-column
                  prop="数据类型"
                  label="数据类型"
                  align="center"
                  width="150"
                />
                <el-table-column
                  prop="功能"
                  label="功能"
                  align="center"
                  width="150"
                />
                <el-table-column
                  prop="描述"
                  label="描述"
                  align="center"
                  width="300"
                />
                <el-table-column
                  prop="time"
                  label="时间"
                  align="center"
                  width="300"
                />
              </el-table>
            </div>
          </el-col>
        </el-row>
      </el-main>
    </el-container>
  </div>
</template>
<script setup>
import { ref } from "vue";
import API from "../utils/request";
var tableData = ref([]);
var eventSource = null;
function startCollection() {
  API.post("/state/", {
    aaa: "开始采集",
  }).then(function (res) {
    console.log(res);
  });
  if (!eventSource) {
    eventSource = new EventSource("http://127.0.0.1:8000/sse_endpoint");
    console.log("连接已建立");
    eventSource.onmessage = function (event) {
      var data = JSON.parse(event.data);
      if (tableData.value.length == 11) {
        tableData.value.length = 0;
      }
      tableData.value.push(data);
    };
    eventSource.onerror = function () {
      eventSource.close();
      eventSource = null;
    };
  }
}
function stopCollection() {
  if (eventSource) {
    eventSource.close();
    eventSource = null;
  }
  API.post("/state/", {
    aaa: "停止采集",
  }).then(function (res) {
    console.log(res);
  });
}
</script>
<style>
.table {
  overflow: hidden;
}
</style>

Django后端:

 urls.py

from django.contrib import admin
from django.urls import path
from App01.views import sse_endpoint, state

urlpatterns = [
    path('admin/', admin.site.urls),
    path('sse_endpoint', sse_endpoint,name='sse_endpoint'),
    path('state/', state,name='state'),

 view.py

def sse_endpoint(request):
    def event_stream():
        while True:
            # 在这里替换为获取最新数据的代码
            data_list = []
            cpList = DB3000_act01.objects.all()
            # cpList = DB3000_act01.objects.all().order_by('-id')
            for i in cpList:
                data = {
                    "id": i.id,
                    "地址": i.地址,
                    "值": i.值,
                    "数据类型": i.数据类型,
                    "功能": i.功能,
                    "描述": i.描述,
                    "time": str(i.time)
                }
                data_list.append(data)
            for data in data_list:
                yield 'data: {}\n\n'.format(json.dumps(data))
            time.sleep(0.05)  # 休眠5秒钟,模拟实时数据更新

    response = StreamingHttpResponse(event_stream(), content_type='text/event-stream')
    response['Cache-Control'] = 'no-cache'
    return response

sse_endpoint :每隔50ms向前端发送数据

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
django-sse 是一个用于实现服务器发送事件的 Django 库。它可以用来向客户端实时推送数据,但它并不适合传输大文件数据。 如果你需要传输大文件数据,建议使用其他的文件传输方式,例如 FTP 或者 HTTP Range 请求。你可以使用 Django 自带的 `StreamingHttpResponse` 对象来实现 HTTP Range 请求和分块传输。 下面是一个简单的示例代码: ```python from django.http import FileResponse, HttpResponse from django.views.decorators.http import condition def file_download(request): # 打开要下载的文件 file_path = 'path/to/your/file' with open(file_path, 'rb') as f: response = HttpResponse(f, content_type='application/octet-stream') # 获取文件大小 file_size = os.path.getsize(file_path) # 设置响应头 response['Content-Length'] = file_size response['Content-Disposition'] = 'attachment; filename=%s' % os.path.basename(file_path) # 支持 HTTP Range 请求 response['Accept-Ranges'] = 'bytes' # 如果客户端支持 HTTP Range 请求,则返回分块数据 if 'HTTP_RANGE' in request.META: range_header = request.META['HTTP_RANGE'] start, end = parse_range_header(range_header, file_size) response['Content-Range'] = 'bytes %d-%d/%d' % (start, end, file_size) response.status_code = 206 f.seek(start) response.streaming_content = FileResponse(f, status=206, content_type='application/octet-stream', content_length=(end - start + 1)) return response @condition(etag_func=None) def stream_file(request): # 打开要下载的文件 file_path = 'path/to/your/file' with open(file_path, 'rb') as f: response = HttpResponse(f, content_type='application/octet-stream') # 获取文件大小 file_size = os.path.getsize(file_path) # 设置响应头 response['Content-Length'] = file_size response['Content-Disposition'] = 'attachment; filename=%s' % os.path.basename(file_path) # 支持 HTTP Range 请求 response['Accept-Ranges'] = 'bytes' # 如果客户端支持 HTTP Range 请求,则返回分块数据 if 'HTTP_RANGE' in request.META: range_header = request.META['HTTP_RANGE'] start, end = parse_range_header(range_header, file_size) response['Content-Range'] = 'bytes %d-%d/%d' % (start, end, file_size) response.status_code = 206 f.seek(start) response.streaming_content = FileResponse(f, status=206, content_type='application/octet-stream', content_length=(end - start + 1)) else: # 如果客户端不支持 HTTP Range 请求,则返回整个文件 response['Content-Length'] = file_size response.streaming_content = FileResponse(f, content_type='application/octet-stream') return response def parse_range_header(range_header, file_size): m = re.match(r'bytes=(?P<start>\d+)-(?P<end>\d+)?', range_header) if m: start = int(m.group('start')) end = int(m.group('end')) if m.group('end') else file_size - 1 return start, end else: raise Http404('Invalid Range header') ``` 这里提供了两个视图函数:`file_download` 和 `stream_file`。`file_download` 使用了 `StreamingHttpResponse` 对象来实现 HTTP Range 请求和分块传输;`stream_file` 使用了 Django 自带的 `FileResponse` 对象来实现同样的功能。你可以根据实际需求选择使用其中的一个。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值