【一起學Rust | 框架篇 | Tauri2.0框架】在Tauri應用中設置Http頭(Headers)

文章目錄

  • 前言
  • 一、配置準備
    • 1. 檢查版本
    • 2. 使用條件
    • 3. 支持的請求頭(并不是全部支持)
  • 二、使用步驟
    • 1. 如何配置header
    • 2. 框架集成
      • 1. 對于`Vite`系列、`Nuxt`、`Next.js`這種前端框架
        • `Vite`系列框架
        • `Angular`系列框架
        • `Nuxt`系列框架
        • `Next.js`系列框架
      • 2. 對于`Yew`和`Leptos`這種全棧框架


前言

Tauri是一個基于Rust的跨平臺桌面應用框架,允許開發者使用Web技術(如HTML、CSS和JavaScript)創建桌面應用。Tauri2.0是該框架的最新版本,提供了許多新功能和改進。其中一個重要的功能是對Http頭(Headers)的支持。在本文中,我們將探討如何在Tauri應用中設置Http頭,包括為什么設置Http頭是必要的、如何設置Http頭,以及一些常見的Http頭設置場景。

在Web開發中,Http頭(Headers)是Http請求和響應的一部分,用于傳遞額外的信息。Http頭可以用來指定請求的方法、請求體的格式、認證信息等。設置Http頭是必要的,因為它可以幫助開發者控制Http請求的行為,例如指定請求的緩存策略、設置跨域資源共享(CORS)頭等。特別是在Tauri應用中,設置Http頭可以幫助開發者與后端服務器進行更好的交互。

在應用開發過程中,對于http的headers控制是一個通常的需求,在過去的tauri版本中,如果你想要設置http請求頭,就需要ipc調用rust層的方法,然后再設置請求頭,就比較麻煩,或者你可以試試用Fetch看看能否得到你想要的效果。但是現在,最近Tauri官方就給出了配置http請求頭的方法,盡管并不能盡善盡美,但也足夠開發使用了。


一、配置準備

1. 檢查版本

首先確認你的tauri版本要大于2.1.0,因為這是后面新增的特性,如果你是剛剛從頭創建的Tauri項目,那么可以跳過這步。

2. 使用條件

然后就是要明確知道什么時候會用上這個配置。

配置中定義的標頭會隨對網頁視圖的響應一起發送。這并不包括進程間通信(IPC)消息和錯誤響應。更具體地說,通過crates/tauri/src/protocol/tauri.rs中的get_response函數發送的每個響應都將包含這些標頭。

3. 支持的請求頭(并不是全部支持)

  • Access-Control-Allow-Credentials
  • Access-Control-Allow-Headers
  • Access-Control-Allow-Methods
  • Access-Control-Expose-Headers
  • Access-Control-Max-Age
  • Cross-Origin-Embedder-Policy
  • Cross-Origin-Opener-Policy
  • Cross-Origin-Resource-Policy
  • Permissions-Policy
  • Timing-Allow-Origin
  • X-Content-Type-Options
  • Tauri-Custom-Header

以上請求頭的意義均可在MDN找到
https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Allow-Credentials

以下是官方建議

  1. Tauri-Custom-Header并非用于生產環境。
  2. 內容安全策略(Content-Security-Policy,CSP)在此處未定義。(暫時先不用管)

二、使用步驟

1. 如何配置header

官方文檔寫的,tauri的header支持以下值

  • 字符串
  • 字符串數組
  • key-value對象,但是value必須是字符串
  • null

標頭值始終會針對實際響應轉換為字符串。根據配置文件的外觀,某些標頭值需要進行組合。以下是創建復合標頭的規則:

  • string - 與最終轉化的結果保持一致
  • Array - 結果是用, 連接起來
  • key-value - 最終打包的格式是key + 空格 + value,然后結尾用;分割
  • null - 最終會被忽略

例如

// src-tauri/tauri.conf.json
{//..."app":{//..."security": {//..."headers": {"Cross-Origin-Opener-Policy": "same-origin","Cross-Origin-Embedder-Policy": "require-corp","Timing-Allow-Origin": ["https://developer.mozilla.org","https://example.com",],"X-Content-Type-Options": null, // 忽略"Access-Control-Expose-Headers": "Tauri-Custom-Header","Tauri-Custom-Header": {"key1": "'value1' 'value2'","key2": "'value3'"}},// 告訴內容安全策略(CSP)手動制定請求頭。"csp": "default-src 'self'; connect-src ipc: http://ipc.localhost",}}
}

