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密码哈希策略和媒体权限控制将显著提高系统安全性。
升级过程通常只需更新依赖版本并重新生成类型定义即可。如果项目中有自定义的媒体访问逻辑,可能需要根据新的权限系统进行相应调整。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
pc-uishopTNT开源商城系统使用java语言开发,基于SpringBoot架构体系构建的一套b2b2c商城,商城是满足集平台自营和多商户入驻于一体的多商户运营服务系统。包含PC 端、手机端(H5\APP\小程序),系统架构以及实现案例中应满足和未来可能出现的业务系统进行对接。Vue00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01