> 백엔드 개발 > 파이썬 튜토리얼 > Django를 기반으로 웹 GIS 애플리케이션 구축

Django를 기반으로 웹 GIS 애플리케이션 구축

PHPz
풀어 주다: 2023-06-17 13:12:03
원래의
1882명이 탐색했습니다.

GPS(Global Positioning System)와 위성 영상 기술의 급속한 발전으로 지리정보시스템(GIS)이 중요한 응용 분야로 자리 잡았습니다. GIS는 지도 제작 및 분석에만 국한되지 않고 환경관리, 토지관리, 도시계획 등 다양한 분야에서 널리 활용되고 있습니다. 웹 GIS 애플리케이션의 개발을 통해 사용자는 언제 어디서나 어떤 장치를 통해서든 GIS 데이터를 쿼리, 분석 및 관리할 수 있으며 이는 애플리케이션 전망이 뛰어납니다.

Django는 Python 언어 기반의 웹 개발 프레임워크로 효율적인 웹 애플리케이션을 빠르게 구축하는 데 도움이 되는 일련의 개발 도구와 기술을 제공합니다. 이 기사에서는 Django를 사용하여 간단한 웹 GIS 애플리케이션을 구축하는 방법을 소개합니다.

1. 환경 준비

시작하기 전에 다음과 같은 필수 환경이 설치되어 있는지 확인해야 합니다.

  1. Python 3. , GIS 데이터를 처리하는 데 사용됩니다.
  2. 2. 새 Django 프로젝트 만들기
  3. 다음 명령을 통해 새 Django 프로젝트를 만들 수 있습니다.
  4. django-admin startproject webgis
    로그인 후 복사
이 명령은 webgis라는 Django 프로젝트를 만듭니다. 다음 명령을 사용하여 프로젝트의 루트 디렉터리에 들어갈 수 있습니다.

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 = True
로그인 후 복사

4. 지리적 특징 모델 생성

애플리케이션의 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/map
로그인 후 복사
Summary

이 문서에서는 Django와 GDAL을 사용하여 간단한 웹 GIS 애플리케이션을 구축하는 방법을 설명합니다. 이러한 도구와 기술을 사용하여 지리 데이터를 표시하고 분석하는 효율적인 웹 애플리케이션을 쉽게 개발할 수 있습니다. 또한 다른 지도 라이브러리와 GIS 데이터 소스를 사용하여 애플리케이션을 더욱 확장하고 최적화할 수 있습니다.

위 내용은 Django를 기반으로 웹 GIS 애플리케이션 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