bknd项目v0.12.0版本发布:类型生成与安全增强
bknd是一个现代化的后端开发框架,它提供了从数据模型定义到API生成的一整套解决方案。最新发布的v0.12.0版本带来了多项重要更新,特别是在类型安全和系统安全方面有了显著提升。
类型生成功能
在开发过程中,类型安全是保证代码质量的重要手段。新版本引入了类型生成功能,开发者可以通过简单的命令行操作自动生成项目中所有实体的TypeScript类型定义。
使用方式非常简单,只需在项目根目录下执行:
npx bknd types
这条命令会生成一个名为bknd-types.d.ts的类型定义文件。为了确保这些类型能够在项目中生效,开发者需要将其包含在tsconfig.json的include数组中。
这一功能无论是对使用原型函数定义数据结构的开发者,还是偏好通过Admin UI可视化构建数据模型的用户都非常实用,它大大减少了手动维护类型定义的工作量,提高了开发效率。
密码哈希策略增强
在安全方面,v0.12.0版本新增了bcrypt作为密码哈希策略选项。bcrypt是目前公认的安全密码哈希算法,它通过加入"盐"(salt)和可调节的计算成本来有效抵御彩虹表攻击。
现在开发者可以在密码策略配置中选择三种哈希方式:
- plain - 明文存储(仅建议用于开发和测试环境)
- sha256 - SHA-256哈希
- bcrypt - 更安全的bcrypt哈希
这一变化使得bknd在用户认证安全方面达到了行业标准,为生产环境应用提供了更可靠的安全保障。
媒体文件权限控制
新版本还对媒体文件的安全访问机制进行了完善。当启用Guard安全模块时,现在需要为角色显式配置以下媒体相关权限:
- 读取媒体文件
- 列出媒体文件
- 上传媒体文件
- 删除媒体文件
对于已经配置了implicit_allow的管理员角色,系统会自动应用这些新权限,确保现有系统的平滑过渡。这一改进使得媒体资源的访问控制更加精细,符合最小权限原则。
其他重要改进
除了上述主要特性外,v0.12.0还包含多项优化和修复:
- 错误处理和日志记录机制得到了增强,使调试更加方便
- Media API现在支持自定义fetch实现,提高了灵活性
- 同步事件处理机制得到修复,确保操作的正确顺序
- Dropzone组件进行了重构,使用zustand统一状态管理
- 移除了LiquidJs渲染引擎,改用更简单的渲染器实现
这些改进共同提升了框架的稳定性、性能和开发者体验。
升级建议
对于正在使用bknd的项目,建议尽快升级到v0.12.0版本以获取这些新特性和安全改进。特别是对于生产环境应用,采用bcrypt密码哈希策略和媒体权限控制将显著提高系统安全性。
升级过程通常只需更新依赖版本并重新生成类型定义即可。如果项目中有自定义的媒体访问逻辑,可能需要根据新的权限系统进行相应调整。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C081
baihu-dataset异构数据集“白虎”正式开源——首批开放10w+条真实机器人动作数据,构建具身智能标准化训练基座。00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python056
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
agent-studioopenJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力TSX0135
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00