GeoServer基础教程(六):使用GeoServer发布PostGIS表数据

转自:http://www.360doc.com/content/15/0609/15/8279768_476806992.shtml

关于PostgreSQL、PostGIS安装使用和Shapefile文件的导入请查看http://blog.****.net/muzhaomingplay/article/details/77848985

1、新建数据存储

在Geoserver中新建POSTGIS的数据存储(此处database、user和password为PostgreSQL中的信息)

GeoServer基础教程(六):使用GeoServer发布PostGIS表数据

然后发布图层:

GeoServer基础教程(六):使用GeoServer发布PostGIS表数据
图层发布完成之后转到图层预览,以openlayers的方式打开:

GeoServer基础教程(六):使用GeoServer发布PostGIS表数据

当你看到这个图的时候,就说明你的服务已经发布成功了!

接下来就是用Openlayers调用显示,

  1. <html xmlns="http://www.w3.org/1999/xhtml">  
  2. <head>  
  3. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  4. <title>china EPSG:4326 image/png</title>  
  5. <link rel="stylesheet" type="text/css" href="http://200.200.200.223/OpenLayers-2.12/theme/default/style.css"/>  
  6. <style type="text/css">  
  7.     body { font-family: sans-serif; font-weight: bold; font-size: .8em; }  
  8.     body { border: 0px; margin: 0px; padding: 0px; }  
  9.     #map { width: 100%; height: 100%; border: 0px; padding: 0px; }  
  10.     #nodelist{  
  11.         position:absolute;  
  12.         right:10px;  
  13.         top:10px;  
  14.         background:#FFF;  
  15.         border:#06F solid 2px;    
  16.         padding:5px;  
  17.     }  
  18. </style>  
  19. <script type="text/javascript" src="http://200.200.200.223/OpenLayers-2.12/OpenLayers.js"></script>  
  20. <script type="text/javascript" src="http://200.200.200.223/OpenLayers-2.12/lib/OpenLayers/Lang/zh-CN.js"></script>  
  21. <script type="text/javascript">                 
  22.     var map, demolayer;                                                                          
  23.     OpenLayers.DOTS_PER_INCH = 90.71428571428572;  
  24.     OpenLayers.Util.onImageLoadErrorColor = 'transparent';  
  25.     function init(){  
  26.         var mapOptions = {   
  27.             resolutions: [0.703125, 0.3515625, 0.17578125, 0.087890625, 0.0439453125, 0.02197265625,   
  28.                 0.010986328125, 0.0054931640625, 0.00274658203125, 0.001373291015625, 6.866455078125E-4,   
  29.                 3.4332275390625E-4, 1.71661376953125E-4, 8.58306884765625E-5, 4.291534423828125E-5,   
  30.                 2.1457672119140625E-5, 1.0728836059570312E-5, 5.364418029785156E-6, 2.682209014892578E-6,   
  31.                 1.341104507446289E-6, 6.705522537231445E-7, 3.3527612686157227E-7  
  32.             ],  
  33.             projection: new OpenLayers.Projection('EPSG:4326'),  
  34.             maxExtent: new OpenLayers.Bounds(-180.0,-90.0,180.0,90.0),  
  35.             units: "degrees",  
  36.             controls: []  
  37.         };  
  38.         map = new OpenLayers.Map('map', mapOptions );  
  39.           
  40.         map.addControl(new OpenLayers.Control.PanZoomBar({  
  41.                 position: new OpenLayers.Pixel(2, 15)  
  42.         }));  
  43.         map.addControl(new OpenLayers.Control.Navigation());  
  44.         map.addControl(new OpenLayers.Control.Scale($('scale')));  
  45.         map.addControl(new OpenLayers.Control.MousePosition({element: $('location')}));  
  46.           
  47.         var wms = new OpenLayers.Layer.WMS(  
  48.             "lake",   
  49.             "http://200.200.200.223:8888/geoserver/wms",  
  50.             {  
  51.                 LAYERS: "mpro",  
  52.                 transparent:true  
  53.             },  
  54.             {  
  55.                 singleTile: false,   
  56.                 ratio: 1,   
  57.                 isBaseLayer: false,  
  58.                 visibility:true,  
  59.                 yx : {'EPSG:4326' : true}  
  60.             }   
  61.         );  
  62.         map.addLayer(wms);  
  63.           
  64.         map.zoomToExtent(new OpenLayers.Bounds(73.45100463600005, 18.16324718800007,   
  65.             134.976797647, 53.53194315200005)  
  66.         );  
  67.           
  68.         map.events.register('click', map, function (e) {  
  69.             console.log(e);              
  70.         });       
  71.     }  
  72. </script>  
  73. </head>  
  74. <body onLoad="init()">  
  75.     <div id="map"></div>  
  76. </body>  
  77. </html>