发动态
综合 最新发布 最新回复
图文
列表
开源项目:朱迪的录音笔\n\n简介:此工程是录音电路,免编程,注意layout不要随意改动,录音电路对layout要求较高。3D外壳在附件上下载。\n\n开源链接:[https://oshwhub.com/dora.ma/zhu-di-de-lu-yin-bi]\n#消费电子#
开源硬件平台
这是什么芯片啊包括型号,有谁认得吗
这是什么芯片啊包括型号,有谁认得吗
开源硬件平台
锦瑞来了哦
CA51F251L2芯片是基于1T8051内核的8位微控制器,通常情况下,运行速度比传统的8051芯片快10倍,性能更加优越。内置Flash程序存储器,可多次重复编程的特性,此系列芯片提供8K Flash容量供客户按照产品需求选择,给用户开发带来了极大的方便。不仅保留了传统8051芯片的基本特性,还集成了12Bit ADC、LCD/LED驱动、Touch Key、16 Bit PWM、UART、RTC、无刷直流电机驱动、乘除法器、低电压检测(LVD)等功能模块。支持IDLE、STOP和低速运行三种省电模式以适应不同功耗要求的应用。强大的功能及优越的抗干扰性能使其可广泛应用于各种车载音响、家用音响、小家电、蓝牙音箱、汽车电子、数码电机、运动器材、马达控制、医疗保健、仪器仪表、安防、电源控制、工业控制产品。 #嘉立创PCB# #51单片机# #DIY设计# #技术干货#
开源硬件平台
作为程序员,你竟然还在手撸代码 ??? 如果没有公司给你提供科学上网,提供AI 编程工具的账号,你真能玩转AI ??? 除了平时搜搜查查,AI 对你还有其他用处 ???震惊!某博主竟然开头就贩卖焦虑?难道程序员真的要被 AI 取代了? 别急,这篇文章就一步步带你玩转 AI 编程! 如果只是想了解如何使用 AI 编程,可以直接跳到章节: 「所以,我们需要什么!?」理解概念要深入使用 AI,我们要先理解一些概念1. AI 基础AI大模型:拥有超大规模参数、超级聪明的机器学习模型,所有的 AI 应用都是调用大模型的计算处理能力。如:问答、图片生成、视频生成。[机-会]技术大厂,前端-后端-测试,新一线和一二线城市等地均有机-会,感兴趣可以试试。待遇和稳定性都不错~————国内主流大模型对比:国外主流大模型对比模型厂商核心能力主攻场景Gemini🐂🍺Google DeepMind多模态能力强大,可无缝处理文本、图像、音频、视频、代码等创意内容创作、文档处理、用于处理复杂、多源信息的场景Claude🐂🍺Anthropic推理能力优秀,多模态能力一般长文档分析场景,如法律文件审查;适用于需要可靠输出的领域,如医疗诊断辅助Veo 3Google自动生成视频和音频,口型同步精准到毫秒级。支持最高 4K 分辨率输出,画质清晰,色彩还原。生成速度快专注于视频生成领域,如短视频内容创作,为用户提供高效、高质量的视频生成解决方案。SonnetAnthropicSonnet 是 Claude 3 系列中的平衡型模型,性价比高适用于注重性价比和处理速度的场景,如一般性的文档分析GPTOpenAI通用性极强,各个方面都有出色表现,GPT-4o 等版本增强了多模态交互能力。自然语言处理相关的场景,如内容创作、智能客服CopilotGitHub 与 OpenAI 合作开发基于 GPT 系列模型训练,理解自然语言,生成对应代码用于日常编码、代码调试、新手编程学习,降低重复编码工作量一般我们编程使用的都是国外的大模型,毕竟开发工具、系统、编程语言都是外国的。编码方面的能力,国外模型还是碾压的存在。MCP:一套提供给 AI 大模型调用的标准协议。一些厂商会把自己的能力包装成MCP,让大模型在理解完用户的复杂任务时,可以调用厂商的能力。比如:你让豆包给你用 “高德” 生成一份超准的导航,豆包就会去调用高德的 MCP,为你出导航~IDE:程序员专属概念。AI IDE是集成了 AI 能力的软件开发平台,开发者可以通过自然语言,让 IDE 调用 AI 模型和 MCP 给你写代码,速度和质量牛的飞起,真有手就能写代码!主流的 AI IDE 对比名称厂商搭载的模型收费维度Cursor🐂Cursor 公司GPT-4、Claude 3.5、Cursor-small、o3-mini 等很贵,按 token 收费Antigravity🐂🍺Google支持在 Gemini 3 Pro、Claude Sonnet 4.5 和 GPT-OSS 等多种模型之间无缝切换有羊毛薅,国外邮箱+学生认证~Trae字节跳动国内版搭载豆包 1.5-pro、DeepSeek R1/V3 等模型,海外版内置 GPT-4o、Claude-3.5-Sonnet 模型国内的,充个会员的事,不贵2. RAG ➡️ Agent ➡️ Planning:AI 应用方式的演进之路AI 的应用方式正从 “被动响应” 向 “主动规划” 快速迭代。 从 RAG 进行检索增强生成,到 AI Agent 实现自主调用工具完成任务,再到 Planning 能 “拆解复杂任务与全局决策” 的高阶形态。让 AI 从 “内容生成器” 蜕变到 “智能协作体”。RAG —— 检索增强生成 核心逻辑是:先检索,再生成。用户提出问题,先从外部数据库、文档库中检索与问题最相关的信息,再将这些信息作为 “参考资料” 喂给大模型,让模型基于真实数据生成回答。AI Agent —— “自主工具操作员” AI Agent(智能体) ,让 AI 像人一样调用工具、执行步骤、验证结果。能理解用户的模糊需求,自主规划任务步骤,选择并调用合适的工具(如计算器、浏览器、代码解释器、RAG 系统),完成任务。Planning(规划)—— “全局任务指挥官” AI 系统的高阶能力,核心逻辑是 “先拆解,再执行,再调整”。基于全局目标,将复杂、长期、多约束的任务拆解为有序的子任务序列,并根据执行过程中的反馈动态调整策略。 不仅关注单个任务的完成,更关注子任务之间的关联和整体目标的达成。演进逻辑与核心差异总结维度RAG(检索增强生成)AI Agent(智能体)Planning(规划)核心定位大模型的 “知识库外挂”自主工作的 “工具操作员”全局任务的 “指挥官”能力核心检索 + 生成,保证回答准确决策 + 工具调用,完成单任务闭环拆解 + 协同 + 动态调整,掌控多任务全局典型比喻学生的 “参考书”能独立完成工作的 “专员”统筹全局的 “项目经理”所以,我们需要什么!?你作为一名优秀的程序员,你需要通过科学上网、精准付费,在 AI IDE中,基于AI大模型的能力,熟练使用 Agent/Planning,配合 MCP 等工具,让 AI 帮你写出又快又好的代码,更好的服务你的业务!1. 使用 Cursor、Antigravity、Trae 开发工具下载地址:Cursor、Antigravity、TREA 账号注册:Cursor 和 Trae 登录方式都超简单,会员的话直接去官网购买即可 至于 Antigravity,因为 Google 是禁止国内用户访问的,因此一定要能正常上网,邮箱账号必须纯正🇺🇸,但是我们有 闲鱼 之光,是可以尝试下的~ 2. 装好主流 MCP对于前端程序员,UI 这类低级工作,完全可以交给 Agent 去编写。比如:公司的设计师用的是figma,我们只需要在 cursor 中装上figma mcp,然后 figma 账号申请开发者权限,就能自由的让 AI 帮我们写好代码。亲测还原度 85%+ 3. 沉淀 Rules 和 Workflows我们现在已经可以通过开发工具让 AI 干活了,但如何更符合我们的编码习惯和设计思想?那就得给 AI 规范,也就是通过提示词让 AI 更乖的,干更对的活。 比如,Antigravity就有明确的让我们添加规则和工作流的入口,并且会引导我们如何写提示词,然后在提问的时候,引用对应的文件即可。 Rules(规则)和Workflows(工作流),沉淀 沉淀 再 沉淀!!! 4. !!!文档先行!!!AI 时代的编码,一定要做好设计,写好文档。 AI 虽然帮你干活,但是任务是你来安排的,你给出的任务要足够精准。 同时,你的编码思维才是代码能写好的核心,你必须把你的思维和想法,落成文档给到 AI 大模型。markdown 格式:注意 AI 需要理解 md 文档图文并茂:在编写文档的时候,时常需要画图,此时可以使用 md 语法来画图。这里我推荐mermaidchart,可以基于 md 语法进行可视化编辑。 写在最后当你有正常可以使用模型的账号后,其实这个账号不仅仅是在 IDE 可以使用,比如 Antigravity 的账号,跟 Gemini 是一致的,你也可以在大模型的官网登录进行图片、视频生成。在了解了大模型、MCP、工作流、AI 编程工具后,相信你对 AI 的应用又有了新的理解。我们一定要积极去尝试,国内国外的 AI 工具能用的多用,尽情的去拥抱 AI!AI 是生产力,毋庸置疑!——转载自:Karl_wei
AI 只会淘汰不用 AI 的程序员🥚
开源硬件平台
请教下手机上面是怎么测算电池的循环次数和剩余容量的?
已知锂电池的总容量是会随着使用次数而减小的,智能手机使用时,用户一般不会等到电池耗光电量再充电,甚至充电也不一定会充到满电再拔出充电器,那么已进行的循环次数如何判断呢?难道只估算充电或放电单向部分的总容量在除以单电池容量吗? 此外,部分手机会公开自身的电池健康度数据,而用户几乎不会把电池放空再充满,也就是不会有一个完整的充放电循环让库仑计去直接得出当前的电池剩余总容量,那么他们是怎么估算出当前电池容量的?
开源硬件平台
在Type-C接口相关的硬件开发与电子DIY场景中,6P电源板省略5.1kΩ CC下拉电阻的设计常引发技术疑问 🤔。需明确的是,此类省略仅适用于特定限定场景,非通用设计方案。从工程化设计角度,优先配置5.1kΩ CC下拉电阻是保障Type-C接口兼容性与供电稳定性的核心前提。本文将系统解析Type-C接口6P与16P的选型逻辑,深入阐释5.1kΩ CC下拉电阻的技术原理与影响,为硬件设计、选型整改及配件选用提供专业技术指引。一、Type-C 6P与16P供电接口技术特性对比Type-C接口的引脚配置直接决定其功能边界与应用场景,6P与16P为两类典型的供电导向型配置,核心差异集中于引脚功能扩展与协议支持能力。1.1 6P(纯供电精简型)接口6P接口为供电功能优先的精简配置,仅保留VBUS(供电主通道)、GND(接地回路)、CC1/CC2(配置通道)四大核心功能对应的6个引脚。该配置具备成本可控、焊接工艺难度低、良率高等优势,适用于仅需供电功能的终端设备,如移动电源、TWS耳机充电盒、小功率电源适配器等纯受电或供电设备。技术局限性:无数据传输通道,无法支持依赖D+/D-差分对的快充协议(如QC、AFC等),仅可通过PD(Power Delivery)协议实现电压与电流协商,进而达成快充需求。1.2 16P(功能扩展型)接口16P接口在6P核心引脚配置基础上,新增USB 2.0 D+/D-差分对(数据传输通道)、SBU1/2(辅助扩展通道)等引脚,实现供电与基础数据传输的功能融合。其可支持480Mbps低速数据传输与供电并行,通过SBU引脚扩展还可实现DP音视频传输等增值功能(需配套固件与协议栈支持)。适用场景:开发板、精简版智能手机、USB 2.0移动硬盘等需兼顾供电与低速数据交互的设备。相较于6P接口,其成本略高,且新增引脚对PCB布局与焊接工艺精度要求更高。二、5.1kΩ CC下拉电阻的技术原理与影响分析CC(Configuration Channel)引脚是Type-C接口实现端口角色识别、供电协议协商的核心通道,5.1kΩ下拉电阻是符合USB PD规范的关键元件,其有无直接决定接口的工作状态与安全性。2.1 合规配置(含5.1kΩ下拉电阻)✅当受电端(UFP侧)在CC1/CC2引脚对地并联5.1kΩ下拉电阻时,供电端(DFP侧)可通过CC引脚的阻抗检测机制快速识别受电设备接入,完成端口角色定位与PD等快充协议的握手流程。技术优势:6P接口可稳定实现PD协议快充;16P接口可同时实现USB 2.0数据传输与多协议快充功能,供电链路具备完善的协议保护,稳定性与安全性符合行业规范。违规配置(无5.1kΩ下拉电阻)❌缺失5.1kΩ下拉电阻将导致供电端无法完成标准阻抗检测,进而引发端口角色识别失效、供电协议协商失败等一系列问题,具体表现如下:C-to-C接口场景:供电端与受电端均无法完成DRP(双角色端口)角色协商,直接导致供电链路无法建立,设备无法获取电力;A-to-C接口场景:多数合规充电器仅能输出5V默认电压与0.5A小电流的慢充模式,PD、PPS等快充协议因缺少阻抗触发条件无法激活;非标旧款充电器:可能存在强制输出5V/3A恒压恒流的异常工况,因缺失协议握手与动态调整机制,易导致设备过热、元器件损坏,甚至引发短路、起火等安全隐患。三、选型策略与整改技术方案结合接口功能需求与成本控制目标,需制定针对性的选型方案;针对已存在的缺失5.1kΩ电阻问题,可通过标准化整改恢复接口正常功能。3.1 选型核心准则纯供电+成本敏感场景:选用6P接口,需在受电端CC1/CC2引脚分别对地并联5.1kΩ±1%精度电阻;配套PD协议芯片可实现多档位快充,无PD芯片则仅支持5V慢充模式;供电+USB 2.0数据场景:选用16P接口,保留D+/D-差分对以兼容QC、AFC等多协议快充,同步在CC1/CC2引脚配置5.1kΩ对地下拉电阻,保障协议协商可靠性。3.2 缺失电阻整改方案 🔧核心整改措施:在受电端CC1/CC2引脚分别并联1个5.1kΩ±1%贴片电阻至GND,建议选用0402或0603封装以适配PCB布局;针对电磁干扰敏感场景,可在电阻支路串联10nF~100nF陶瓷电容实现高频滤波,确保CC引脚信号稳定性,恢复接口正常识别与快充功能。四、充电器选用与故障排查规范Type-C接口的供电可靠性不仅取决于设备端设计,还与充电器选型、线缆质量密切相关,需建立标准化的选用与排查流程。4.1 充电器选用规范优先选用符合USB PD规范的认证产品:根据设备额定功率选用匹配规格(如65W、100W),规避非标快充头,降低强制供电带来的安全风险;接口功能匹配验证:6P接口设备需确保充电器支持PD协议;16P接口设备若需兼顾数据与快充,需确认充电器同时兼容PD协议与USB 2.0传输规范(多数合规充电器可满足)。4.2 供电异常故障排查流程 🔍当出现慢充、无供电等异常情况时,建议遵循以下排查逻辑:核心元件核查:优先确认设备端CC1/CC2引脚5.1kΩ下拉电阻是否存在、焊接是否可靠;交叉验证测试:更换已知正常的设备测试充电器,判断故障是否源于充电器;线缆质量排查:更换合规Type-C线缆,劣质线缆易出现CC引脚导通不良或阻抗异常,直接影响识别与快充功能。4.3 线缆选用注意事项选用支持CC引脚正常导通的合规线缆,避免使用CC引脚虚接、阻抗超标的劣质产品。线缆的CC引脚阻抗特性直接影响供电端与受电端的阻抗检测精度,是保障协议协商成功的基础条件。#2025内容大赏# #2025年度测评# #DIY设计##技术干货#
Type-C接口核心技术解析:6P与16P选型差异及5.1kΩ CC下拉电阻的关键作用 🛠️
开源硬件平台
开源文章:立创开发板「课设/毕设」开源计划获奖名单\n\n简介:立创开发板「课设/毕设」开源计划获奖名单!本次征集令奖品有京东E卡最高500元,泰山派3-RK3576,泰山派1-RK3566,各大厂家提供的大礼包,50元彩色丝印券,还有荣誉证书~\n\n文章链接:[https://oshwhub.com/article/lichuang-development-board-class-set-up-open-source-program-award-list]\n#活动资讯#
开源硬件平台
前言想象一下:你打开一个网站,从 “首页” 点到 “个人中心”,页面连个白屏都没有 —— 这不是魔法,是 单页应用(SPA) 的 “小心机”。而让 SPA 实现 “网址变、内容换” 的幕后大佬,就是今天要唠的 React Router。我今天以一个后台管理系统来全方位的拆解路由的细节~想要详细React Router资料可以在这里找到:reactrouter.com一、从 “多页翻书” 到 “单页变魔术”早年间的网站是 “多页应用”:点个链接跳转到新 HTML 文件,像翻书似的 “唰唰” 换页。但缺点很明显:加载慢、体验卡,就像翻一本 500 页的字典找个词,翻半天手都酸了。现在的 SPA 是 “单页魔术盒”:只有一个 HTML 文件,网址变了,只是把对应的 “组件” 塞进这个盒子里 —— 就像变魔术时从盒子里掏出不同道具,盒子本身根本不动。比如我写的这个后台管理系统:访问 http://localhost:5173/login → 塞进「登录组件」访问 http://localhost:5173/home → 塞进「首页组件」网址变,内容秒切,丝滑到像德芙广告~二、React Router:SPA 的 “导航指挥家”要实现这种 “秒切”,得请出react-router-dom这个 “指挥家”。它的核心成员有这些(结合我们的后台系统代码来看更爽):首先你需要安装好react-router:就在我开头给的网址里面就可以找到哈!1. BrowserRouter:给应用 “装个导航系统”它是路由的 “容器”,相当于给整个应用装了个 “导航大脑”(用的是 HTML5 的 History API,所以网址长得像正常网址)。看App.jsx的开头: import { BrowserRouter, Routes, Route } from 'react-router-dom' export default function App() { return ( <BrowserRouter> {/* 所有路由配置都得包在它里面 */} <Routes> {/* 这里塞各种路由规则 */} </Routes> </BrowserRouter> ) } 2. Routes + Route:给 “组件” 贴 “网址标签”Routes是 “路由出口”,Route是 “网址→组件” 的标签贴。比如我们的后台系统,给 「登录页」「首页」 贴标签: <Routes> {/* 根路径直接跳转到登录页 */} <Route path="/" element={<Navigate to="/login" />} /> {/* 访问/login → 显示Login组件(就是我们写的登录界面) */} <Route path="/login" element={<Login />} /> {/* 访问/home → 显示Home组件(首页),同时它是二级路由的容器 */} <Route path="/home" element={<Home />}> {/* 二级路由:/home/class → 显示Class组件 */} <Route path="class" element={<Class />} /> {/* 二级路由:/home/leetcode → 显示LeetCode组件 */} <Route path="leetcode" element={<LeetCode />} /> </Route> {/* 404页面:匹配不到的网址都显示这个 */} <Route path="*" element={<h2>NOT FOUND</h2>} /> </Routes> 登录首页:点击登录(自动进入/home/class):像不像给每个组件发了张 “网址门票”?拿着/login门票,就能进登录页的门?机-会技术大厂,前端-后端-测试,新一线和一二线城市等地均有机-会,感兴趣可以试试。待遇和稳定性都不错~3. Outlet:二级路由的 “展示窗口”首页Home是个 “大容器”,里面要放class和leetcode这些 “子页面”——Outlet就是这个 “子页面展示窗口”。看Home.jsx的代码: import { Outlet, Link } from 'react-router-dom' export default function Home() { return ( <div className="home"> <header>后台管理系统</header> <main className="body"> <aside> {/* 侧边栏导航,点了跳转到二级路由 */} <li><Link to="/home/class">课程</Link></li> <li><Link to="/home/leetcode">算法</Link></li> </aside> <main className="content"> {/* 二级路由的内容就显示在这里! */} <Outlet /> </main> </main> </div> ) } 点击算法进入/home/leetcode:Outlet就像电视屏幕,点 “课程” 就播 《课程频道》,点 “算法” 就切 《LeetCode 频道》。4. Link:SPA 的 “无痛跳转链接”传统的<a>标签跳转是 “翻页”,Link是 “换内容”—— 点它网址变,但页面不刷新,就像遥控器换台。比如首页侧边栏的导航: <Link to="/home/class">课程</Link> 5. useNavigate:“编程式跳转” 的魔法棒有时候需要 “代码触发跳转”(比如登录成功后自动跳首页),这时候useNavigate就派上用场了。看我们的Login.jsx: import { useNavigate } from 'react-router-dom' export default function Login() { const navigate = useNavigate() // 拿到跳转函数 const login = () => { // 登录逻辑... navigate('/home') // 登录成功,跳转到首页! } return ( <div className="login"> <input placeholder="账号" /> <input placeholder="密码" /> <button onClick={login}>登录</button> </div> ) } 点登录前:点登录后:点 “登录” 按钮,navigate('/home')一执行,网址直接切到首页,比外卖小哥送餐还快~三、总结:React Router 就是 SPA 的 “导航全家桶”把这些成员凑一起,我们的后台系统就活了:打开网站,/自动跳/login → 显示登录界面(带输入框和绿色登录按钮);点 “登录”,useNavigate跳/home → 显示首页(带侧边栏);点侧边栏 “课程”,Link跳/home/class → Outlet显示课程页面;输错网址,直接显示NOT FOUND → 404 页面。是不是感觉 React Router 像个 “全能导航员”?既管网址匹配,又管页面切换,还能代码跳转 —— 有了它,SPA 才能像 “魔术盒” 一样,变内容比变魔术还快!结语说到底,React Router 就是单页应用的 “流量控制器”,它用极简的配置和灵活的 API,让我们的后台管理系统实现了 “网址变、组件换” 的丝滑体验。从登录页到首页,从一级路由到二级路由,没有烦人的页面刷新,只有行云流水的内容切换。路由其实不难,需要多理解,掌握这些核心用法,你也能轻松搭建出结构清晰、体验流畅的 SPA 应用。下次再遇到路由相关的需求,不妨拿出这些 “导航法宝”,让你的项目像后台管理系统一样,在路由的世界里畅通无阻。现在就用我的例子敲代码吧!——转载自:风止何安啊
从 “翻页书” 到 “魔术盒”:React 路由凭啥如此丝滑?
开源硬件平台
typec 好使了(好使了=功能正常,没有问题)
之前功能完全不能用,感谢 “小Q” 指出不能接两条CC,我切断了一根CC线。 另外还有一个坑。 因为开始想的是用这个FPCtypec作为一段导线用的,以为直连就行了。然而当两个公头背对背的时候,直连的线就变成A1-A12’;A2-A11' 方向颠倒了。直通的意义应该是这边A1进到另一测应该也是A1'才对,还好这是FPC,只要旋转一圈焊接就行了。 所以现在好使了,不过这种FPC排线拧绕的方式感觉不好看。本来做这个就是想代替两条CC线又长又绕的。现在线短了,但还是绕。大家有没有什么好点子,能让这块看起来干净利索儿的?
开源硬件平台
开源项目:EDA-SuperBear智能熊\n\n简介:基于ESP32S3打造的小智LLM大模型机器熊,通过LLM完成六舵机控制\n\n开源链接:[https://oshwhub.com/course-examples/eda-robot-max]\n#ESP8266/32# #AI视觉# #WiFi/以太网#
开源硬件平台
开源项目:AI陪伴虚拟宠物虚拟人数字生命盒
简介:本项目采用ESP32-S作为主控,无线联网调用AI大模型实现智能语音对话,利用串口屏显示时间、虚拟人物或宠物动态图和暖心文字,使用立创EDA设计3D打印外壳。另外适配SD卡槽,可读取播放卡内内容。 开源链接:https://oshwhub.com/qiuzhihhq/ai-digital-life-box #DIY设计# #嘉立创PCB# #嘉立创3D打印# #嘉立创免费3D打印# #ESP8266/32#
开源硬件平台
开源项目:ESP32+WS2812b+WLED的节日圣诞树\n\n简介:该项目使用ESP32主控芯片,通过开源的WLED实现对WS2812B灯珠的控制,实现圣诞的节日彩灯,具体的效果可以参考B站演示\n\n开源链接:[https://oshwhub.com/ywusmile/ji-yu-ws2812-de-mi-ni-sheng-dan-shu-wy]\n#RISC-V# #DIY设计# #消费电子#
开源硬件平台
电流环转串口
请教一下各位大佬,有设备的通讯接口是电流环的,我想通过电脑的串口来接,有没有办法?
开源硬件平台
关于数字电子秤的制作
关于数字电子秤的制作用 HX711有电路图吗
开源硬件平台
抄板、改板及打样 悬赏3万元
#技术干货# #嘉立创PCB# 寻求有经验的硬件工程师进行主板、显卡板、电源板的抄板、改板及打样工作。项目包括两个主板、一个电源板和一个显卡板的设计与优化,悬赏3万元,欢迎有相关经验的专业人士联系我! fuym9907013(vx)
开源硬件平台
大家好,我是小悟。想象一下你去游乐园,买了一张通票(登录),然后就可以玩所有项目(访问各个系统),不用每个项目都重新买票(重新登录)。这就是单点登录(SSO)的精髓!SSO的日常比喻普通登录:像去不同商场,每个都要查会员卡单点登录:像微信扫码登录,一扫全搞定令牌:像游乐园手环,戴着就能证明你买过票下面用代码来实现这个"游乐园通票系统":代码实现:简易SSO系统 import java.util.*; // 用户类 - 就是我们这些想玩项目的游客 class User { private String username; private String password; public User(String username, String password) { this.username = username; this.password = password; } // getters 省略... } // 令牌类 - 游乐园手环 class Token { private String tokenId; private String username; private Date expireTime; public Token(String username) { this.tokenId = UUID.randomUUID().toString(); this.username = username; // 令牌1小时后过期 - 游乐园晚上要关门的! this.expireTime = new Date(System.currentTimeMillis() + 3600 * 1000); } public boolean isValid() { return new Date().before(expireTime); } // getters 省略... } // SSO认证中心 - 游乐园售票处 class SSOAuthCenter { private Map<String, Token> validTokens = new HashMap<>(); private Map<String, User> users = new HashMap<>(); public SSOAuthCenter() { // 预先注册几个用户 - 办了年卡的游客 users.put("zhangsan", new User("zhangsan", "123456")); users.put("lisi", new User("lisi", "abcdef")); } // 登录 - 买票入场 public String login(String username, String password) { User user = users.get(username); if (user != null && user.getPassword().equals(password)) { Token token = new Token(username); validTokens.put(token.getTokenId(), token); System.out.println(username + " 登录成功!拿到游乐园手环:" + token.getTokenId()); return token.getTokenId(); } System.out.println("用户名或密码错误!请重新买票!"); return null; } // 验证令牌 - 检查手环是否有效 public boolean validateToken(String tokenId) { Token token = validTokens.get(tokenId); if (token != null && token.isValid()) { System.out.println("手环有效,欢迎继续玩耍!"); return true; } System.out.println("手环无效或已过期,请重新登录!"); validTokens.remove(tokenId); // 清理过期令牌 return false; } // 登出 - 离开游乐园 public void logout(String tokenId) { validTokens.remove(tokenId); System.out.println("已登出,欢迎下次再来玩!"); } } // 业务系统A - 过山车 class SystemA { private SSOAuthCenter authCenter; public SystemA(SSOAuthCenter authCenter) { this.authCenter = authCenter; } public void accessSystem(String tokenId) { System.out.println("=== 欢迎来到过山车 ==="); if (authCenter.validateToken(tokenId)) { System.out.println("过山车启动!尖叫声在哪里!"); } else { System.out.println("请先登录再玩过山车!"); } } } // 业务系统B - 旋转木马 class SystemB { private SSOAuthCenter authCenter; public SystemB(SSOAuthCenter authCenter) { this.authCenter = authCenter; } public void accessSystem(String tokenId) { System.out.println("=== 欢迎来到旋转木马 ==="); if (authCenter.validateToken(tokenId)) { System.out.println("木马转起来啦!找回童年记忆!"); } else { System.out.println("请先登录再玩旋转木马!"); } } } // 测试我们的SSO系统 public class SSODemo { public static void main(String[] args) { // 创建认证中心 - 游乐园大门 SSOAuthCenter authCenter = new SSOAuthCenter(); // 张三登录 String token = authCenter.login("zhangsan", "123456"); if (token != null) { // 拿着同一个令牌玩不同项目 SystemA systemA = new SystemA(authCenter); SystemB systemB = new SystemB(authCenter); systemA.accessSystem(token); // 玩过山车 systemB.accessSystem(token); // 玩旋转木马 // 登出 authCenter.logout(token); // 再尝试访问 - 应该被拒绝 systemA.accessSystem(token); } // 测试错误密码 authCenter.login("lisi", "wrongpassword"); } } 运行结果示例: zhangsan 登录成功!拿到游乐园手环:a1b2c3d4-e5f6-7890-abcd-ef1234567890 === 欢迎来到过山车 === 手环有效,欢迎继续玩耍! 过山车启动!尖叫声在哪里! === 欢迎来到旋转木马 === 手环有效,欢迎继续玩耍! 木马转起来啦!找回童年记忆! 已登出,欢迎下次再来玩! === 欢迎来到过山车 === 手环无效或已过期,请重新登录! 请先登录再玩过山车! 用户名或密码错误!请重新买票! 总结一下:单点登录就像:一次认证,处处通行 🎫不用重复输入密码 🔑安全又方便 👍好的SSO系统就像好的游乐园管理,既要让游客玩得开心,又要确保安全!机会技术大厂,前端-后端-测试,新一线和一二线城市等地均有机-会,感兴趣可以试试。待遇和稳定性都不错~您的一键三连,是我更新的最大动力,谢谢山水有相逢,来日皆可期,谢谢阅读,我们再会——转载自:悟空码字
单点登录:一次登录,全网通行
开源硬件平台
什么,CH340G芯片可以当做数字量输入输出监测控制?什么,还不用单片机编程,串口助手直接可用?
简介:本项目基于CH340G芯片,除USB转TTL功能外,还可+5V和+3.3V电平切换以及供电,此外将DTR,RTS,CTS,DSR,RI,DCD通信接口作为普通数字IO端口,可由串口助手或上位机监测控制。 #DIY设计# #开源硬件平台# 感兴趣可看:https://oshwhub.com/qiuzhihhq/digital-io-and-usb-to-ttl
开源硬件平台
那位大佬可以设计一款DC-DC Buck-Boost 输入电压8V-60V输出电压24V(可以通过电阻调其他电压)输出电流60A(自适应输出)原来图和PCB文件,可以设计的私聊
开源硬件平台
优质硬件创作分享平台
推荐话题 换一批
#DIY设计#
#嘉立创PCB#
#嘉立创3D打印#
#嘉立创免费3D打印#
#技术干货#
#ESP8266/32#
#2025年度踩坑日记#
#2025年度项目秀#
查看更多热门话题
打赏记录
服务时间:周一至周六 9::00-18:00 · 联系地址:中国·深圳(福田区商报路奥林匹克大厦27楼) · 媒体沟通:pr@jlc.com · 集团介绍
移动社区