Tauri-Custom-Header并非用于生產環境。對于測試:請記得相應地設置Access-Control-Expose-Headers

在這個示例中,Cross-Origin-Opener-PolicyCross-Origin-Embedder-Policy被設置為允許使用SharedArrayBuffer (文檔在MDN)。Timing-Allow-Origin允許從列出的網站加載的腳本通過資源定時 API 訪問詳細的網絡定時數據。

最終的請求頭結果會轉化為

access-control-allow-origin:  http://tauri.localhost
access-control-expose-headers: Tauri-Custom-Header
content-security-policy: default-src 'self'; connect-src ipc: http://ipc.localhost; script-src 'self' 'sha256-Wjjrs6qinmnr+tOry8x8PPwI77eGpUFR3EEGZktjJNs='
content-type: text/html
cross-origin-embedder-policy: require-corp
cross-origin-opener-policy: same-origin
tauri-custom-header: key1 'value1' 'value2'; key2 'value3'
timing-allow-origin: https://developer.mozilla.org, https://example.com

2. 框架集成

一些開發環境需要額外的設置,以模擬生產環境。

1. 對于Vite系列、NuxtNext.js這種前端框架

Vite系列框架

對于使用Vite來構建的項目(包括Qwik, React, Solid, Svelte, 和 Vue),只所需的標頭添加到vite.config.ts中。

import { defineConfig } from 'vite';export default defineConfig({// ...server: {// ...headers: {'Cross-Origin-Opener-Policy': 'same-origin','Cross-Origin-Embedder-Policy': 'require-corp','Timing-Allow-Origin': 'https://developer.mozilla.org, https://example.com','Access-Control-Expose-Headers': 'Tauri-Custom-Header','Tauri-Custom-Header': "key1 'value1' 'value2'; key2 'value3'"},},
})
Angular系列框架

Angular需要寫入angular.json,按照以下方式

{//..."projects":{//..."insert-project-name":{//..."architect":{//..."serve":{//..."options":{//..."headers":{"Cross-Origin-Opener-Policy": "same-origin","Cross-Origin-Embedder-Policy": "require-corp","Timing-Allow-Origin": "https://developer.mozilla.org, https://example.com","Access-Control-Expose-Headers": "Tauri-Custom-Header","Tauri-Custom-Header": "key1 'value1' 'value2'; key2 'value3'"}}}}}}
}
Nuxt系列框架

Nuxt系列框架需要寫入的文件是nuxt.config.ts

// nuxt.config.ts
export default defineNuxtConfig({//...vite: {//...server: {//...headers:{'Cross-Origin-Opener-Policy': 'same-origin','Cross-Origin-Embedder-Policy': 'require-corp','Timing-Allow-Origin': 'https://developer.mozilla.org, https://example.com','Access-Control-Expose-Headers': 'Tauri-Custom-Header','Tauri-Custom-Header': "key1 'value1' 'value2'; key2 'value3'"}},},
});
Next.js系列框架

Next.js并不依賴于Vite,但是異曲同工,寫入的文件是next.config.js

// next.config.js
module.exports = {//...async headers() {return [{source: '/*',headers: [{key: 'Cross-Origin-Opener-Policy',value: 'same-origin',},{key: 'Cross-Origin-Embedder-Policy',value: 'require-corp',},{key: 'Timing-Allow-Origin',value: 'https://developer.mozilla.org, https://example.com',},{key: 'Access-Control-Expose-Headers',value: 'Tauri-Custom-Header',},{key: 'Tauri-Custom-Header',value: "key1 'value1' 'value2'; key2 'value3'",},],},]},
}

2. 對于YewLeptos這種全棧框架

這種全棧框架只需要新建個文件Trunk.toml,然后按照以下內容寫入即可

