uniapp 使用 XMLHttpRequest发送二进制上传文件 可使用预上传接口上传到华为obs

<template> <button @click="changeMessage">选择文件</button> <view v-show="false" :path="path" :change:path="requestModule.uploadOBS"></view> </template> <script setup> import { ref } from 'vue' import { getCurrentInstance } from 'vue' const { proxy } = getCurrentInstance() // 把回调挂到实例上,renderjs 就能通过 callMethod 调到 proxy.$onRenderData = (data) => { console.error('str:', data) } const path = ref(null) const changeMessage = () => { uni.chooseImage({ count: 1, // 最多选择数量 sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图 sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机 success: async (res) => { // tempFilePath 可以作为 img 标签的 src 属性显示图片 const tempFilePaths = res.tempFilePaths path.value = tempFilePaths[0]; }, fail: (err) => { console.error('选择图片失败:', err) } }) } </script> <script> // 专门给 renderjs 回调用 ownerVm.callMethod('onRenderData', "999999") 就能调到 /* export default { methods: { onRenderData(data) { console.error('str:', data) } } } */ </script> <script module="requestModule" lang="renderjs"> export default { methods: { /* 1. 逻辑层 → renderjs */ uploadOBS(newVal, oldVal, ownerVm, vm) { console.error('path:', newVal) this.getFileAsArrayBuffer2(newVal).then(res => { console.error('arrayBuffer:', res) return this.uploadArrayBuffer(res,'https://jszj-dev.obs.cn-east-3.myhuaweicloud.com/2011725287372374017/jszj_lp_merchant_apply_for_application_materials_file_id/20260116/1762482093185_1768566856106.jpg?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Date=20260116T123416Z&X-Amz-SignedHeaders=host&X-Amz-Credential=HPUAACHPJ15SJKPZGOAP%2F20260116%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Expires=86400&X-Amz-Signature=29eb09d67a7bf73afb199e75148c57d73d13d65146fe6bd351b479cc0ebd66d1','image/jpeg'); }).then(res => { console.error('upload:', res) }).catch(err => { }) //调用vue2方法 //ownerVm.callMethod('onRenderData', "999999") //调用vue3方法 ownerVm.callMethod('$onRenderData', "999999") }, getFileAsArrayBuffer2(filePath) { return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest() xhr.open('GET', filePath, true) xhr.responseType = 'arraybuffer' xhr.onload = function() { if (xhr.status === 200) { resolve(xhr.response) } else { reject(new Error('Failed to load file')) } } xhr.onerror = function() { reject(new Error('Network error')) } xhr.send() }) }, uploadArrayBuffer(arrayBuffer, uploadUrl, fileType = 'application/octet-stream') { return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest(); /* 1. 打开连接 */ xhr.open('PUT', uploadUrl, true); /* 2. 设置请求头 */ xhr.setRequestHeader('Content-Type', fileType); /* 3. 响应类型(按需要) */ xhr.responseType = 'arraybuffer'; /* 4. 上传进度 */ xhr.upload.onprogress = function(e) { if (e.lengthComputable) { const percent = (e.loaded / e.total) * 100; console.log('上传进度:', percent.toFixed(2) + '%'); } }; /* 5. 成功/失败 */ xhr.onload = function() { if (xhr.status >= 200 && xhr.status < 300) { resolve(xhr.response); // 服务端返回的 ArrayBuffer } else { reject(new Error(`上传失败 ${xhr.status}`)); } }; xhr.onerror = () => reject(new Error('网络错误')); /* 6. 发送二进制 */ xhr.send(arrayBuffer); }); } } } </script> <style> </style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1172641.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

保姆级教程:从零开始使用Qwen All-in-One做情感分析

保姆级教程&#xff1a;从零开始使用Qwen All-in-One做情感分析 1. 引言&#xff1a;为什么需要轻量级多任务AI服务&#xff1f; 在当前大模型&#xff08;LLM&#xff09;快速发展的背景下&#xff0c;越来越多的应用场景要求模型具备多功能性与低部署门槛。然而&#xff0c…

Hunyuan开源模型值不值得用?技术架构深度解析指南

