国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁(yè) 后端開(kāi)發(fā) Golang 制作漂亮的 API 密鑰

制作漂亮的 API 密鑰

Jan 11, 2025 am 08:52 AM

Making Beautiful API Keys

摘要: AgentStation 為了提升開(kāi)發(fā)者體驗(yàn),創(chuàng)建了 uuidkey 包,將 UUID 編碼成美觀易讀的 API 密鑰。該包支持 UUIDv7,并可解碼密鑰以便數(shù)據(jù)庫(kù)排序和索引。

問(wèn)題:

API 密鑰是用戶(hù)與 AgentStation 產(chǎn)品初次交互的重要環(huán)節(jié)。我們希望密鑰既美觀又易用,但行業(yè)中似乎缺乏統(tǒng)一標(biāo)準(zhǔn)。作為一家以開(kāi)發(fā)者為中心的初創(chuàng)公司,我們投入時(shí)間和精力尋找理想的解決方案。

大多數(shù) API 密鑰都很糟糕:

我們對(duì) API 密鑰提出了以下要求:

  • 安全
  • 全局唯一
  • 可排序
  • 在 Postgres 中性能優(yōu)異
  • 外觀美觀

然而,大多數(shù) API 密鑰都缺乏美感,通常是格式不一致的隨機(jī)字符,難以閱讀、排序和識(shí)別。 我們希望 API 密鑰也具備美感,如同生活中美好的事物一樣對(duì)稱(chēng)。

我們拒絕的 ID:

過(guò)于隨機(jī)、容易猜測(cè)、外觀難看……都不盡如人意。

  • 整數(shù)和 BigInt: 簡(jiǎn)單易讀,易于排序。但它們會(huì)暴露密鑰數(shù)量,且容易猜測(cè),安全性不足。
  • NanoIDs: 提供完全隨機(jī)、可自定義的 ID,特別適合面向公眾的標(biāo)識(shí)符。但缺乏用于排序和調(diào)試的時(shí)間戳信息。
  • UUIDs: 行業(yè)標(biāo)準(zhǔn),有兩個(gè)版本值得考慮:
    • UUIDv4:純隨機(jī)字符,簡(jiǎn)單有效。
    • UUIDv7:包含時(shí)間戳,便于調(diào)試和數(shù)據(jù)庫(kù)查詢(xún)排序。
  • ULIDs: 包含時(shí)間戳并使用 Base32 編碼,提高可讀性。但我們更傾向于 UUID 原生的 Postgres 支持,且其美觀性仍不足。

我們的解決方案:

由于現(xiàn)有方案的美觀性(對(duì)稱(chēng)性)不足,我們創(chuàng)建了自己的方法:

  1. 使用 UUIDv7 作為基礎(chǔ) ID,利用時(shí)間戳信息。
  2. 使用 Crockford Base32 編碼提高可讀性。
  3. 添加美觀的破折號(hào)以增強(qiáng)視覺(jué)效果。

結(jié)果:

<code>key, _ := uuidkey.Encode("d1756360-5da0-40df-9926-a76abff5601d")
fmt.Println(key) // Output: 38QARV0-1ET0G6Z-2CJD9VA-2ZZAR0X</code>

我們的密鑰:

  • 31 個(gè)字符(不含破折號(hào)為 28 個(gè)),比 UUID 的 36 個(gè)字符更短。
  • 高度可讀的段落,包含 4 組 7 個(gè)大寫(xiě)字母和數(shù)字,具有“塊狀”的美感和可讀性。
  • 以解碼后的 UUID 形式存儲(chǔ)時(shí),可以按時(shí)間順序排序。
  • 用戶(hù)可見(jiàn)的密鑰中時(shí)間戳被模糊處理(但精通技術(shù)的使用者仍然可以解碼)。我們認(rèn)為密鑰中的時(shí)間戳元數(shù)據(jù)是一個(gè)額外的好處,您也可以選擇使用 UUIDv4!

為什么選擇 UUIDv7?

除了時(shí)間戳的優(yōu)勢(shì)外,UUIDv7 將在 Postgres v18 中獲得原生支持。雖然目前可以使用擴(kuò)展在服務(wù)器端生成 UUIDv7,但原生 Postgres 支持的性能肯定會(huì)更好,并且可以很好地與 uuidkey.Encode() 配合使用。

