GPS(Global Positioning System)와 위성 영상 기술의 급속한 발전으로 지리정보시스템(GIS)이 중요한 응용 분야로 자리 잡았습니다. GIS는 지도 제작 및 분석에만 국한되지 않고 환경관리, 토지관리, 도시계획 등 다양한 분야에서 널리 활용되고 있습니다. 웹 GIS 애플리케이션의 개발을 통해 사용자는 언제 어디서나 어떤 장치를 통해서든 GIS 데이터를 쿼리, 분석 및 관리할 수 있으며 이는 애플리케이션 전망이 뛰어납니다.
Django는 Python 언어 기반의 웹 개발 프레임워크로 효율적인 웹 애플리케이션을 빠르게 구축하는 데 도움이 되는 일련의 개발 도구와 기술을 제공합니다. 이 기사에서는 Django를 사용하여 간단한 웹 GIS 애플리케이션을 구축하는 방법을 소개합니다.
1. 환경 준비
시작하기 전에 다음과 같은 필수 환경이 설치되어 있는지 확인해야 합니다.
django-admin startproject webgis
cd webgis다음으로 다음 명령을 사용하여 gisapp이라는 응용 프로그램을 만들 수 있습니다.
python manage.py startapp gisapp이 명령은 gisapp이라는 Django 응용 프로그램을 만들고 프로젝트 A 하위 디렉터리에 추가합니다. 디렉터리 아래에 동일한 이름이 생성됩니다. 3. Django 프로젝트 구성 프로젝트의 settings.py 파일에서 GDAL과 애플리케이션을 구성해야 합니다.
# settings.py # 导入GDAL库 from django.contrib.gis import gdal # 数据库设置 DATABASES = { 'default': { 'ENGINE': 'django.contrib.gis.db.backends.postgis', # 使用PostGIS数据库 'NAME': 'webgis', # 数据库名称 'USER': 'postgres', # 数据库用户名 'PASSWORD': '****', # 数据库密码 'HOST': '127.0.0.1', # 数据库地址 'PORT': '5432', # 数据库端口 } } # 应用设置 INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.gis', 'gisapp', # 加入我们的应用程序 ] # 时间区域设置 TIME_ZONE = 'Asia/Shanghai' # GDAL设置 gdal.HAS_GDAL = True gdal.HAS_SRS = True4. 지리적 특징 모델 생성 애플리케이션의 models.py에서 일부 지리를 생성해야 합니다. 데이터베이스에 지리적 특징 데이터를 저장하는 파일 기능 모델입니다. 예를 들어, "WorldBorder"라는 모델을 만들어 전 세계 국가의 국경 정보를 저장할 수 있습니다. 모델 정의는 다음과 같습니다.
# models.py from django.contrib.gis.db import models class WorldBorder(models.Model): name = models.CharField(max_length=50) area = models.IntegerField(default=0) pop2005 = models.IntegerField(default=0) fips = models.CharField(max_length=2) iso2 = models.CharField(max_length=2) iso3 = models.CharField(max_length=3) un = models.IntegerField(default=0) region = models.IntegerField(default=0) subregion = models.IntegerField(default=0) lon = models.FloatField() lat = models.FloatField() mpoly = models.MultiPolygonField() def __str__(self): return self.name이 모델에서는 국가/지역의 기본 정보(예: 이름, 면적, 인구 등)를 저장하기 위해 일부 필드를 정의하고 다음과 같은 필드도 정의합니다. 경계 정보를 저장하려면 MultiPolygonField를 입력하세요. 5. 지리 특징 데이터 생성데이터베이스에 저장하기 위한 지리 특징 데이터를 생성해야 합니다. 다음 명령을 사용하여 데이터를 데이터베이스로 가져올 수 있습니다.
ogr2ogr -f "PostgreSQL" PG:"dbname=webgis user=postgres host=127.0.0.1 password=**** port=5432" -nln worldborder -nlt MULTIPOLYGON -update -overwrite -lco GEOMETRY_NAME=mpoly -skipfailures ./world_borders.shp이 명령은 world_borders.shp 파일의 데이터를 "worldborder"라는 테이블로 가져옵니다. 6. 뷰 함수 작성 사용자 요청에 응답하려면 애플리케이션의 views.py 파일에 몇 가지 뷰 함수를 작성해야 합니다. 예를 들어, "map"이라는 뷰 함수를 작성하여 전 세계 국가의 국경 정보를 지도에 표시할 수 있습니다. 이 보기 기능의 정의는 다음과 같습니다.
# views.py from django.shortcuts import render from django.contrib.gis.geos import GEOSGeometry from .models import WorldBorder def map(request): # 获取所有国家/地区 countries = WorldBorder.objects.all() # 构造GeoJSON格式数据 geojson = { "type": "FeatureCollection", "features": [] } for country in countries: feature = { "type": "Feature", "geometry": country.mpoly.geojson, "properties": { "name": country.name, "area": country.area, "pop2005": country.pop2005, "fips": country.fips, "iso2": country.iso2, "iso3": country.iso3, "un": country.un, "region": country.region, "subregion": country.subregion } } geojson["features"].append(feature) # 返回地图页面 return render(request, 'map.html', {'geojson': geojson})이 기능은 먼저 모든 국가의 정보를 가져온 다음 이를 GeoJSON 형식의 데이터로 변환합니다. 마지막으로 데이터는 표시를 위해 "map.html"이라는 템플릿으로 전달됩니다. 7. 템플릿 작성지도와 데이터를 표시하려면 애플리케이션의 템플릿 디렉토리에 "map.html"이라는 템플릿을 만들어야 합니다. 이 템플릿의 정의는 다음과 같습니다.
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Web GIS Application</title> <style> #map { width: 100%; height: 100%; position: absolute; top: 0; left: 0; z-index: -1; } </style> <script src="{% static 'leaflet/leaflet.js' %}"></script> <link rel="stylesheet" href="{% static 'leaflet/leaflet.css' %}"/> </head> <body> <div id="map"></div> <script> // 初始化地图 var map = L.map('map').setView([39.9, 116.4], 3); // 添加图层 var geojson = {{ geojson | safe }}; var countries = L.geoJSON(geojson, { onEachFeature: function (feature, layer) { layer.bindPopup(feature.properties.name); } }).addTo(map); // 添加控件 L.control.scale().addTo(map); // 添加底图 var osm = L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', { attribution: 'Map data © <a href="http://openstreetmap.org">OpenStreetMap</a> contributors' }); osm.addTo(map); </script> </body> </html>이 템플릿은 "Leaflet"이라는 JavaScript 맵 라이브러리를 사용합니다. 8. 애플리케이션 실행명령줄에서 다음 명령을 실행하여 Django 서버를 시작할 수 있습니다.
python manage.py runserver그런 다음 브라우저에서 웹 GIS 애플리케이션을 보려면 다음 주소를 방문하세요.
http://127.0.0.1:8000/mapSummary 이 문서에서는 Django와 GDAL을 사용하여 간단한 웹 GIS 애플리케이션을 구축하는 방법을 설명합니다. 이러한 도구와 기술을 사용하여 지리 데이터를 표시하고 분석하는 효율적인 웹 애플리케이션을 쉽게 개발할 수 있습니다. 또한 다른 지도 라이브러리와 GIS 데이터 소스를 사용하여 애플리케이션을 더욱 확장하고 최적화할 수 있습니다.
위 내용은 Django를 기반으로 웹 GIS 애플리케이션 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!