Hunyuan开源模型值不值得用&#xff1f;技术架构深度解析指南 1. 引言&#xff1a;企业级翻译需求下的新选择 随着全球化业务的不断扩展&#xff0c;高质量、低延迟的机器翻译能力已成为众多企业和开发者的刚需。传统的云服务翻译方案虽然稳定&#xff0c;但在数据隐私、定制…

BERT智能填空避坑指南:常见问题与解决方案汇总

BERT智能填空避坑指南&#xff1a;常见问题与解决方案汇总 1. 引言 随着自然语言处理技术的不断演进&#xff0c;基于预训练模型的应用已广泛渗透到各类语义理解任务中。其中&#xff0c;BERT 智能语义填空服务凭借其轻量化架构与高精度推理能力&#xff0c;成为中文掩码语言…

PDF-Extract-Kit版面分析:复杂文档结构识别技巧

PDF-Extract-Kit版面分析&#xff1a;复杂文档结构识别技巧 1. 技术背景与问题提出 在处理学术论文、技术报告、财务报表等复杂PDF文档时&#xff0c;传统文本提取工具往往难以准确还原原始文档的结构信息。常见的OCR工具虽然能够识别字符内容&#xff0c;但在面对多栏布局、…

实测通义千问2.5-7B-Instruct:AI对话效果惊艳,附完整部署教程

实测通义千问2.5-7B-Instruct&#xff1a;AI对话效果惊艳&#xff0c;附完整部署教程 1. 引言 随着大语言模型技术的持续演进&#xff0c;Qwen系列已升级至Qwen2.5版本。该版本在预训练数据量、推理能力、多语言支持和结构化输出等方面实现了全面增强。其中&#xff0c;Qwen2…

Ffmpeg.js 终极指南:浏览器端音视频处理的完整解决方案

Ffmpeg.js 终极指南&#xff1a;浏览器端音视频处理的完整解决方案 【免费下载链接】Ffmpeg.js Ffmpeg.js demos, both for browsers and node.js 项目地址: https://gitcode.com/gh_mirrors/ffm/Ffmpeg.js Ffmpeg.js 通过 WebAssembly 技术将强大的 FFmpeg 功能引入浏览…

从文本向量化到聚类优化|GTE大模型镜像应用全链路

从文本向量化到聚类优化&#xff5c;GTE大模型镜像应用全链路 1. 背景与挑战&#xff1a;传统文本聚类的瓶颈 在舆情分析、热点发现等自然语言处理任务中&#xff0c;文本聚类是一项基础且关键的技术。其目标是将语义相近的文本自动归为一类&#xff0c;从而帮助运营人员快速…

uni.chooseMedia 返回 /storage/emulated/ 开头或 content://media/external/开头

uni.chooseMedia 返回的 tempFilePath 出现两种前缀&#xff0c;是 平台文件系统差异 是否走压缩路径 导致的正常现象&#xff1a;/storage/emulated/...出现场景&#xff1a;Android 10 以下&#xff0c;或Android 10 但用户选择了“原图/原视频”&#xff08;HBuilderX 3.6 …

LinkSwift终极网盘直链下载助手完整使用教程

LinkSwift终极网盘直链下载助手完整使用教程 【免费下载链接】Online-disk-direct-link-download-assistant 可以获取网盘文件真实下载地址。基于【网盘直链下载助手】修改&#xff08;改自6.1.4版本&#xff09; &#xff0c;自用&#xff0c;去推广&#xff0c;无需输入“暗号…

Windows HEIC缩略图终极方案:让苹果照片在资源管理器完美预览

Windows HEIC缩略图终极方案&#xff1a;让苹果照片在资源管理器完美预览 【免费下载链接】windows-heic-thumbnails Enable Windows Explorer to display thumbnails for HEIC files 项目地址: https://gitcode.com/gh_mirrors/wi/windows-heic-thumbnails 还在为Windo…

小白必看:通义千问2.5-7B-Instruct快速入门与API调用指南

小白必看&#xff1a;通义千问2.5-7B-Instruct快速入门与API调用指南 1. 引言 随着大模型技术的快速发展&#xff0c;越来越多开发者希望将高性能语言模型集成到自己的应用中。然而&#xff0c;面对动辄数十GB的模型文件和复杂的部署流程&#xff0c;许多初学者望而却步。 本…