在我們的實(shí)現(xiàn)中,我們目前在應(yīng)用程序?qū)由擅荑€,并將其作為 UUID 存儲(chǔ)以進(jìn)行排序和索引。一旦發(fā)布 Postgres v18,我們將切換到 Postgres 生成,以減輕應(yīng)用程序?qū)拥呢?fù)載并獲得更好的性能。

為什么選擇 Crockford Base32?

我們選擇 Crockford Base32 編碼是因?yàn)樗?/p>

  • 只使用大寫(xiě)字母和數(shù)字,提高了可讀性。
  • 將密鑰長(zhǎng)度減少約 1/5。
  • 映射高效且可預(yù)測(cè)。

為什么使用破折號(hào)?

帶破折號(hào)的密鑰“塊狀”且對(duì)稱(chēng)。如果將各個(gè)字符灰顯,它們看起來(lái)幾乎像條形碼。我們認(rèn)為這使得快速讀取密鑰的一部分以識(shí)別它變得容易。

破折號(hào)確實(shí)會(huì)移除方便的雙擊復(fù)制功能,但我們認(rèn)為這是為了可讀性而值得的權(quán)衡。我們不希望用戶(hù)到處復(fù)制粘貼它們,事實(shí)上我們希望它們得到謹(jǐn)慎處理。理想情況下,用戶(hù)只在我們的儀表盤(pán)中生成密鑰時(shí)復(fù)制一次密鑰——因此我們?cè)?UI 中添加了一個(gè)復(fù)制按鈕來(lái)解決這個(gè)問(wèn)題。

uuidkey 包:

我們?cè)?github.com/agentstation/uuidkey 上開(kāi)源了這些設(shè)計(jì)選擇。如果您認(rèn)同我們的美學(xué)、推理和對(duì)稱(chēng)性,并希望擁有自己美觀的 API 密鑰,歡迎試用我們的開(kāi)源項(xiàng)目。

uuidkey 包的核心是通過(guò) Base32-Crockford 編解碼器將 UUID 編碼為可讀的密鑰格式,并將其解碼回 UUID。

編碼:

代碼片段已在原文中給出,此處不再贅述。

解碼:

代碼片段已在原文中給出,此處不再贅述。

該包旨在與遵循官方 UUID 規(guī)范 (RFC 4122) 的任何 UUID 配合使用,但我們專(zhuān)門(mén)測(cè)試并維護(hù)與兩個(gè)最流行的 UUID Go 生成器的兼容性:

  • Gofrs
  • Google

安裝很簡(jiǎn)單:

<code>key, _ := uuidkey.Encode("d1756360-5da0-40df-9926-a76abff5601d")
fmt.Println(key) // Output: 38QARV0-1ET0G6Z-2CJD9VA-2ZZAR0X</code>

基本用法:

<code>go get github.com/agentstation/uuidkey</code>

我們努力將開(kāi)銷(xiāo)降至最低:

性能基準(zhǔn)測(cè)試數(shù)據(jù)已在原文中給出,此處不再贅述。

貢獻(xiàn)給 uuidkey:

我們致力于維護(hù) uuidkey 作為可靠的開(kāi)源工具,因?yàn)槲覀冊(cè)谏a(chǎn)中使用它——?dú)g迎貢獻(xiàn)!

如果您覺(jué)得它有用或有改進(jìn)建議,我們很樂(lè)意在我們的 GitHub issues 或 Discord 社區(qū)中聽(tīng)到您的意見(jiàn)。

先前技術(shù)和巨人肩膀:

在我們發(fā)布項(xiàng)目后,我們發(fā)現(xiàn)了一些具有類(lèi)似實(shí)現(xiàn)的項(xiàng)目,但仍然沒(méi)有滿(mǎn)足我們使用 Go 編碼和解碼 UUID 的標(biāo)準(zhǔn)。

  • uuidapikey - Go,但不支持編碼或解碼 UUID 輸入。
  • based_uuid - Ruby,但用于公共 ID。

總結(jié):

在 AgentStation,我們正在構(gòu)建一個(gè)平臺(tái),讓 AI 代理?yè)碛凶约旱奶摂M工作站來(lái)運(yùn)行瀏覽器、參加會(huì)議和執(zhí)行代碼。隨著我們擴(kuò)展到數(shù)千個(gè)工作站,擁有可排序、高性能的密鑰是實(shí)用的基礎(chǔ)設(shè)施。

