Xamarin.Android VSTS 持续集成
这些天做了一个基于 VSTS 的 Xamarin.Android的持续集成,这里分享下
Build Agent 环境需求
DotNetFramework
msbuild
visualstudio
AndroidSDK
JDK
Xamarin.Android
Build的部分分为以下步骤:
1. 还原NuGet包
a. 这步之所以存在,原因为我使用了Xamarin.Android进行编译,而没有直接对解决方案使用MSBUILD进行编译,所以需要单独还原一下NuGet包
b. 解决方案路径填写 **\*.sln 即可
2. 替换版本号
a. Xamarin.Android的版本号与AndroidManifest.xml中的versionName与versionCode有关,我在这里使用Powershell将版本号替换成了新的
b. 此脚本传递参数为当前源代码路径,$(Build.SourcesDirectory)
c. 脚本代码:
param(
[string]$path ) if([String]::IsNullOrEmpty($path)){ $path= $($MyInvocation.MyCommand.Definition.Replace("build\changeVersion.ps1" ,"")) } write $path $pattern='android:versionName="[^"]+"' $version=[String]::Format('android:versionName="{0}.{1}"',[DateTime]::Now.Year-2013,[DateTime]::Now.ToString("M.d.H")) $filePath = [System.IO.Path]::Combine($path,"source\AndroidAppProject\Properties") write $filePath ls $filePath *.xml | %{sc -Path $_.FullName -Value $($(gc $_.FullName) -replace $pattern,$version) }
3. 编译Android程序
a. 使用TSTS自带的Xamarin.Android进行编译
b. 输出目录我设定在了$(Agent.BuildDirectory)\bin$(BuildConfiguration)
c. 配置使用用户入队时的配置$(BuildConfiguration)
4. 获取编译Andorid的AndroidManifest数据,例如 packagename/label/versionName等
a. 这个是我自己写的一个VSTS扩展,用于获取一些应用的基本信息,并存储在对应的变量中,以备后续步骤使用(生成ReleaseNote时)
5. 对编译好的Android apk进行签名
a. 使用 VSTS自带的Android签名 功能进行签名
b. 需要勾选 为APK签名,并填入Keystore密码、Keystore别名,密钥密码
c. Jarsigner 参数: -verbose -sigalg MD5withRSA -digestalg SHA1
d. 勾选Zipalign
6. 删除多余的文件
a. 因为编译时 DLL 也会被复制过来,所以需要删除下多余的文件,只留APK
7. 生成 ReleaseNotes
a. 使用的是 rfennell 的生成ReleaseNote的VSTS扩展 https://github.com/rfennell/vNextBuild/tree/master/Extensions/GenerateReleaseNotes
b. 我这里将 ReleaseNotes,生成了一个 MarkDown :ReleaseNotes.md,以备发布时使用
8. 生成预发布脚本
a. 我提前写了一个预发布Powershell脚本用于将APK发布到Bugly,主要是调用 CURL,这里就不详述了
这样,就可以进行 手动或自动集成的操作
小技巧:
关于敏感数据,一些敏感数据,比如签名时的密码、其实可以在 生成定义 的 变量 中进行定义,并设置为加密变量 ,这样在传输或编辑时,都将无法查看此变量
引用:
Vsts build 中可以使用的变量:
https://www.visualstudio.com/zh-cn/docs/build/define/variables
Bugly api文档
https://bugly.qq.com/docs/user-guide/api-beta/?v=20160824161206
获取 Xamarin.Android AndroidManifest 信息
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异