Salesforce学习之路(八)一次拉取多个文件或全部文件至本地
在开发中,经常会遇到本地工程错乱或者误操作导致本地本地项目被删除,此时利用SFDX: Retrieve Source from Org只会拉取新建并且名称相同的组件,若通过创建一个个文件,然后再拉取的方式,不免显得过于笨拙。
本人便踩过这个坑,这里分享一下个人的解决方案。
在我看来,从Org中一次拉取多个组件文件或者全部组件文件,有三种解决方案,下面一一叙述:
1. 利用manifest新建工程
1)打开Vs Code,进入命令行模式(shift+cmmand+p/F1), SFDX: Create Project with Manifest

直接创建标准模式即可,当然可根据自身实际选择。这里直接创建工程:sample
在sample/manifest目录下,可发现名为package.xml的文件,标准内容如下:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
<types>
<members>*</members>
<name>ApexClass</name>
</types>
<types>
<members>*</members>
<name>ApexComponent</name>
</types>
<types>
<members>*</members>
<name>ApexPage</name>
</types>
<types>
<members>*</members>
<name>ApexTestSuite</name>
</types>
<types>
<members>*</members>
<name>ApexTrigger</name>
</types>
<types>
<members>*</members>
<name>AuraDefinitionBundle</name>
</types>
<types>
<members>*</members>
<name>LightningComponentBundle</name>
</types>
<types>
<members>*</members>
<name>StaticResource</name>
</types>
<version>47.0</version>
</Package>
从packge.xml文件中可以看出,主要分为一下标准类型:
- ApexClass: Apex类文件
- ApexComponent: Apex组件
- ApexPage: Visualforce组件
- ApexTestSuite: Apex测试类
- ApexTrigger: Apex的触发问价
- AuraDefinitionBundle: Apex的自定义Aura组件
- LightningCompentBundle: Apex的自定义LWC组件
- StaticResource: 项目中的静态文件
2)认证Org并设置为默认Org
# 认证Org
SFDX: Authorize an Org
# 设置默认Org
SFDX: Set a Default Org
查看Org列表
[kaiwu3@localhost:~/sample]$sfdx force:org:list
=== Orgs
ALIAS USERNAME ORG ID CONNECTED STATUS
─── ──────────── ──────────────────────── ────────────────── ────────────────
(U) k_Reset kaiwu3@*****.com 00D2v000001Xk5DEAS Connected No active scratch orgs found. Specify --all to see all scratch orgs
3) 利用pacakge.xml拉取文件
右击sample/manifest/pacakge.xml,选择SFDX: Retrieve Source in Manifest from Org
::16.740 sfdx force:source:retrieve --manifest /Users/kaiwu3/Works/Code/sfdcTmp/sample/manifest/package.xml
=== Retrieved Source
FULL NAME TYPE PROJECT PATH
──────────────────────────────────────────────────────────────────────── ──────────────────────── ────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────
heatmapmock StaticResource force-app/main/default/staticresources/heatmapmock.resource-meta.xml
heatmapmock StaticResource force-app/main/default/staticresources/heatmapmock.js
heatmap StaticResource force-app/main/default/staticresources/heatmap.resource-meta.xml
heatmap StaticResource force-app/main/default/staticresources/heatmap.js
......
此时,你会发现package.xml中定义的标准组件,都已经成功拉到本地工程。
2. 利用Package Manage方式自由拉取文件
1) Org中创建Package包
上述manifest方式拉取的文件,仅限于创建工程是自动生成的package.xml中定义的几种类型,有时并不能满足我们的需求(比如Org迁移或者备份,此时不仅需要上述的组件文件,还需要保留在Org中创建的Object等信息)。此时,你会发现Package Manager可以满足你的一切需求。
在Org中,【Setup】-->【Package Manager】-->【new】

点击Add按钮,添加所需组件。