YOLO26模型融合:Ensemble推理性能提升

YOLO26模型融合&#xff1a;Ensemble推理性能提升 1. 技术背景与问题提出 目标检测作为计算机视觉领域的核心任务之一&#xff0c;近年来随着深度学习的发展取得了显著进步。YOLO&#xff08;You Only Look Once&#xff09;系列模型凭借其高精度与实时性&#xff0c;在工业界…

从架构到部署:AutoGLM-Phone-9B实现手机端低延迟多模态推理

从架构到部署&#xff1a;AutoGLM-Phone-9B实现手机端低延迟多模态推理 1. AutoGLM-Phone-9B的架构设计与核心价值 1.1 面向移动端的多模态融合挑战 随着智能终端对AI能力需求的持续增长&#xff0c;如何在资源受限的设备上实现高效、低延迟的多模态推理成为工程落地的关键瓶…

腾讯优图Youtu-2B案例:金融行业智能助手实现

腾讯优图Youtu-2B案例&#xff1a;金融行业智能助手实现 1. 引言 1.1 业务场景描述 在金融行业中&#xff0c;客户服务、风险评估、合规审查和投资咨询等环节对信息处理的准确性与响应速度提出了极高要求。传统人工处理方式效率低、成本高&#xff0c;而通用大模型往往因算力…

PDF智能提取全攻略|基于PDF-Extract-Kit镜像快速实现布局与公式识别

PDF智能提取全攻略&#xff5c;基于PDF-Extract-Kit镜像快速实现布局与公式识别 1. 引言&#xff1a;PDF内容智能提取的挑战与需求 在科研、教育、出版和企业文档处理等场景中&#xff0c;PDF文件作为信息传递的重要载体&#xff0c;广泛用于论文、报告、教材和技术手册的发布…

通义千问2.5-7B-Instruct工具调用实战:Agent接入详细步骤

通义千问2.5-7B-Instruct工具调用实战&#xff1a;Agent接入详细步骤 1. 技术背景与核心价值 随着大模型在实际业务场景中的深入应用&#xff0c;具备工具调用&#xff08;Function Calling&#xff09;能力的指令模型正成为构建智能 Agent 的关键组件。传统的语言模型仅能生成…

[C++][cmake]基于C++在windows上使用纯opencv部署yolo26的图像分类onnx模型

【算法介绍】在C中使用纯OpenCV部署YOLO26-cls图像分类ONNX模型是一项具有挑战性的任务&#xff0c;因为YOLO26通常是用PyTorch等深度学习框架实现的&#xff0c;而OpenCV本身并不直接支持加载和运行PyTorch模型。然而&#xff0c;可以通过一些间接的方法来实现这一目标&#x…

边疆政务翻译难题破局|HY-MT1.5-7B模型镜像实测与合规性探讨

边疆政务翻译难题破局&#xff5c;HY-MT1.5-7B模型镜像实测与合规性探讨 在边疆民族地区的政务服务场景中&#xff0c;语言障碍长期制约着公共服务的均等化与高效化。一位只会使用少数民族语言的群众&#xff0c;在面对全中文界面的政务系统时往往束手无策&#xff1b;而基层工…

AI读脸术多任务并行优势:单次推理完成三项检测

AI读脸术多任务并行优势&#xff1a;单次推理完成三项检测 1. 技术背景与问题提出 在计算机视觉领域&#xff0c;人脸属性分析是一项基础且关键的任务。传统方案中&#xff0c;开发者往往需要分别部署人脸检测、性别识别和年龄估计三个独立模型&#xff0c;通过串行调用实现完…

AI智能二维码工坊实操手册:从零搭建本地化解码服务

AI智能二维码工坊实操手册&#xff1a;从零搭建本地化解码服务 1. 引言 1.1 学习目标 本文将带你从零开始部署并使用一个轻量、高效、无需依赖的本地化二维码处理系统——AI智能二维码工坊。你将掌握&#xff1a; 如何快速启动一个集成生成与识别功能的二维码服务理解基于O…