【OSS】 前端如何直接上傳到OSS 上返回https鏈接,如果做到OSS圖片資源加密訪問

使用阿里云OSS(對象存儲服務)進行前端直接上傳并返回HTTPS鏈接,同時實現圖片資源的加密訪問,可以通過以下步驟實現:

前端直接上傳到OSS并返回HTTPS鏈接

  1. 設置OSS Bucket

    • 確保你的OSS Bucket已創建,并且設置為公共讀或私有(根據訪問控制需求)。
    • 在Bucket屬性中啟用HTTPS訪問。
  2. 生成上傳策略和簽名

    • 在后端生成一個上傳策略(Policy)和簽名(Signature),用于前端直接上傳文件。
    • 策略中應包括OSS的Endpoint、Bucket名稱、上傳路徑、過期時間等。
  3. 前端上傳代碼

    • 使用阿里云OSS SDK(如ali-oss)進行上傳。

    • 示例代碼(使用JavaScript):

      import OSS from 'ali-oss';const client = new OSS({region: 'your-oss-region', // 例如: 'oss-cn-hangzhou'accessKeyId: 'your-access-key-id', // 建議在后端生成臨時憑證accessKeySecret: 'your-access-key-secret', // 建議在后端生成臨時憑證bucket: 'your-bucket-name'
      });async function uploadFile(file) {try {const result = await client.put('your-upload-path/' + file.name, file);console.log('File uploaded:', result.url); // 返回HTTPS鏈接return result.url;} catch (error) {console.error('Upload error:', error);}
      }// 示例調用
      const fileInput = document.getElementById('file-input');
      fileInput.addEventListener('change', (e) => {const file = e.target.files[0];if (file) {uploadFile(file);}
      });
      
    • 注意:出于安全考慮,不建議在前端直接使用永久AccessKey,建議使用后端生成臨時憑證(STS Token)。

  4. 獲取HTTPS鏈接

    • 上傳成功后,result.url即為文件的HTTPS訪問鏈接。

圖片資源加密訪問

  1. 使用HTTPS

    • 確保OSS的Endpoint是HTTPS,這樣所有上傳和訪問的鏈接都是通過HTTPS加密傳輸的。
  2. Bucket權限控制

    • 設置Bucket為私有,這樣只有授權用戶才能訪問資源。
    • 通過生成預簽名URL(Signed URL)來實現臨時訪問權限。
  3. 生成預簽名URL

    • 在后端生成預簽名URL,用于臨時授權訪問私有Bucket中的文件。

    • 示例代碼(Node.js):

      const OSS = require('ali-oss');const client = new OSS({region: 'your-oss-region',accessKeyId: 'your-access-key-id',accessKeySecret: 'your-access-key-secret',bucket: 'your-bucket-name'
      });async function generateSignedUrl(fileName, expires) {try {const url = client.signatureUrl(fileName, {expires: expires, // 例如: 3600 表示1小時后過期process: 'image/resize,w_200' // 可選:對圖片進行實時處理});console.log('Signed URL:', url);return url;} catch (error) {console.error('Generate signed URL error:', error);}
      }// 示例調用
      generateSignedUrl('your-file-path.jpg', 3600);
      
  4. 前端使用預簽名URL

    • 前端從后端獲取預簽名URL后,可以直接在<img>標簽中使用該URL進行圖片展示。

    • 示例:

      <img src="signed-url-from-backend" alt="Encrypted Image">
      

通過上述步驟,你可以實現前端直接上傳文件到OSS并返回HTTPS鏈接,同時通過預簽名URL實現圖片資源的加密訪問。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/85290.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/85290.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/85290.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

TDenigne 集群可視化管理

可視化管理工具 為方便用戶更高效地使用和管理 TDengine&#xff0c;TDengine 3.0 版本推出了一個全新的可視化組件 taosExplorer。這個組件旨在幫助用戶在不熟悉 SQL 的情況下&#xff0c;也能輕松管理 TDengine 集群。通過 taosExplorer&#xff0c;用戶可以輕松查看 TDengi…

Centos7安裝gitlab

環境準備&#xff1a; 操作系統&#xff1a;Centos7 內存&#xff1a;2G以上 磁盤&#xff1a;50G 安全&#xff1a;關閉防火墻&#xff0c;selinux 1、安裝GitLab所需依賴 yum -y install policycoreutils openssh-server openssh-clients postfix 2、設置postfix開機自啟…

【前端面經】云智慧一面

寫在前面&#xff1a;面經只是記錄博主遇到的題目。每題的答案在編寫文檔的時候已經有問過deepseek&#xff0c;它只是一種比較普世的答案&#xff0c;要學得深入還是靠自己 Q&#xff1a;手撕代碼&#xff0c;兩個有序數組排序 A&#xff1a; function mysort(arr1, arr2) {…

Leetcode 3568. Minimum Moves to Clean the Classroom

Leetcode 3568. Minimum Moves to Clean the Classroom 1. 解題思路2. 代碼實現 題目鏈接&#xff1a;3568. Minimum Moves to Clean the Classroom 1. 解題思路 這一題我的核心思路就是廣度優先遍歷遍歷剪枝。 顯然&#xff0c;我們可以給出一個廣度優先遍歷來給出所有可能…

Spring Boot,注解,@RestController

RestController 是 Spring MVC 中用于創建 RESTful Web 服務的核心注解。 RestController 核心知識點 REST 作用: RestController 是一個方便的組合注解&#xff0c;它結合了 Controller 和 ResponseBody 兩個注解。 Controller: 將類標記為一個控制器&#xff0c;使其能夠處理…

【計算機網絡】Linux下簡單的UDP服務器(超詳細)

套接字接口 我們把服務器封裝成一個類&#xff0c;當我們定義出一個服務器對象后需要馬上初始化服務器&#xff0c;而初始化服務器需要做的第一件事就是創建套接字。 &#x1f30e;socket函數 這是Linux中創建套接字的系統調用,函數原型如下: int socket(int domain, int typ…

Fashion-MNIST LeNet訓練

前面使用線性神經網絡softmax 和 多層感知機進行圖像分類&#xff0c;本次我們使用LeNet 卷積神經網絡進行 訓練&#xff0c;期望能捕捉到圖像中的圖像結構信息&#xff0c;提高識別精度&#xff1a; import torch import torchvision from torchvision import transforms f…

EasyRTC嵌入式音視頻通信SDK助力1v1實時音視頻通話全場景應用

一、方案概述? 在數字化通信需求日益增長的今天&#xff0c;EasyRTC作為一款全平臺互通的實時視頻通話方案&#xff0c;實現了設備與平臺間的跨端連接。它支持微信小程序、APP、PC客戶端等多端協同&#xff0c;開發者通過該方案可快速搭建1v1實時音視頻通信系統&#xff0c;適…

查看make命令執行后涉及的預編譯宏定義的值

要查看 make 命令執行后涉及的預編譯宏定義&#xff08;如 -D 定義的宏&#xff09;及其值&#xff0c;可以采用以下方法&#xff1a; 1. 查看 Makefile 中的宏定義 直接檢查 Makefile 或相關構建腳本&#xff08;如 configure、CMakeLists.txt&#xff09;&#xff0c;尋找 -…

【C/C++】面試常考題目

面試中最常考的數據結構與算法題&#xff0c;適合作為刷題的第一階段重點。 ? 分類 & 推薦題目列表&#xff08;精選 70 道核心題&#xff09; 一、數組 & 字符串&#xff08;共 15 題&#xff09; 題目類型LeetCode編號兩數之和哈希表#1盛最多水的容器雙指針#11三數…

【芯片學習】555

一、引腳作用 二、原理圖 三、等效原理圖 1.比較器 同相輸入端大于反相輸入端&#xff0c;輸出高電平&#xff0c;反之亦然 2.三極管 給它輸入高電平就可以導通 3.模擬電路部分 4.數字電路部分 這部分的核心是RS觸發器&#xff0c;R-reset代表0&#xff0c;set是置位代表1&am…

Linux《文件系統》

在之前的系統IO當中已經了解了“內存”級別的文件操作&#xff0c;了解了文件描述符、重定向、緩沖區等概念&#xff0c;在了解了這些的知識之后還封裝出了我們自己的libc庫。接下來在本篇當中將會將視角從內存轉向磁盤&#xff0c;研究文件在內存當中是如何進行存儲的&#xf…

Java-代碼段-http接口調用自身服務中的其他http接口(mock)-并建立socket連接發送和接收報文實例

最新版本更新 https://code.jiangjiesheng.cn/article/367?fromcsdn 推薦 《高并發 & 微服務 & 性能調優實戰案例100講 源碼下載》 1. controller入口 ApiOperation("模擬平臺端現場機socket交互過程,需要Authorization")PostMapping(path "/testS…

基于遞歸思想的系統架構圖自動化生成實踐

文章目錄 一、核心思想解析二、關鍵技術實現1. 動態布局算法2. 樣式規范集成3. MCP服務封裝三、典型應用場景四、最佳實踐建議五、擴展方向一、核心思想解析 本系統通過遞歸算法實現了Markdown層級結構到PPTX架構圖的自動轉換,其核心設計思想包含兩個維度: 數據結構遞歸:將…

Python包管理器 uv替代conda?

有人問&#xff1a;python的包管理器uv可以替代conda嗎? 搞數據和算法的把conda當寶貝&#xff0c;其他的場景能替代。 Python的包管理器有很多&#xff0c;pip是原配&#xff0c;uv是后起之秀&#xff0c;conda則主打數據科學。 uv替代pip似乎只是時間問題了&#xff0c;它…

使用pnpm、vite搭建Phaserjs的開發環境

首先&#xff0c;確保你已經安裝了 Node.js 和 npm。然后按照以下步驟操作&#xff1a; 一、使用pnpm初始化一個新的 Vite 項目 pnpm create vite 輸入名字 選擇模板&#xff0c;這里我選擇Vanilla,也可以選擇其他的比如vue 選擇語言 項目新建完成 二、安裝相關依賴 進入項…

JS逆向案例—喜馬拉雅xm-sign詳情頁爬取

JS逆向案例——喜馬拉雅xm-sign詳情頁爬取 聲明網站流程分析總結 聲明 本文章中所有內容僅供學習交流&#xff0c;抓包內容、敏感網址、數據接口均已做脫敏處理&#xff0c;嚴禁用于商業用途和非法用途&#xff0c;否則由此產生的一切后果均與作者無關&#xff0c;若有侵權&am…

姜老師的MBTI課程:MBTI是可以轉變的

我們先來看內向和外向這條軸&#xff0c;I和E內向和外向受先天遺傳因素的影響還是比較大的&#xff0c;因為它事關到了你的硬件&#xff0c;也就是大腦的模型。但是我們在大五人格的排雷避坑和這套課程里面都強調了一個觀點&#xff0c;內向和外向各有優勢&#xff0c;也各有不…

進程同步:生產者-消費者 題目

正確答案&#xff1a; 問題類型&#xff1a; 經典生產者 - 消費者問題 同時涉及同步和互斥。 同步&#xff1a;生產者與消費者通過信號量協調生產 / 消費節奏&#xff08;如緩沖區滿時生產者等待&#xff0c;空時消費者等待&#xff09;。互斥&#xff1a;對共享緩沖區的訪問需…

吳恩達MCP課程(1):chat_bot

原課程代碼是用Anthropic寫的&#xff0c;下面代碼是用OpenAI改寫的&#xff0c;模型則用阿里巴巴的模型做測試 .env 文件為&#xff1a; OPENAI_API_KEYsk-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx OPENAI_API_BASEhttps://dashscope.aliyuncs.com/compatible-mode…