返回Package Maneger界面可见Package列表存在sample的包。
2)本地工程下载smaple包
[kaiwu3@localhost:~/Works/Code/sfdcTmp/sample]$mkdir pacakge
# 下载包命令:sfdx force:mdapi:retrieve -s -r {{pathToCreatePackageFile}} -u {{sandboxUsername}} -p {{packageName}}
[kaiwu3@localhost:~/Works/Code/sfdcTmp/sample]$sfdx force:mdapi:retrieve -s -r package/ -u kaiwu3@*****.com -p sample
Retrieving source... === Status
Status: InProgress
jobid: 09S2v000006nL64EAE === Result
Status: Succeeded
jobid: 09S2v000006nL64EAE # 产生的zip包路径
Wrote retrieve zip to /Users/kaiwu3/Works/Code/sfdcTmp/sample/package/unpackaged.zip.
3)转换package为工程文件
# 解压下载包(下载包一般命名为:unpacakge.zip)
[kaiwu3@localhost:~/sfdcTmp/sample/package]$unzip unpackaged.zip
Archive: unpackaged.zip
inflating: staticresources/leaflet1.resource
inflating: staticresources/leaflet1.resource-meta.xml
inflating: aura/SmartLocks/SmartLocks.css
inflating: aura/SmartLocks/SmartLocksHelper.js
inflating: aura/SmartLocks/SmartLocksController.js
inflating: aura/SmartHome/SmartHome.css
inflating: aura/SmartHome/SmartHomeController.js
......
inflating: package.xml # 将解压文件转换匹配到对应工程中
# 转换命令:sfdx force:mdapi:convert -r {pacakge.xml所在目录}
[kaiwu3@localhost:~/Works/Code/sfdcTmp/sample]$sfdx force:mdapi:convert -r package/
=== Converted Source
STATE FULL NAME TYPE PROJECT PATH
───── ─────────────────────────────────────────────────────── ───────────────── ────────────────────────────────────────────────────────────────────────────────────────────────────────────
Add CCTG CustomApplication force-app/main/default/applications/CCTG.app-meta.xml
Add Company__c-Company Layout Layout force-app/main/default/layouts/Company__c-Company Layout.layout-meta.xml
Add Employee__c-Employee Layout Layout force-app/main/default/layouts/Employee__c-Employee Layout.layout-meta.xml
......
细心的同学应该发现了,package manager方式中也存在package.xml文件,区别在哪呢?
<?xml version="1.0" encoding="UTF-8"?>
<Package xmlns="http://soap.sforce.com/2006/04/metadata">
<fullName>sample</fullName>
<!--类型:ApexClass,成员:sample中自定义添加的-->
<types>
<members>BotController</members>
...
<name>ApexClass</name>
</types>
<!--类型:触发器,成员:sample包中自定义选择-->
<types>
<members>PairContactToAccount</members>
<members>PushNotificationTrigger</members>
...
<name>ApexTrigger</name>
</types>
<!--类型:Aura组件,成员:sample包中自定义选择-->
<types>
<members>Map</members>
<members>MapCard</members>
...
<name>AuraDefinitionBundle</name>
</types>
<!--类型:自定义应用,成员:sample包中自定义选择-->
<types>
<members>CCTG</members>
...
<name>CustomApplication</name>
</types>
<!--类型:自定义字段,成员:sample包中自定义选择-->
<types>
<members>Command__c.Active__c</members>
...
<name>CustomField</name>
</types>
<!--类型:自定义对象,成员:sample包中自定义选择-->
<types>
<members>Command__c</members>
...
<name>CustomObject</name>
</types>
<!--类型:自定义导航,成员:sample包中自定义选择-->
<types>
<members>Account__c</members>
...
<name>CustomTab</name>
</types>
<!--类型:Layout,成员:sample包中自定义选择-->
<types>
<members>Bot_Command__c-Bot Action Layout</members>
...
<name>Layout</name>
</types>
...
<!--类型:RecordType,成员:sample包中自定义选择-->
<types>
<members>Account__c.DemoChart</members>
...
<name>RecordType</name>
</types>
<!--类型:静态文件, 成员:sample包中自定义选择-->
<types>
<members>leaflet1</members>
<name>StaticResource</name>
</types>
<types>
<members>Account__c.Open_Report</members>
<name>WebLink</name>
</types>
<version>47.0</version>
</Package>
而在manifest中,类型仅有上述几种,并且成员为所有。
3. 利用Scratch Org全部拉取
1)创建Scratch Org
# 创建scratch Org
# 注意,如果没有权限,需进入Org,enable Dev Hub
# 这里使设置有效期为3天
[kaiwu3@localhost:~/smaple/config]$sfdx force:org:create -f project-scratch-def.json -d
Successfully created scratch org: 00D9D0000000St7UAE, username: test-l5cwqegykwud@example.comsfdx force:org:create -f project-scratch-def.json -d # 将scratch Org设置为默认Org
[kaiwu3@localhost:~/sample/config]$sfdx force:config:set defaultusername=test-l5cwqegykwud@example.com
=== Set Config
NAME VALUE
─────────────── ─────────────────────────────
defaultusername test-l5cwqegykwud@example.com # 查看Org列表
[kaiwu3@localhost:~/Works/Code/test/config]$sfdx force:org:list
=== Orgs
ALIAS USERNAME ORG ID CONNECTED STATUS
─── ───── ──────────────── ────────────────── ────────────────
(D) k_Reset kaiwu3@*****.com 00D2v000001Xk5DEAS Connected ALIAS SCRATCH ORG NAME USERNAME ORG ID EXPIRATION DATE
─── ───── ──────────────── ───────────────────────────── ────────────────── ───────────────
(U) kaiwu3 Company test-l5cwqegykwud@example.com 00D9D0000000St7UAE --
2)全量拉取数据
# 权量拉取命令:sfdx force:source:pull -u {username}
[kaiwu3@localhost:~/sample]$sfdx force:source:pull -u test-l5cwqegykwud@example.com
=== Pulled Source
...
在切换Org即可。
作者:吴家二少
博客地址:https://www.cnblogs.com/cloudman-open/
本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。
Salesforce学习之路(八)一次拉取多个文件或全部文件至本地的更多相关文章
- Salesforce学习之路(十三)Aura案例实战分析
Aura相关知识整合: Salesforce学习之路(十)Aura组件工作原理 Salesforce学习之路(十一)Aura组件属性<aura:attribute /> Salesforc ...
- Jenkins拉取Git远程仓库中指定目录至本地指定目录
Jenkins拉取源码是非常实用的操作,比如每天在跑自动化测试前,拉取Git远程仓库中最新的脚本至本地.那么,Jenkins如何拉取Git远程仓库中指定目录至本地指定目录呢?下面来看看具体的设置方法. ...
- Salesforce学习之路(三)利用VS Code结合Git开发Salesforce
在前面说了一些有关Admin的知识,但实际开发运用中,仅凭Admin的配置很难满足项目的定制化需求,因此基于CRM的二次开发则应运而生. 由于国内资料相对较少,所以很多入门新手无处下手,那这里就简单介 ...
- Salesforce学习之路-developer篇(一)利用VS Code结合Git开发Salesforce
Part 1: 从Git中克隆代码到本地 git clone https://github.com/git/git Part 2: 在VS Code中安装Salesforce和Git插件 在VS Co ...
- Salesforce学习之路-developer篇(二)利用Jenkins和Bitbucket实现Salesforce的CI/CD功能
上文提到,基于CRM的二次开发是必不可少的,但是在实际项目中CI/CD是不可忽略的一个重要部分,与传统的Java,Python项目不同,如果对Salesforce进行持续集成和持续部署呢? 结合找到的 ...
- Salesforce学习之路(四)利用Jenkins和Git实现Salesforce的CI/CD功能
上文提到,基于CRM的二次开发是必不可少的,但是在实际项目中CI/CD是不可忽略的一个重要部分,与传统的Java,Python项目不同,如果对Salesforce进行持续集成和持续部署呢? 结合找到的 ...
- git使用命令行拉取远程代码仓库中的分支至本地
1.本地创建文件夹用于存放拉取的代码 2.执行git init初始化文件夹 3.与远程代码仓库建立连接 git remote add origin git@github.com.wuylin/noth ...
- Salesforce学习之路-developer篇(五)一文读懂Aura原理及实战案例分析
1. 什么是Lightning Component框架? Lightning Component框架是一个UI框架,用于为移动和台式设备开发Web应用程序.这是一个单页面Web应用框架,用于为Ligh ...
- Salesforce学习之路-admin篇
Salesforce是一款非常强大的CRM(Customer Relationship Management)系统,国外企业使用十分频繁,而国内目前仅有几家在使用(当然,国内外企使用的依旧较多),因此 ...
随机推荐
- python TKinter的主窗口运行程序完毕后,怎么让其自动关闭
如题: 在pycharm 调试Tkinter程序的时候,关闭右上角的X 实际上并未退出进程,长期以往 再大的内存也会被耗尽. 一般就是下面的代码: """ from tk ...
- 拎壶带你冲----教育类mysql用户表设计参考
说起用户表,大概是每个应用/网站立项动工(码农们)考虑的第一件事情.用户表结构的设计,算是整个后台架构的基石.如果基石不稳,待到后面需求跟进了发现不能应付,回过头来反复修改用户表,要大大小小作改动的地 ...
- 2018-2-13-win10-UWP-MessageDialog-和-ContentDialog
原文:2018-2-13-win10-UWP-MessageDialog-和-ContentDialog title author date CreateTime categories win10 U ...
- Flask笔记:上下文
线程隔离Thread Local: 如果一个对象具有线程隔离的特性,就可以称之为“Thread Local”,线程隔离是指该对象在不同的线程中都是独立的,在一个线程中对该对象的操作不会影响另一个线程对 ...
- crm-1
1.crm 客户关系管理系统 :1.业务逻辑部分 2.权限插件 2.forms组件之modelform modelform就是model+form ,form根据model的字段生成标签 ,校验信息 ...
- Python之dict(或对象)与json之间转化
在Python语言中,json数据与dict字典以及对象之间的转化,是必不可少的操作. 在Python中自带json库.通过import json导入. 在json模块有2个方法, loads():将 ...
- msf中的情报搜集
msf中的情报搜集 被动的信息搜集 使用被动的.间接的信息搜索技巧,可以在目标不察觉的情况下挖掘目标的相关信息. 公开渠道情报搜集 对公开的和已知的信息进行检索筛选,获取到目标的情报集合,一系列的 ...
- 微信小程序访问webservice(wsdl)+ axis2发布服务端(Java)
0.主要思路:使用axis2发布webservice服务端,微信小程序作为客户端访问.步骤如下: 1.服务端: 首先微信小程序仅支持访问https的url,且必须是已备案域名.因此前期的服务器端工作需 ...
- CODING 2.0:如何通过设计给品牌创造价值?
升级背景 伴随着 CODING 理念的全面升级,CODING 正构建起覆盖构想到交付的全覆盖工具链,用户注册即可实践敏捷开发与 DevOps,提升软件交付质量与速度. 一直以来,CODING 作为软件 ...
- 实时数据推送webSocket
实时数据推送 在Web或移动项目中,服务器向客户端实时推送消息是一种常见的业务需求. 实现方式 Polling:轮询(俗称“拉”),即定期重新请求数据. Long-Polling:长轮询,是 Poll ...