STBaseProject 是一个功能强大的 iOS 基础组件库,提供了丰富的 UI 组件和工具类,帮助开发者快速构建高质量的 iOS 应用。
在 Podfile 中添加:
pod 'STBaseProject', '~> 1.3.0'然后执行:
pod install在 Xcode 中依次选择 File -> Add Package Dependencies...,输入:
https://github.com/i-stack/STBaseProject.git
或在 Package.swift 中声明:
dependencies: [
.package(url: "https://github.com/i-stack/STBaseProject.git", from: "1.3.0")
]- 下载仓库源码
- 将
Sources目录拖入工程 - 确认文件已加入目标 Target
如果只需要部分能力,建议按模块引入,减少编译与依赖负担。
STBaseProject:基础能力(含 Markdown 渲染,依赖swift-markdown、SwiftMath;使用import STBaseProject即可)STContacts:联系人权限与读取STLocation:定位与地理编码STMedia:图片处理、扫码、截图
与 CocoaPods 的差异:CocoaPods 下 STMarkdown 为可选 subspec;SPM 将 Markdown 合入 STBaseProject product,无法在不拉取 swift-markdown / SwiftMath 的前提下单独「只要核心」。
示例:
dependencies: [
.package(url: "https://github.com/i-stack/STBaseProject.git", from: "1.3.0")
],
targets: [
.target(
name: "YourApp",
dependencies: [
.product(name: "STBaseProject", package: "STBaseProject"),
.product(name: "STContacts", package: "STBaseProject"),
.product(name: "STLocation", package: "STBaseProject")
]
)
]核心 subspec 名为 STBaseProject(与 Pod 名相同)。若使用 :subspecs,列表会覆盖 default_subspecs,需要基础能力时请把 STBaseProject 一并写上,否则只会安装列出的扩展 subspec。
# 默认:仅核心(等价于 default_subspecs)
pod 'STBaseProject', '~> 1.3.0'
# 核心 + 定位(按需把 STContacts、STMedia、STMarkdown 加入数组即可)
pod 'STBaseProject', '~> 1.3.0', :subspecs => ['STBaseProject', 'STLocation']
# 核心 + 多个扩展示例
# pod 'STBaseProject', '~> 1.3.0', :subspecs => ['STBaseProject', 'STLocation', 'STContacts', 'STMedia']
# 仅安装某个扩展、不要核心(一般少见;扩展模块不依赖核心时可单独拉取)
# pod 'STBaseProject/STLocation', '~> 1.3.0'STBaseProject 已随 SPM target 与 CocoaPods subspec 提供 PrivacyInfo.xcprivacy。这些隐私清单只声明 SDK 自身访问的隐私相关 API,不会替 App 自动补齐运行时权限说明。消费方如果调用下列能力,必须在 App Target 的 Info.plist 中配置对应 usage description。
| 模块 | 能力 | 必需 Info.plist Key |
|---|---|---|
STMedia |
相机拍照、扫码 | NSCameraUsageDescription |
STMedia |
读取/选择照片 | NSPhotoLibraryUsageDescription |
STMedia |
录制含音频的视频或扩展媒体能力 | NSMicrophoneUsageDescription |
STLocation |
使用期间定位、反地理编码 | NSLocationWhenInUseUsageDescription |
STContacts |
联系人读取 | NSContactsUsageDescription |
示例:
<key>NSCameraUsageDescription</key>
<string>用于拍摄照片或扫码</string>
<key>NSPhotoLibraryUsageDescription</key>
<string>用于选择照片</string>
<key>NSLocationWhenInUseUsageDescription</key>
<string>用于获取当前位置</string>
<key>NSContactsUsageDescription</key>
<string>用于读取联系人</string>
<key>NSMicrophoneUsageDescription</key>
<string>用于录制音频</string>仓库通过 .github/check_try_question_mark.sh 与 CI 限制 try? 使用范围。边界 IO、Keychain、网络发送、证书/加密等安全敏感路径必须使用 do/catch 或 Result<T, Error>,并保留可诊断错误信息。try? 仅允许用于明确可丢弃失败的探测场景,例如 Codable 多类型解码尝试、JSON 解析探测、正则编译探测和可取消的 Task.sleep。
- 在应用启动阶段完成基础配置初始化(
STBaseConfig) - 建议将全局配置集中在
AppDelegate或SceneDelegate
- 页面优先基于
STBaseViewController组织统一导航与通用交互 - 状态和异步流程建议落在
STBaseViewModel
- UI 组件(按钮、标签、输入框、HUD)统一从
STUIKit/STDialog选择 - 复杂渲染场景(如 Markdown)优先使用
STMarkdown
建议按“启动配置 -> 页面接入 -> 网络接入 -> 展示能力 -> 安全能力 -> 上线检查”的顺序推进:
- 启动阶段:在
AppDelegate/SceneDelegate完成基础配置 - 页面层:优先使用
STBaseViewController+STBaseViewModel - 网络层:统一使用
STHTTPSession,策略放在会话与拦截器层 - 展示层:富文本场景优先使用
STMarkdown - 安全层:敏感数据统一使用
STKeychainHelper,高安全接口配合STSecurityConfig/STSSLPinningConfig
常用模块入口(点击可直接跳转):
- 基础页面与状态:STBaseViewController / STBaseViewModel
- 全局配置与外观:STConfig
- 网络能力:STNetwork / 网络专题文档
- 安全能力:STSecurity / 安全专题文档
- 国际化能力:STLocalizable / 本地化专题文档
- 媒体能力:STMedia
- UIKit 组件:STUIKit
- 通用工具:STTools
- Docs/STHTTPSession.md:网络会话、拦截器、流式响应、SSL Pinning
- Docs/STSecurity.md:加解密、Keychain、安全检测与策略
- Docs/STLocalizable.md:本地化读取、语言切换、通知刷新
仅列模块能力与入口,不在 README 展开具体实现细节:
- 动画与视觉:
STAnimation - 页面基类与状态:
STBaseViewController、STBaseViewModel - 全局配置:
STConfig - 网络:
STNetwork(详见 Docs/STHTTPSession.md) - 安全:
STSecurity(详见 Docs/STSecurity.md) - 国际化:
STLocalizable(详见 Docs/STLocalizable.md) - 媒体能力:
STMedia - UIKit 组件:
STUIKit - 通用工具:
STTools
- 自定义导航栏 - 支持多种样式和自定义配置
- 自定义按钮 - 支持图片文字多种布局方式
- HUD 提示 - 丰富的提示组件,支持多种类型
- 标签栏 - 自定义标签栏组件
- 渐变标签 - 支持渐变效果的标签组件
- 颜色工具 - 支持十六进制、RGB、暗黑模式等
- 字符串工具 - 丰富的字符串处理方法
- 日期工具 - 日期格式化和计算
- 网络工具 - HTTP 请求、网络监控
- 文件管理 - 文件操作和存储
- 设备信息 - 获取设备相关信息
- 加密工具 - 数据加密和解密
- Keychain 管理 - 安全存储敏感信息
- 网络安全 - SSL 证书锁定、安全检测
- 本地化管理 - 多语言支持
- 动态语言切换 - 运行时语言切换
- 屏幕适配 - 支持不同屏幕尺寸
- 安全区域适配 - 支持刘海屏等特殊设备
- 字体适配 - 动态字体大小调整
README 仅保留能力概览与模块入口。
具体实现、参数说明与完整示例请查看对应专题文档:
- 网络请求:
Docs/STHTTPSession.md - 安全能力:
Docs/STSecurity.md - 本地化能力:
Docs/STLocalizable.md
- iOS 16.0+
- Xcode 12.0+
- Swift 5.0+
仓库内提供自动发布脚本:
./scripts/release_pod.sh 1.1.6推荐(自动创建并推送同名 tag):
./scripts/release_pod.sh 1.1.6 --tag --push-tag脚本会按顺序执行:
- 更新
STBaseProject.podspec中的s.version - 检查工作区是否干净(可用
--allow-dirty跳过) - 检查或自动创建本地 tag(
--tag) - 检查或自动推送远端 tag(
--push-tag) - 校验 tag 是否指向当前
HEAD - 执行
pod spec lint STBaseProject.podspec --allow-warnings(可用--skip-lint跳过) - 执行
pod trunk push STBaseProject.podspec --allow-warnings
本项目采用 MIT 许可证。详情请参阅 LICENSE 文件。
欢迎提交 Issue 和 Pull Request 来帮助改进这个项目。
如有问题或建议,请通过以下方式联系:
- 提交 Issue: GitHub Issues
- 邮箱: songshoubing7664@163.com
⭐ 如果这个项目对你有帮助,请给它一个星标!