# Trunk.toml
#...
[serve]
#...
headers = {"Cross-Origin-Opener-Policy" = "same-origin","Cross-Origin-Embedder-Policy" = "require-corp","Timing-Allow-Origin" = "https://developer.mozilla.org, https://example.com","Access-Control-Expose-Headers" = "Tauri-Custom-Header","Tauri-Custom-Header" = "key1 'value1' 'value2'; key2 'value3'"
}

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

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

相關文章

Uniapp 開發中遇到的坑與注意事項:全面指南

文章目錄 1. 引言Uniapp 簡介開發中的常見問題本文的目標與結構 2. 環境配置與項目初始化環境配置問題解決方案 項目初始化注意事項解決方案 常見錯誤與解決方案 3. 頁面與組件開發頁面生命周期注意事項示例代碼 組件通信與復用注意事項示例代碼 樣式與布局問題注意事項示例代碼…

【藍橋杯集訓·每日一題2025】 AcWing 6135. 奶牛體檢 python

6135. 奶牛體檢 Week 1 2月21日 農夫約翰的 N N N 頭奶牛站成一行,奶牛 1 1 1 在隊伍的最前面,奶牛 N N N 在隊伍的最后面。 農夫約翰的奶牛也有許多不同的品種。 他用從 1 1 1 到 N N N 的整數來表示每一品種。 隊伍從前到后第 i i i 頭奶牛的…

算法系列之搜素算法-二分查找

在算法中,查找算法是處理數據集合的基礎操作之一。二分查找(Binary Search)是一種高效的查找算法,適用于有序數組或列表。本文將介紹二分查找的基本原理、Java實現。 二分查找介紹 二分查找是一種在有序數組中查找特定元素的算法…

JVM生產環境問題定位與解決實戰(三):揭秘Java飛行記錄器(JFR)的強大功能

提到飛行記錄器,或許你的腦海中并未立刻浮現出清晰的畫面,但一說起“黑匣子”,想必大多數人都能恍然大悟,知曉其重要性及用途。在航空領域,黑匣子作為不可或缺的設備,默默記錄著飛行過程中的每一項關鍵數據…

C#開發——ConcurrentDictionary集合

ConcurrentDictionary<TKey, TValue> 是 C# 中一個專為多線程場景設計的線程安全字典集合&#xff0c;位于 System.Collections.Concurrent 命名空間中。它允許多個線程同時對字典進行讀寫操作&#xff0c;而無需額外的同步措施。 一、集合特征 此集合有如下特征…

Unity百游修煉(2)——Brick_Breaker詳細制作全流程

一、項目簡介 Brick Breaker 是一款經典的打磚塊游戲&#xff0c;本次案例將使用 Unity 引擎來實現該游戲的核心功能。 游戲畫面如下&#xff1a; Brick_ breaker 二、項目結構概覽和前期準備 &#xff08;1&#xff09;在 Unity 項目視圖中&#xff0c;我們可以看到幾個重要…

KubeSphere平臺安裝

KubeSphere簡介 KubeSphere 是一款功能強大的容器管理平臺&#xff0c;以下是其簡介&#xff1a; 1&#xff09;基本信息 開源項目&#xff1a;基于 Apache-2.0 授權協議開源&#xff0c;由 Google Go、Groovy、HTML/CSS 和 Shell 等多種編程語言開發。基礎架構&#xff1a;…

UE5銷毀Actor,移動Actor,簡單的空氣墻的制作

1.銷毀Actor 1.Actor中存在Destory()函數和Destoryed()函數 Destory()函數是成員函數&#xff0c;它會立即標記 Actor 為銷毀狀態&#xff0c;并且會從場景中移除該 Actor。它會觸發生命周期中的銷毀過程&#xff0c;調用 Destroy() 后&#xff0c;Actor 立即進入銷毀過程。具體…

Hadoop 基礎原理

Hadoop 基礎原理 基本介紹Hadoop 的必要性Hadoop 核心組件Hadoop 生態系統中的附加組件 HDFSHDFS 集群架構HDFS 讀寫流程HDFS 寫流程HDFS 讀流程 NameNode 持久化機制 MapReduce底層原理示例 Hadoop 是一個由 Apache 基金會開發的分布式系統基礎架構&#xff0c;主要解決海量數…

Linux編輯器

1.三種模式 2.圖例 3.wq 4.光標的使用

2.24DFS和BFS刷題

