当前位置: 首页 > java >正文

chili3d笔记11 连接yolo python http.server 跨域请求 flask

from ultralytics import YOLO
from flask import Flask, request, jsonify
from flask_cors import CORS
import base64
from io import BytesIO
from PIL import Image
import json# 加载模型
model = YOLO('./yolo_detect/best.pt')app = Flask(__name__)
CORS(app)  # 启用跨域支持def predict(img_data):image_data = base64.b64decode(img_data)image = Image.open(BytesIO(image_data))results = model.predict(source=image)predictions = []for result in results:boxes = result.boxesfor box in boxes:predictions.append({"Confidence": box.conf.item(),"Object": model.names[int(box.cls.item())],"BoxCoordinate": box.xyxy.cpu().numpy().tolist()})return predictions@app.route('/', methods=['POST'])
def handle_post():payload = request.get_json()img_data = payload.get("image_data")if not img_data:return jsonify({"error": "Missing image data"}), 400try:result = predict(img_data)return jsonify(result)except Exception as e:return jsonify({"error": str(e)}), 500if __name__ == "__main__":app.run(host='0.0.0.0', port=8737)

----------------------------------------------------

 const fileInput = document.createElement("input");fileInput.type = "file";fileInput.accept = "image/*";fileInput.style.display = "none"; // 隐藏输入框// 处理文件选择事件fileInput.addEventListener("change", async (event) => {const target = event.target as HTMLInputElement;this.resultLabel.textContent = "正在上传并检测图像...";if (target.files && target.files.length > 0) {const file = target.files[0];Logger.info(`Selected file: ${file.name}`);try {const reader = new FileReader();reader.onload = async () => {try {const base64Data = reader.result?.toString().split(",")[1];const response = await fetch("http://localhost:8737", {method: "POST",headers: { "Content-Type": "application/json" },body: JSON.stringify({ image_data: base64Data }),});if (!response.ok) throw new Error("Network response was not ok");const data = await response.json();const formattedResult = data.map((item: any, index: number) => {const objType = item.Object;const confidence = (item.Confidence * 100).toFixed(2);const [x1, y1, x2, y2] = item.BoxCoordinate[0];return `目标 ${index + 1}: ${objType}, 置信度 ${confidence}%, 坐标 [${x1.toFixed(1)}, ${y1.toFixed(1)}, ${x2.toFixed(1)}, ${y2.toFixed(1)}]`;}).join("\n");this.resultLabel.textContent = `检测到 ${data.length} 个物体:\n${formattedResult}`;Logger.info("YOLO 检测结果:", data);} catch (error) {Logger.error("请求失败:", error);}};reader.readAsDataURL(file);} catch (err) {Logger.error(`处理文件时出错: ${err}`);}}});

2025-05-05 20-32-07 网页端打开图片进行yolo识别,立方体圆柱体

http://www.xdnf.cn/news/3963.html

相关文章:

  • Linux中web服务器的部署及优化
  • 使用OpenCV 和 Dlib 实现疲劳检测
  • 【macOS常用快捷键】
  • Flink流水线任务在线演示
  • C++类和对象之默认成员函数
  • 基于 Spark 和 Hadoop 的空气质量数据分析与预测系统
  • 【AI提示词】AARRR 模型执行者
  • Google-chrome版本升级后sogou输入法不工作了
  • Cisco NDO - Nexus Dashboard Orchestrator
  • 202533 | SpringBoot集成RocketMQ
  • 2025 年 408 真题及答案
  • 深入探索Anthropic Claude与Spring AI的融合应用
  • 虚幻引擎5-Unreal Engine笔记之显卡环境设置使开发流畅
  • 【LaTeX+VSCode本地Win11编译教程】
  • Debezium TableSchemaBuilder详解
  • (一)Modular Monolith Architecture(项目结构/.net项目初始化/垂直切片架构)
  • 洛谷 P1440 求m区间内的最小值
  • 8.5/Q1,Charls高分经典文章解读
  • 【Web3】上市公司利用RWA模式融资和促进业务发展案例
  • Spring Boot多模块划分设计
  • C++访问MySQL
  • 《Python星球日记》第31天:Django 框架入门
  • opencv+opencv_contrib+cuda和VS2022编译
  • 202531 | RocketMQ 消息过滤 + 消息重试机制 + 死信消息 + 重复消费问题
  • zotero pdf中英翻译插件使用
  • epub格式转txt格式工具,txt批量转PDF
  • 设计模式(结构型)-组合模式
  • 【Java ee初阶】多线程(6)
  • item_get_app_pro - 获得淘宝app商品详情原数据操作流程
  • 使用 vllm 部署 Llama3-8b-Instruct