但我們也相信,開(kāi)發(fā)者像我們一樣欣賞對(duì)稱(chēng)的美好事物,即使是 API 密鑰。

我們希望您發(fā)現(xiàn) uuidkey 既實(shí)用又美觀。

腳注已在原文中給出,此處不再贅述。

以上是制作漂亮的 API 密鑰的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門(mén)話題

默認(rèn)情況下,GO靜態(tài)鏈接的含義是什么? 默認(rèn)情況下,GO靜態(tài)鏈接的含義是什么? Jun 19, 2025 am 01:08 AM

Go默認(rèn)將程序編譯為獨(dú)立二進(jìn)制文件,主要原因是靜態(tài)鏈接。1.部署更簡(jiǎn)單:無(wú)需額外安裝依賴(lài)庫(kù),可直接跨Linux發(fā)行版運(yùn)行;2.二進(jìn)制體積更大:包含所有依賴(lài)導(dǎo)致文件尺寸增加,但可通過(guò)構(gòu)建標(biāo)志或壓縮工具優(yōu)化;3.更高的可預(yù)測(cè)性與安全性:避免外部庫(kù)版本變化帶來(lái)的風(fēng)險(xiǎn),增強(qiáng)穩(wěn)定性;4.運(yùn)行靈活性受限:無(wú)法熱更新共享庫(kù),需重新編譯部署以修復(fù)依賴(lài)漏洞。這些特性使Go適用于CLI工具、微服務(wù)等場(chǎng)景,但在存儲(chǔ)受限或依賴(lài)集中管理的環(huán)境中需權(quán)衡取舍。

在沒(méi)有C中的手動(dòng)內(nèi)存管理的情況下,如何確保內(nèi)存安全性? 在沒(méi)有C中的手動(dòng)內(nèi)存管理的情況下,如何確保內(nèi)存安全性? Jun 19, 2025 am 01:11 AM

Goensuresmemorysafetywithoutmanualmanagementthroughautomaticgarbagecollection,nopointerarithmetic,safeconcurrency,andruntimechecks.First,Go’sgarbagecollectorautomaticallyreclaimsunusedmemory,preventingleaksanddanglingpointers.Second,itdisallowspointe

如何在GO中創(chuàng)建緩沖頻道? (例如,make(chan int,10)) 如何在GO中創(chuàng)建緩沖頻道? (例如,make(chan int,10)) Jun 20, 2025 am 01:07 AM

在Go中創(chuàng)建緩沖通道只需在make函數(shù)中指定容量參數(shù)即可。緩沖通道允許發(fā)送操作在沒(méi)有接收者時(shí)暫存數(shù)據(jù),只要未超過(guò)指定容量,例如ch:=make(chanint,10)創(chuàng)建了一個(gè)可存儲(chǔ)最多10個(gè)整型值的緩沖通道;與無(wú)緩沖通道不同,發(fā)送數(shù)據(jù)時(shí)不會(huì)立即阻塞,而是將數(shù)據(jù)暫存于緩沖區(qū)中,直到被接收者取走;使用時(shí)需注意:1.容量設(shè)置應(yīng)合理以避免內(nèi)存浪費(fèi)或頻繁阻塞;2.需防止緩沖區(qū)無(wú)限堆積數(shù)據(jù)導(dǎo)致內(nèi)存問(wèn)題;3.可用chanstruct{}類(lèi)型傳遞信號(hào)以節(jié)省資源;常見(jiàn)場(chǎng)景包括控制并發(fā)數(shù)量、生產(chǎn)者-消費(fèi)者模型及異

如何使用GO進(jìn)行系統(tǒng)編程任務(wù)? 如何使用GO進(jìn)行系統(tǒng)編程任務(wù)? Jun 19, 2025 am 01:10 AM

Go是系統(tǒng)編程的理想選擇,因?yàn)樗Y(jié)合了C等編譯型語(yǔ)言的性能與現(xiàn)代語(yǔ)言的易用性和安全性。1.文件與目錄操作方面,Go的os包支持創(chuàng)建、刪除、重命名及檢查文件和目錄是否存在,使用os.ReadFile可一行代碼讀取整個(gè)文件,適用于編寫(xiě)備份腳本或日志處理工具;2.進(jìn)程管理方面,通過(guò)os/exec包的exec.Command函數(shù)可執(zhí)行外部命令、捕獲輸出、設(shè)置環(huán)境變量、重定向輸入輸出流以及控制進(jìn)程生命周期,適合用于自動(dòng)化工具和部署腳本;3.網(wǎng)絡(luò)與并發(fā)方面,net包支持TCP/UDP編程、DNS查詢(xún)及原始套