洛谷P2895&#xff1a;用BFS走出危險區域&#xff0c;危險區域存在時間&#xff0c;我們用ma記錄最快變成危險區域的時間&#xff0c; 然后每次枚舉時間1然后跟ma數組比較看能不能走&#xff0c;然后時間復雜度為O(305^2)。 #include<iostream> #include<cstring>…

TMDS視頻編解碼算法

因為使用的是DDR進行傳輸&#xff0c;即雙倍頻率采樣&#xff0c;故時鐘只用是并行數據數據的5倍&#xff0c;而不是10倍。 TMDS算法流程&#xff1a; 視頻編碼TMDS算法流程實現&#xff1a; timescale 1 ps / 1ps //DVI編碼通常用于視頻傳輸&#xff0c;將并行數據轉換為適合…

C++中tuple的用法

C中tuple的用法 在C中&#xff0c;std::tuple 是一個模板類&#xff0c;用于存儲一組不同類型的值。它類似于 Python 中的元組&#xff0c;但具有更強大的功能&#xff0c;例如支持不同類型的元素和更復雜的操作。std::tuple 是 C11 標準引入的&#xff0c;位于 <tuple>…

計算機網絡————(一)HTTP講解

基礎內容分類 從TCP/IP協議棧為依托&#xff0c;由上至下、從應用層到基礎設施介紹協議。 1.應用層&#xff1a; HTTP/1.1 Websocket HTTP/2.0 2.應用層的安全基礎設施 LTS/SSL 3.傳輸層 TCP 4.網絡層及數據鏈路層 IP層和以太網 HTTP協議 網絡頁面形成基本 流程&#xff1a…

【網絡編程】廣播和組播

數據包發送方式只有一個接受方&#xff0c;稱為單播。如果同時發給局域網中的所有主機&#xff0c;稱為廣播。只有用戶數據報(使用UDP協議)套接字才能廣播&#xff1a; 廣播地址以192.168.1.0 (255.255.255.0) 網段為例&#xff0c;最大的主機地址192.168.1.255代表該網段的廣…

小程序如何實現跨頁面通信

前言 最近有很多同學問&#xff0c;小程序里面如何進行跨頁面通信。看了下之前的老代碼&#xff0c;基本都是基于onShow或者localStorage。雖然可以實現&#xff0c;但是并不怎么優雅。 今天就來聊一聊&#xff0c;小程序的跨頁面通信的幾種實現方案。或許會有你想要的方案&a…

【工具】win-畫圖 保留圖片信息并僅改變圖片比例的工具

Windows 系統自帶的“畫圖”工具 Windows 系統自帶的“畫圖”&#xff08;Paint&#xff09;工具可以進行簡單的圖片編輯&#xff0c;包括調整圖片大小和比例。 使用方法&#xff1a; 打開“畫圖”工具&#xff08;可以通過在開始菜單中搜索“畫圖”或“Paint”&#xff09;。…

如何編輯autodl中以.bashrc結尾的隱藏文件

在nnunet的運行過程中遇到了設置環境變量的問題。之前沒有接觸過linux系統&#xff0c;但是autodl里面默認是linux系統。.bashrc 是一個在 Bash shell 啟動時執行的腳本文件&#xff0c;常用于設置環境變量、定義別名、加載函數等&#xff0c;用戶可以通過編輯這個文件來定制自…

實驗3 知識表示與推理

實驗3 知識表示與推理 一、實驗目的 &#xff08;1&#xff09;掌握知識和知識表示的基本概念&#xff0c;理解其在AI中的深刻含義與意義&#xff1b; &#xff08;2&#xff09;熟悉AI中常用的知識表示方法的優缺點及其應用場景&#xff1b; &#xff08;3&#xff09;掌握產…

在 M1 Mac 上解鎖 TensorFlow GPU 加速:從環境搭建到實戰驗證

在 M1 Mac 上解鎖 TensorFlow GPU 加速&#xff1a;從環境搭建到實戰驗證 前言&#xff1a;蘋果芯片的深度學習新紀元 隨著 Apple Silicon 芯片的普及&#xff0c;M1/M2/M3 系列 Mac 已成為移動端深度學習開發的新選擇。本文將以 TensorFlow 2.x 為例&#xff0c;手把手教你如…