ArcGIS API For Python中的GIS
对象提供了对于几类用户的多种验证方案:
- 匿名用户
- 内置用户
- Enterprise标识存储
- Web-tier authentication with LDAP
- Portal-tier authentication with Active Directory
- Portal-tier authentication with LDAP
- Web-tier authentication secured with PKI
- Web-tier authentication secured with IWA
- 基于OAuth 2.0的用户身份验证
- 通过ArcGIS Pro连接
GIS
类支持通过向ArcGIS Online
或者ArcGIS Enterprise
实例提供URL或者用户凭据的方式构建GIS
对象。用户凭据内容可包括一对用户名和用户密码,或者在使用PKI的情况下,使用一个密钥文件/文件证书对作为用户凭据内容。
如果不提供URL地址,默认使用ArcGIS Online;如果不提供用户凭据,则默认以匿名用户访问。另外,脚本可通过ArcGIS Pro登录Portal,并且会选择使用当前激活的Portal。
匿名用户访问
作为匿名用户访问此API,你可完成的任务比较少,可以查询或者查看公开分享的地图和图层,但是,向创建或者修改内容、执行分析任务等情况是没有权限的。
- 作为匿名用户连接ArcGIS Online
print("ArcGIS Online as anonymous user")
gis = GIS()
print("Logged in as anonymous user to " + gis.properties.portalName)
- 作为匿名用户连接ArcGIS Enterprise
如果ArcGIS Enterprise允许匿名用户访问,只传入Enterprise的URL地址,不传入用户名和密码,即可以匿名用户的方式连接Enterprise。
值得注意的一点,如果Enterprise配置了IWA认证,并且在Windows系统中登录Enterprise,可能连接时会自动登录。
print("ArcGIS Enterprise as anonymous user")
gis = GIS("https://singlega.jiaoxn.local/arcgis")
print("Logged in as anonymous user to " + gis.properties.portalName)
内置用户
无论ArcGIS Online还是ArcGIS Enterprise都使用内置的身份存储进行了预配置,所以可以很轻松的创建用户和创建组。当使用这种情况登录时,需提供用户名和密码。
- 作为内置用户连接ArcGIS Online
print("ArcGIS Online Org account")
gis = GIS("https://www.arcgis.com", "arcgis_python", "P@ssword123")
print("Logged in as " + str(gis.properties.user.username))
- 作为内置用户连接Enterprise
print("Portal for ArcGIS as a built in user")
gis = GIS("https://portalname.domain.com/webadapter_name", "sharinguser", "password")
print("Logged in as: " + gis.properties.user.username)
Enterprise 标识存储
ArcGIS Online和ArcGIS Enterprise的设计允许您通过Enterprise账号和群组来控制对ArcGIS组织的访问。
- Web-tier authentication with LDAP
print("\n\nBasic Authentication with LDAP")
ldapbasic = GIS("https://portalname.domain.com/webadapter_name", "amy", "password")
print("Logged in as: " + ldapbasic.properties.user.username)
- Portal-tier authentication with Active Directory
当使用来自当前激活目录的Enterprise用户连接时,以domain\\username
的方式指定用户名。
print("\n\nPortal-tier Authentication with LDAP - enterprise user")
gisldap = GIS("https://portalname.domain.com/webadapter_name", "AVWORLD\\Publisher", "password")
print("Logged in as: " + gisldap.properties.user.username)
- Portal-tier authentication with LDAP
当使用来自LDAP的Enterprise用户账号连接时,向平常一样指定用户名和密码即可。
print("\n\nPortal-tier Authentication with LDAP - builtin user")
gisldap = GIS("https://portalname.domain.com/webadapter_name", "sharing1", "password")
print("Logged in as: " + gisldap.properties.user.username)
- Web-tier authentication secured with PKI
使用PKI连接时,有两种方式:一种是使用key_file
和cert_file
,另一种是使用pkcs12
格式化的证书文件和密码
# 使用PEM编码的证书和密钥文件
print("\n\nPKI with key and cert files")
gis = GIS("https://portalname.domain.com/webcontext",
key_file="C:\\path\\to\\key.pem",
cert_file="C:\\path\\to\\cert.pem")
print("Logged in as: " + gis.properties.user.username)
# 使用PKCS12格式化的证书文件和密码
print("\n\nPKI with PFX file and password")
gis = GIS("https://portalname.domain.com/webcontext",
cert_file="C:\\path\\to\\mycert.pfx",
password="secret.password")
print("Logged in as: " + gis.properties.user.username)
- Web-tier authentication secured with IWA
基于OAuth 2.0的用户身份验证
使用此方式连接时,需要一个client.id
。
获取一个client id
- 登录ArcGIS Online或者ArcGIS Enterprise
- 选择
Content
- 点击
+ Add Item
,An Application
按钮 - 添加一个应用:类型为
Application
,标题为Python
,标签为Python
- 在刚刚创建的应用的详细页面,导航至
Settings
- 点击页面底部的
Registered Info
- 点击后,当前页面会显示一个应用ID,这个就是连接GIS对象时需要的client.id。
此方式连接时,如果不提供用户名和密码,将会显示交互式的登录页面,登录后将会获得一个代码,可以粘贴为该代码已完成登录过程;提供用户名和密码,可屏蔽此过程。
gis = GIS("https://pythonapi.playground.esri.com/portal", username="arcgis_python", password="amazing_arcgis_123",
client_id='f8cRxbP3NO8bf9ag')
print("Successfully logged in as: " + gis.properties.user.username)
通过ArcGIS Pro连接
基于pro
的授权模式,Python代码脚本可以在不输入用户名和密码的情况下,创建代表当前激活的Portal的GIS
类实例。
值得注意的是,如果使用Named User license
这样的授权方式授权Pro,如果在登录时没有勾选Signe me in automatically
或者没有设置Pro可离线使用,则在使用该模式连接时,需确保ArcGIS Pro在运行该代码的机器上已安装并且Pro已运行。如果勾选Signe me in automatically
,默认情况下,在Portal许可到期之前,ArcGIS Pro可以连续关闭2周。
print("\n\nActive Portal in ArcGIS Pro")
gis = GIS("pro")
保护密码
如果向其他用户分享你的Notebook代码或者在你的代码存储在公共位置时,有时会不想直接暴露密码在代码中,可以不输入代码来解决这个问题。当Python API运行代码时,会调用内置模块getpass
,提示用户输入代码,如下代码所示。
gis = GIS("https://pythonapi.playground.esri.com/portal", username='arcgis_python')
print("Successfully logged in as: " + gis.properties.user.username)
# Output
Enter password: ········
Successfully logged in as: arcgis_python
当提示输入密码时,代码将会暂停运行,直到用户输入正确的代码。输入的代码会用*号掩盖。
在需要输入密码的连接模式中,均可使用这种模式保护你的密码。如果在单独的Python脚本中使用这种方式时,该脚本需要以交互式的方式运行,因为在脚本运行时,需要用户提供密码。
本地保存资格证书
如果经常连接一个GIS
实例,并且考虑将连接证书保存到本地,那么GIS
实例化时传入profile
参数可解决。
通过向GIS
类传递授权凭据,并指定一个证书名称,即可创建持久化的配置文件。这个配置文件在用户主目录下,将除密码以外的授权凭据存储在一个未加密的名为.arcgisprofile
配置文件中。资格证书会通过keyring
模块以安全的方式将密码存放在操作系统的密码管理器中,如果是Linux系统可能需要安装额外的软件来保证适当的安全性。
保存配置文件后,可通过profile
参数传递证书文件。多个证书文件可以被平行的创建和调用。
# 创建
playground_gis = GIS(url="https://pythonapi.playground.esri.com/portal", username='arcgis_python', password='amazing_arcgis_123',
profile='python_playground_prof')
agol_gis = GIS(url="https://arcgis.com/", username='arcgis_python', password="P@ssword123",
profile="AGOL_prof")
print("profile defined for {}".format(playground_gis))
print("profile defined for {}".format(agol_gis))
# 使用
def print_profile_info(gis):
print("Successfully logged into '{}' via the '{}' user".format(
gis.properties.portalHostname,
gis.properties.user.username))
playground_gis = GIS(profile='python_playground_prof')
print_profile_info(playground_gis)
agol_gis = GIS(profile="AGOL_prof")
print_profile_info(agol_gis)
持久配置文件详细内容
持久配置文件将在未加密的.arcgisprofile
文件中存储以下GIS
参数的任意组合:
- url
- username
- key_file
- cert_file
- cliend_id
密码将会通过keyring
模块以安全的方式的存储,也就是说,在运行代码时,密码将会从操作系统的密码存储管理器中检索。
Windows
Window系统中,密码将会存放在Windows凭据管理器。其查看方式为:
Start > Control Panel > User Accounts > Credential Manager > Windows Credentials > Generic Credentials
Mac
在Mac系统中,密码将会存放在Keychain Access,查看方式为:
Applications > Utilities > Keychain Access > Passwords > "arcgis_python_api_profile_passwords"
Linux
在Linux上,可能需要安装并配置其他软件,以安全地存储具有持久配置文件的密码。其配置过程可通过另外一篇博客来了解。