Skip to content

i-stack/STBaseProject

Repository files navigation

STBaseProject

CocoaPods License Platform Swift CI SPM iOS Xcode Stars

STBaseProject 是一个功能强大的 iOS 基础组件库,提供了丰富的 UI 组件和工具类,帮助开发者快速构建高质量的 iOS 应用。

📋 目录

🚀 安装方式

CocoaPods

Podfile 中添加:

pod 'STBaseProject', '~> 1.3.0'

然后执行:

pod install

Swift Package Manager

在 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")
]

手动集成

  1. 下载仓库源码
  2. Sources 目录拖入工程
  3. 确认文件已加入目标 Target

🧩 按需加载

如果只需要部分能力,建议按模块引入,减少编译与依赖负担。

Swift Package Manager(按 Product 选择)

  • STBaseProject:基础能力(含 Markdown 渲染,依赖 swift-markdownSwiftMath;使用 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")
        ]
    )
]

CocoaPods(按 Subspec 选择)

核心 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/catchResult<T, Error>,并保留可诊断错误信息。try? 仅允许用于明确可丢弃失败的探测场景,例如 Codable 多类型解码尝试、JSON 解析探测、正则编译探测和可取消的 Task.sleep

⚡ 快速开始

1) 启动配置

  • 在应用启动阶段完成基础配置初始化(STBaseConfig
  • 建议将全局配置集中在 AppDelegateSceneDelegate

2) 页面基类接入

  • 页面优先基于 STBaseViewController 组织统一导航与通用交互
  • 状态和异步流程建议落在 STBaseViewModel

3) 常用组件示例

  • UI 组件(按钮、标签、输入框、HUD)统一从 STUIKit / STDialog 选择
  • 复杂渲染场景(如 Markdown)优先使用 STMarkdown

📚 文档导航

业务接入概览

建议按“启动配置 -> 页面接入 -> 网络接入 -> 展示能力 -> 安全能力 -> 上线检查”的顺序推进:

  • 启动阶段:在 AppDelegate/SceneDelegate 完成基础配置
  • 页面层:优先使用 STBaseViewController + STBaseViewModel
  • 网络层:统一使用 STHTTPSession,策略放在会话与拦截器层
  • 展示层:富文本场景优先使用 STMarkdown
  • 安全层:敏感数据统一使用 STKeychainHelper,高安全接口配合 STSecurityConfig/STSSLPinningConfig

模块使用概览

常用模块入口(点击可直接跳转):

专题文档

📁 目录介绍

仅列模块能力与入口,不在 README 展开具体实现细节:

  • 动画与视觉:STAnimation
  • 页面基类与状态:STBaseViewControllerSTBaseViewModel
  • 全局配置:STConfig
  • 网络:STNetwork(详见 Docs/STHTTPSession.md
  • 安全:STSecurity(详见 Docs/STSecurity.md
  • 国际化:STLocalizable(详见 Docs/STLocalizable.md
  • 媒体能力:STMedia
  • UIKit 组件:STUIKit
  • 通用工具:STTools

🎯 主要功能

🎨 UI 组件

  • 自定义导航栏 - 支持多种样式和自定义配置
  • 自定义按钮 - 支持图片文字多种布局方式
  • HUD 提示 - 丰富的提示组件,支持多种类型
  • 标签栏 - 自定义标签栏组件
  • 渐变标签 - 支持渐变效果的标签组件

🛠 工具类

  • 颜色工具 - 支持十六进制、RGB、暗黑模式等
  • 字符串工具 - 丰富的字符串处理方法
  • 日期工具 - 日期格式化和计算
  • 网络工具 - HTTP 请求、网络监控
  • 文件管理 - 文件操作和存储
  • 设备信息 - 获取设备相关信息

🔒 安全功能

  • 加密工具 - 数据加密和解密
  • Keychain 管理 - 安全存储敏感信息
  • 网络安全 - SSL 证书锁定、安全检测

🌐 国际化支持

  • 本地化管理 - 多语言支持
  • 动态语言切换 - 运行时语言切换

📱 设备适配

  • 屏幕适配 - 支持不同屏幕尺寸
  • 安全区域适配 - 支持刘海屏等特殊设备
  • 字体适配 - 动态字体大小调整

💡 使用说明

README 仅保留能力概览与模块入口。

具体实现、参数说明与完整示例请查看对应专题文档:

  • 网络请求:Docs/STHTTPSession.md
  • 安全能力:Docs/STSecurity.md
  • 本地化能力:Docs/STLocalizable.md

📋 系统要求

  • iOS 16.0+
  • Xcode 12.0+
  • Swift 5.0+

🚀 Pod 发布脚本

仓库内提供自动发布脚本:

./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 来帮助改进这个项目。

📞 联系方式

如有问题或建议,请通过以下方式联系:


⭐ 如果这个项目对你有帮助,请给它一个星标!

About

Modular iOS 16+ toolkit: MVVM page layer, HTTP/WebSocket networking, SSL pinning, Keychain/crypto, UIKit, Markdown, localization; optional Contacts/Location/Media. SPM & CocoaPods.

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors