欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

geoserver通过rest自动发布postigs图层 博客分类: GIS geoserver-managergeoserverpostgisest 

程序员文章站 2024-02-25 09:45:46
...

 geoserver自带rest服务,可以发布shp,postgis等数据源。本文目前只说明怎么通过geoserver的rest发布postgis表数据。

 

1、maven添加geoserver-manager的依赖。

 

 

<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>jcl-over-slf4j</artifactId>
			<version>1.7.5</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-api</artifactId>
			<version>1.7.5</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-log4j12</artifactId>
			<version>1.7.5</version>
		</dependency>
		<dependency>
			<groupId>it.geosolutions</groupId>
			<artifactId>geoserver-manager</artifactId>
			<version>1.5.2</version>
		</dependency>

 

 

2、java代码开始

 

配置数据库连接参数、geoserver连接参数,要发布的图层信息参数

 

String url = "http://localhost:8000/geoserver" ;
		String username = "admin" ; 
		String passwd = "geoserver" ;
		
		//postgis连接配置
		String postgisHost = "localhost" ;
		int postgisPort = 6666 ;
		String postgisUser = "xxx" ;
		String postgisPassword = "xxx" ;
		String postgisDatabase = "xxx" ;
		
		String ws = "lyf" ; //待创建和发布图层的workspace
		String store_name = "lyf" ; //数据库连接要创建的store
		String table_name = "xxx" ; // 数据库要发布的表名称,后面图层名称和表名保持一致

 

 

 

判断workspace是否存在,不存在则创建:

		URL u = new URL(url);
		
		
		GeoServerRESTManager manager = new GeoServerRESTManager(u, username, passwd);
		
		GeoServerRESTPublisher publisher = manager.getPublisher() ;
		//创建一个workspace
		List<String> workspaces = manager.getReader().getWorkspaceNames();
		if(!workspaces.contains(ws)){
			boolean createws = publisher.createWorkspace(ws);
			
			System.out.println("create ws : " + createws);
		}else {
			System.out.println("workspace已经存在了,ws :" + ws);
		}

 

判断datastore是否已经存在,不存在则创建

//store 包含和workspace一致,一个ws一个连接即可
		RESTDataStore restStore = manager.getReader().getDatastore(ws, store_name);
		
		if(restStore == null){
		
			
			GSPostGISDatastoreEncoder store = new GSPostGISDatastoreEncoder(store_name);
            store.setHost(postgisHost);//设置url
            store.setPort(postgisPort);//设置端口
            store.setUser(postgisUser);// 数据库的用户名
            store.setPassword(postgisPassword);// 数据库的密码
            store.setDatabase(postgisDatabase);// 那个数据库;
            store.setSchema("public"); //当前先默认使用public这个schema
            store.setConnectionTimeout(20);// 超时设置
            //store.setName(schema);
            store.setMaxConnections(20); // 最大连接数
            store.setMinConnections(1);		// 最小连接数
            store.setExposePrimaryKeys(true);
            boolean createStore = manager.getStoreManager().create(ws, store);
			
            System.out.println("create store : " + createStore);
            
		} else {
			System.out.println("数据store已经发布过了,store:" + store_name);
		}

 

 

判断图层是否已经存在,不存在则创建

//发布
		
		RESTLayer layer = manager.getReader().getLayer(ws, table_name);
		
		if(layer == null){
			GSFeatureTypeEncoder pds = new GSFeatureTypeEncoder();
			pds.setTitle(table_name);
			pds.setName(table_name);
			pds.setSRS("EPSG:4326");
			  
			GSLayerEncoder layerEncoder = new GSLayerEncoder();
			
			boolean publish = manager.getPublisher().publishDBLayer(ws, store_name,  pds, layerEncoder);
			
			System.out.println("publish : " + publish);
		}else {
			System.out.println("表已经发布过了,table:" + table_name);
		}

 

 

好了,到此就结束了。

 

附件带了完整的demo。