文章目录
- 0.引言
- 1.准备ArcGIS相关工具
- 2.创建含有ArcSDE地理数据库的MXD文件
- 3.注册ArcSDE地理数据库
- [4.发布数据到Arcgis Server](#4.发布数据到Arcgis Server)
- [5.ArcgisForJS访问ArcGIS Server数据](#5.ArcgisForJS访问ArcGIS Server数据)
0.引言
ArcGIS API for JavaScript 是一个用于在Web和移动应用程序中创建交互式地图和地理空间分析应用的库。它支持从 ArcGIS Server 加载数据。本文先介绍创建地理数据,然后发布为ArcGIS Server数据,最后利用ArcGIS API for JavaScript 加载ArcGIS Server数据。
1.准备ArcGIS相关工具
安装ArcGIS_Desktop,参考:ArcGIS10.2保姆式安装教程,超详细;附安装包
安装ArcGIS_Server,参考:ArcGIS server 10.2安装教程详细版
安装ArcGIS_SDE,参考:arcgis10.2 SDE (sqlserver)安装及使用
安装完成相关工具后,添加数据库连接,并添加ArcGIS Server,如下:
data:image/s3,"s3://crabby-images/11896/11896f2492070a4af822496b892103675e1e0690" alt=""
2.创建含有ArcSDE地理数据库的MXD文件
(1)创建MXD文件并保存
data:image/s3,"s3://crabby-images/9e790/9e7900e2d3da41bab752dba5eee10306d4a01eec" alt=""
data:image/s3,"s3://crabby-images/71b88/71b88dfd9ace28f96d290b75dd107c8e5f42f8fd" alt=""
(2)添加要素集
data:image/s3,"s3://crabby-images/5e769/5e769473a3439f4f05ac2c948572b97f1b69cf34" alt=""
填写要素集名称。
data:image/s3,"s3://crabby-images/7162f/7162f07920bcc67a2579a47d618f651b2f376315" alt=""
设置地理坐标系。
data:image/s3,"s3://crabby-images/54fc1/54fc15f5915ba03869ad16c557e715001eb1b07b" alt=""
设置垂直坐标系。
data:image/s3,"s3://crabby-images/f12fd/f12fd8e3bbed5d5be227818174a8d904a4ba11de" alt=""
data:image/s3,"s3://crabby-images/005ed/005eda7633e1c137452e47dc786967510f9aca6e" alt=""
data:image/s3,"s3://crabby-images/84678/84678571b346e015c0c92786313d676219551154" alt=""
(3)添加一个线要素
data:image/s3,"s3://crabby-images/e8768/e876873908bfdb4cb0a7448e1090571c262db281" alt=""
data:image/s3,"s3://crabby-images/f10ee/f10eec60479250b27d2067eca4943e474db58a99" alt=""
data:image/s3,"s3://crabby-images/45956/459569bc3866d5cea6f125886acd72f9410a0789" alt=""
data:image/s3,"s3://crabby-images/76e5e/76e5e1f633b430b557efc1d975ef1e04bc9f34c5" alt=""
data:image/s3,"s3://crabby-images/468c0/468c040332969c05ccfbdf3507f403cef36b6402" alt=""
(4)编辑线要素并保存
data:image/s3,"s3://crabby-images/0dfbe/0dfbecd561216b0eab43789c6cc43b566033b3f2" alt=""
data:image/s3,"s3://crabby-images/71c1a/71c1ae0fd8acb41d337a1daac82f85f2ec3f5e31" alt=""
(5)注册要素集版本
注册要素时,需要将ArcSDE要素移除TOC页,以解除要素占用。
data:image/s3,"s3://crabby-images/788e3/788e308ff206042b72a6d537c1f8118fae9a8648" alt=""
对要素集注册版本。
data:image/s3,"s3://crabby-images/16ba0/16ba0942677cab2236d67fcb495942e32067ecd6" alt=""
data:image/s3,"s3://crabby-images/785e1/785e13b5f876e475bb20de5b35a5c885d56ee057" alt=""
添加要素:
data:image/s3,"s3://crabby-images/62ed7/62ed751b787861caad8385e3792599509bc1991e" alt=""
注:有时注册会提示锁定,如下:
data:image/s3,"s3://crabby-images/3430d/3430d43afe1ae5071e20fe7f5341d90fcd0d68dd" alt=""
解决方案如下:
data:image/s3,"s3://crabby-images/a2dd4/a2dd452e9f3202acfa84a3eb40e2292206ccbff6" alt=""
data:image/s3,"s3://crabby-images/5e315/5e315756bb947dc068322cc2970a59d3519077df" alt=""
data:image/s3,"s3://crabby-images/f033b/f033b71bb3f145dd054e212f61d1aca6054f67a9" alt=""
完成以上操作后,即可正常进行要素注册或删除等操作。
3.注册ArcSDE地理数据库
data:image/s3,"s3://crabby-images/aba53/aba534f9fad510b03c4bfd2d4165e09fb58f1c58" alt=""
data:image/s3,"s3://crabby-images/59d1e/59d1e245cdf886ea0883c7ec1f03095d81092b54" alt=""
data:image/s3,"s3://crabby-images/663ec/663ec228d1fe2a0f079e188fd228d05a715da11b" alt=""
以上②步添加以下内容。
data:image/s3,"s3://crabby-images/2bd8b/2bd8b9b29131d4f1b555a70207899eee61ea3501" alt=""
data:image/s3,"s3://crabby-images/ef5e4/ef5e43e4d51a285a2c947d1ce4ad088b7ab2747c" alt=""
4.发布数据到Arcgis Server
data:image/s3,"s3://crabby-images/3f3ee/3f3ee896704f7d0faaf2ceb836f0d84cd34b12d0" alt=""
data:image/s3,"s3://crabby-images/8764e/8764e81fddcb3876222f1939aa5bcd30533ae5e8" alt=""
data:image/s3,"s3://crabby-images/794d4/794d4301673ff41f34158c458d9822f333684b9e" alt=""
data:image/s3,"s3://crabby-images/0179b/0179b424bf1f4ba285d77cee7a0610b88ff87567" alt=""
data:image/s3,"s3://crabby-images/93943/93943f868a67d86026654de9e1b75219fef0adce" alt=""
data:image/s3,"s3://crabby-images/c2cb6/c2cb6f33c71b74f2074d1313044d171e0fe6d09f" alt=""
data:image/s3,"s3://crabby-images/cfaf8/cfaf8ef6fae47986526eb2e5a8b87486f8782680" alt=""
data:image/s3,"s3://crabby-images/19dde/19ddecb9e88685df22332ce1eecab90efb26c438" alt=""
有时可能出现以下结果:
data:image/s3,"s3://crabby-images/3bd3e/3bd3e4837d30f501b0e74056c2741b57fda87a8f" alt=""
服务发布结果提示需要手动启动server服务,以下进行操作。
Win+Q打开搜索"服务",找到"组件服务"并打开。
data:image/s3,"s3://crabby-images/85f60/85f6029ea9440e6aafde66561d54749fa8457bca" alt=""
data:image/s3,"s3://crabby-images/4efed/4efedbbc85c13037164d2a812c879062c7a8d397" alt=""
data:image/s3,"s3://crabby-images/96e5e/96e5e47e0a223828ef63aab923247afeeec5319f" alt=""
data:image/s3,"s3://crabby-images/5dfee/5dfee31063080b9528b571cb747132a7696d0056" alt=""
data:image/s3,"s3://crabby-images/73ecf/73ecf7bb66098716622cfa7aeb2e0b46d3d63c51" alt=""
发布的服务可以在本地查看,如下:
data:image/s3,"s3://crabby-images/a7b44/a7b4432d4e6af1009ddb455da8ee2a7b1126acbe" alt=""
发布的服务可以在server端查看,如下:
data:image/s3,"s3://crabby-images/b97bc/b97bcd53f9bc1352d3c74d1819ba8a23e2cd3c8b" alt=""
data:image/s3,"s3://crabby-images/d1bcf/d1bcfbb5bafdd588378645225ed159aafcccbbda" alt=""
5.ArcgisForJS访问ArcGIS Server数据
启用ArcGIS Server地图服务
data:image/s3,"s3://crabby-images/6d71c/6d71ccc19fcabbefd082c959d60f59e0fe49a7d8" alt=""
ArcgisForJS访问以下的REST URL:http://localhost:6080/arcgis/rest/services/TEST/测试server/MapServer
data:image/s3,"s3://crabby-images/71874/7187451879aea2a0dfd6f875daa61711d5c33c98" alt=""
data:image/s3,"s3://crabby-images/65178/6517845757c7e5cdecfffe6735dad74123bd79da" alt=""
ArcgisForJS加载Arcgis Server发布的数据实现代码:
csharp
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Create Map</title>
<link rel="stylesheet" href="http://localhost:8099/arcgis_js_api/javascript/4.28/esri/themes/light/main.css" />
<script src="http://localhost:8099/arcgis_js_api/javascript/4.28/init.js"></script>
<style>
html,
body,
#viewDiv {
padding: 0;
margin: 0;
height: 100%;
width: 100%;
}
</style>
<script type="text/javascript">
require(["esri/Map",
"esri/views/MapView",
"esri/config",
"esri/layers/MapImageLayer"
], function (
Map,
MapView,
esriConfig,
MapImageLayer
) {
let layer = new MapImageLayer({
url:"http://localhost:6080/arcgis/rest/services/TEST/测试server/MapServer"
});
const map = new Map({
basemap: "topo-vector"
});
map.add(layer);
const view = new MapView({
container: "viewDiv", // Reference to the DOM node that will contain the view
map: map, // References the map object created in step 3
zoom: 3,
center: [0, 45]
});
});
</script>
</head>
<body>
<div id="viewDiv"></div>
</body>
</html>
实现结果
data:image/s3,"s3://crabby-images/07ce5/07ce5a6b9aa15ff7505d174b5b7d98f89a83ef0d" alt=""
参考资料:
[1] juechen333. ArcGIS10.2保姆式安装教程,超详细;附安装包; 2023-01-15 [accessed 2024-02-21].
[2] GISer苍如狗. Arcgis Server安装教程; 2021-05-01 [accessed 2024-02-21].
[3] 孙霸天. ArcGIS server 10.2安装教程详细版; 2022-03-15 [accessed 2024-02-21].
[4] 一入GIS深似海. 不一样的前端,JavaScript之arcgis api教程; 2020-11-02 [accessed 2024-02-21].
[5] wsqplsh. arcgisserver发布服务详细流程; 2016-01-12 [accessed 2024-02-21].
[6] 老靳的WebGIS. 【完整的WebGIS教程】6.1 使用ArcGIS Server发布要素服务; 2023-08-07 [accessed 2024-02-21].
[7] jxufeng. arcgis10.2 SDE (sqlserver)安装及使用; 2014-04-16 [accessed 2024-02-20].
[8] 2015在路上. ArcGIS Server10.2服务启动不了之http://localhost:6080/arcgis/manager无法打开之arcMap 无法打开6080admin问题解决之路; 2016-10-21 [accessed 2024-02-21].
[9] 马克玲. 发布服务成功后arcgis services directory目录中无法显示服务列表; 2014-07-15 [accessed 2024-02-21].
[10] 佛系小泉. ArcGIS Server发布服务及一些发布常见问题解决; 2023-07-31 [accessed 2024-02-21].
[11] 芒小李. Failed to register as versioned.Lock request conflicts with an established lock; 2019-01-23 [accessed 2024-02-21].
[12] xiaoxingdi. 分别使用arcgis for js 4.x和3.x加载本地server地图; 2019-04-12 [accessed 2024-02-21].
[13] GIS开发者. ArcGIS API for JS4.7加载ArcGIS Server发布的REST和WMS地图服务; 2018-07-18 [accessed 2024-02-21].
[14] 易智瑞. ArcGIS API For Javascript入门; 2020-09-15 [accessed 2024-02-21].