使用Bazel创建iOS应用

Bazel简介

Bazel是一个Google开源的构建和测试工具,Bazel支持多种语言的项目,并为多个平台构建输出。Bazel的主要特点如下:

  • 高级语言构建。Bazel使用一种抽象的、人类可读的语言在高语义级别上描述项目的构建属性。与其他工具不同的是,Bazel使用的是库、二进制文件、脚本和数据集的概念,这样可以避免编写对编译器和链接器等工具的单独调用的复杂性。
  • 又快又可靠。Bazel缓存所有以前做过的工作,并跟踪对文件内容和构建命令的更改。通过这种方式,Bazel知道什么时候需要重建,而且只需要重建。为了进一步加速构建,您可以设置项目以高度并行和增量的方式构建。
  • 多平台。Bazel可以在Linux、macOS和Windows上运行。Bazel可以为同一项目中的多个平台(包括桌面、服务器和移动平台)构建二进制文件和可部署包。
  • Bazel是可扩展的。您可以扩展Bazel来支持您所选择的语言。
  • 可伸缩性:Bazel可以处理大型项目;在Google,一个服务器软件有十万行代码是很常见的,在什么都不改的前提下重新构建这样一个项目,大概只需要200毫秒。
  • 可重复性:在BUILD文件中,每个库、测试用例和二进制文件都需要明确指定它们的依赖关系。当一个源码文件被修改时,Bazel凭这些依赖来判断哪些部分需要重新构建,以及哪些任务可以并行进行。这意味着所有构建都是增量的,并且相同构建总是产生一样的结果。

安装Bazel

以下为Mac终端命令:

如果下载速度缓慢, 请检查自己是否科学的上网了^-^

//download JDK version 8
brew cask install homebrew/cask-versions/java8

//Install the Bazel Homebrew package
brew install bazel

//test bazel
bazel version

build iOS App

空壳文件下载

首先clone一个我创建的示例App, 它是一个空壳的框架
git clone -b shell https://github.com/zhuge1127/BazelDemo
里面有一个sample文件夹, 下面的App文件夹内包含着一个最简单的空壳文件.但是并没有用Xcode的xcodeproj组织文件.

创建WORKSPACE文件

cd path/BazelDemo
touch WORKSPACE

path表示BazelDemo所在路径, 下同.

编辑WORKSPACE文件

要为App设备构建应用程序,Bazel需要从其GitHub存储库中提取最新的苹果构建规则.https://github.com/bazelbuild/rules_apple

load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository")

git_repository(
    name = "build_bazel_rules_apple",
    remote = "https://github.com/bazelbuild/rules_apple.git",
    tag = "0.6.0",
)

load(
    "@build_bazel_rules_apple//apple:repositories.bzl",
    "apple_rules_dependencies",
)

apple_rules_dependencies()

保存上面的内容到WORKSPACE.

创建BUILD文件

介绍一下package和BUILD文件的关系: Bazel把代码划分成package, 可以把package理解为一个目录,这个目录里面包含了源文件和一个描述文件,描述文件中指定了如何将源文件转换成构建的输出。这个描述文件叫做 BUILD,一个目录中存在这个BUILD文件,就可以把这个目录当作一个包。

cd path/BazelDemo/sample
touch BUILD

编辑BUILD内容

  • 要构建一个target,Bazel都需要从GitHub存储库加载构建规则。
    因此需要在BUILD开头添加以下load语句:
    load("@build_bazel_rules_apple//apple:ios.bzl", "ios_application")

  • 构建.m和.xib文件: Bazel提供了几个构建规则, 现在使用objc_library规则告诉Bazel如何源代码和Xib文件构建静态库

    为了更好地解释下面的内容, 将使用//表示注释内容, 实际使用的时候请删除注释内容.

    objc_library(
    // name 设置成当前文件夹下包含源代码或者.xib等文件的文件夹名称+Classes; 此处为App文件夹所以叫AppClasses
    name = "AppClasses",
    // 资源: 填写当前文件夹下资源的相对路径
    srcs = [
         "App/AppDelegate.m",
         "App/ViewController.m",
         "App/main.m",
    ],
    // 头文件
    hdrs = glob(["App/*.h"]),
    // xib文件
    xibs = ["App/ViewController.xib"],
    )


  • 使用ios_application规则告诉它如何构建应用程序二进制文件和.ipa包