如何在GO中的結(jié)構(gòu)實(shí)例上調(diào)用方法? 如何在GO中的結(jié)構(gòu)實(shí)例上調(diào)用方法? Jun 24, 2025 pm 03:17 PM

在Go語(yǔ)言中,調(diào)用結(jié)構(gòu)體方法需先定義結(jié)構(gòu)體和綁定接收者的方法,使用點(diǎn)號(hào)訪問(wèn)。定義結(jié)構(gòu)體Rectangle后,可通過(guò)值接收者或指針接收者聲明方法;1.使用值接收者如func(rRectangle)Area()int,通過(guò)rect.Area()直接調(diào)用;2.若需修改結(jié)構(gòu)體,應(yīng)使用指針接收者如func(r*Rectangle)SetWidth(...),Go會(huì)自動(dòng)處理指針與值的轉(zhuǎn)換;3.嵌入結(jié)構(gòu)體時(shí),內(nèi)嵌結(jié)構(gòu)體的方法會(huì)被提升,可直接通過(guò)外層結(jié)構(gòu)體調(diào)用;4.Go無(wú)需強(qiáng)制使用getter/setter,字

GO中的接口是什么?如何定義它們? GO中的接口是什么?如何定義它們? Jun 22, 2025 pm 03:41 PM

在Go語(yǔ)言中,接口是一種定義行為而不指定實(shí)現(xiàn)方式的類(lèi)型。接口由方法簽名組成,任何實(shí)現(xiàn)這些方法的類(lèi)型都自動(dòng)滿(mǎn)足該接口。例如,定義一個(gè)Speaker接口包含Speak()方法,則所有實(shí)現(xiàn)該方法的類(lèi)型均可視為Speaker。接口適用于編寫(xiě)通用函數(shù)、抽象實(shí)現(xiàn)細(xì)節(jié)和測(cè)試中使用mock對(duì)象。定義接口使用interface關(guān)鍵字并列出方法簽名,無(wú)需顯式聲明類(lèi)型實(shí)現(xiàn)了接口。常見(jiàn)用例包括日志、格式化、不同數(shù)據(jù)庫(kù)或服務(wù)的抽象,以及通知系統(tǒng)等。例如,Dog和Robot類(lèi)型均可實(shí)現(xiàn)Speak方法,并傳遞給同一個(gè)Anno

如何在GO中使用字符串軟件包中的字符串函數(shù)? (例如len(),strings.contains(),strings.index(),strings.replaceall()) 如何在GO中使用字符串軟件包中的字符串函數(shù)? (例如len(),strings.contains(),strings.index(),strings.replaceall()) Jun 20, 2025 am 01:06 AM

在Go語(yǔ)言中,字符串操作主要通過(guò)strings包和內(nèi)置函數(shù)實(shí)現(xiàn)。1.strings.Contains()用于判斷字符串是否包含子串,返回布爾值;2.strings.Index()可查找子串首次出現(xiàn)的位置,若不存在則返回-1;3.strings.ReplaceAll()能替換所有匹配的子串,還可通過(guò)strings.Replace()控制替換次數(shù);4.len()函數(shù)用于獲取字符串字節(jié)數(shù)長(zhǎng)度,但處理Unicode時(shí)需注意字符與字節(jié)的區(qū)別。這些功能常用于數(shù)據(jù)過(guò)濾、文本解析及字符串處理等場(chǎng)景。

如何使用IO軟件包在GO中使用輸入和輸出流? 如何使用IO軟件包在GO中使用輸入和輸出流? Jun 20, 2025 am 11:25 AM

TheGoiopackageprovidesinterfaceslikeReaderandWritertohandleI/Ooperationsuniformlyacrosssources.1.io.Reader'sReadmethodenablesreadingfromvarioussourcessuchasfilesorHTTPresponses.2.io.Writer'sWritemethodfacilitateswritingtodestinationslikestandardoutpu

See all articles