注意这里的内容填写的值要和info.plist文件中的对应一致, 不要出现bundle_id对应不上类似的问题
    ios_application(
    name = "sample",
    bundle_id = "Bazel.App",
    families = [
        "iphone",
        "ipad",
    ],
    minimum_os_version = "9.0",
    infoplists = [":App/Info.plist"],
    visibility = ["//visibility:public"],
    deps = [":AppClasses"],
)

构建App

至此, 我们的配置已经全部完成了.可以开始构建

cd path/BazelDemo
bazel build //sample:sample

# 以下为正确构建输出内容
INFO: Build options have changed, discarding analysis cache.
INFO: Analysed target //sample:sample (31 packages loaded).
INFO: Found 1 target...
Target //sample:sample up-to-date:
  bazel-bin/sample/sample.ipa
INFO: Elapsed time: 3.220s, Critical Path: 0.03s
INFO: 0 processes.
INFO: Build completed successfully, 5 total actions

查看构建产物在 path/BazelDemo/bazel-bin/sample.
正确构建结果

使用Tulsi生成一个xcodeproj

Tulsi是生成xcodeproj的工具, 也是Bazel的一部分内容, 官方地址在 https://tulsi.bazel.build/你可以访问官网然后从github下载这个工具, 它是一个Mac App, 为了方便我已经将它放置在BazelDemo/Tulsi/Tulsi.app. 下面通过截图表示一个xcodeproj创建的过程, 其中一些配置基本没有设置. 需要根据实际项目进行对应的设置, 此处仅做为参考而已
1
2
3
4
5
6
7
通过以上步骤, 你就可以在指定的文件夹下找到类似Sample.xcodeproj的文件, 可以使用xcode打开进行编辑了.

资料介绍

DEMO资料:
demo地址: https://github.com/zhuge1127/BazelDemo.git
demo分支: shell空壳实验分支, master完成之后的全部内容

官方资料:
Bazel官网: https://www.bazel.build/
Bazel-github: https://github.com/bazelbuild
Tulsi官网: https://tulsi.bazel.build/

Bazel相关文章:
http://www.infoq.com/cn/news/2015/03/google-open-source-bazel
https://blog.csdn.net/qq_40114263/article/details/79479886
https://www.cnblogs.com/Leo_wl/p/4458115.html
https://www.zhihu.com/question/29025960
https://medium.com/windmill-engineering/bazel-is-the-worst-build-system-except-for-all-the-others-b369396a9e26
https://www.cnblogs.com/Jack47/p/build-in-the-cloud.html

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MobSF(Mobile Security Framework)是一款专门用于移动应用程序安全测试和漏洞扫描的开源框架。它支持多种移动操作系统和应用程序格式,包括Android、iOS、Windows Phone、BlackBerry等。您可以使用MobSF来测试iOS应用程序的安全性和漏洞情况。 要在Windows上使用MobSF测试iOS应用程序,您需要进行以下步骤: 1. 安装Python和Java环境。MobSF是基于Python和Java开发的,因此您需要先安装Python和Java环境。您可以从官方网站下载并安装Python和Java环境。 2. 下载并安装MobSF。您可以从MobSF的官方GitHub仓库下载最新的版本,并将其解压到您的Windows系统中。 3. 安装必要的依赖项。在MobSF的根目录中,运行以下命令来安装必要的依赖项: ``` pip install -r requirements.txt ``` 4. 启动MobSF。在MobSF的根目录中,运行以下命令来启动MobSF: ``` python manage.py runserver ``` 5. 打开Web界面。在浏览器中访问http://127.0.0.1:8000/,即可打开MobSF的Web界面。 6. 导入iOS应用程序。在MobSF的Web界面中,选择“Upload App”选项,选择要测试的iOS应用程序,并等待应用程序上传完成。 7. 进行安全测试。在MobSF的Web界面中,选择“Run Analysis”选项,等待测试完成。MobSF将会对应用程序进行安全测试,并给出测试结果和漏洞报告。 需要注意的是,MobSF只能对未加密的iOS应用程序进行测试。如果应用程序已经被加密,您需要先解密应用程序,然后再使用MobSF进行测试。此外,MobSF只能进行静态分析,无法进行动态分析,因此可能会存在一些漏洞无法被检测到的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值