openlayers调用ajax接口绘制数据库数据

已被阅读 1942 次 | 文章分类:gis随笔 | 2022-05-21 00:59

利用nodejs写restful接口,ajax调用接口获取数据;openlayers绘制点位数据

1 准备如下:

(1) nodejs: https://nodejs.org/en/download/

(1) mysql: https://dev.mysql.com/downloads/installer/

(1) openlayers: https://openlayers.org/

2 nodejs实现restful接口

2.1 新建demo文件夹,然后在其中新建main.js;

2.2 在demo文件夹下运行命令行 npm install --save express;安装express库

小白GIS

2.3 输入如下代码

                                        
// 引入express模块 commonjs规范引入
const express = require('express')
// 实例化 express
const app = express()
// 定义要返回的值,后面可以从数据库查询返回
let json = {
  code: 200,
  msg: '请求成功',
  data: {
      userId: '123456',
      name: 'xiaobai',
      blog: 'http://www.xiaobaigis.com'
  }
}
// 定义接口类型以及地址
app.get("/api/data", function (req, res) {
  res.send(json)
})
// 启动服务器
app.listen(5438, function () {
  console.log("启动服务 http://localhost:5438 ")
})
                                        
                                    

2.3 运行 node api.js

小白GIS

2.4 浏览器访问 localhost:5438/api/data

3 nodejs读取mysql数据

3.1 连接mysql

安装mysql的nodejs驱动:npm install mysql --save

然后键入如下代码

                                        
const mysql = require("mysql");
var connection = mysql.createConnection({
  host     : 'localhost',
  user     : 'root',
  password : '',
  database : 'demo'
});
                                        
                                    

我们没有设置密码,所以就不用填写密码,数据库是demo;可以自己新建一个

3.2 键入数据;新建数据库,新建表,添加字段

mysql管理工具使用navicat

小白GIS

放两条数据进去:

小白GIS

4 nodejs读取mysql数据并以restful接口方式返回

全部代码:

                                        
// 引入express模块 commonjs规范引入
const express = require('express')
// 实例化 express
const app = express()
// 配置跨域
app.all("*",function(req,res,next){
  //设置允许跨域的域名,*代表允许任意域名跨域
  res.header("Access-Control-Allow-Origin","*");
  //允许的header类型
  res.header("Access-Control-Allow-Headers","content-type");
  //跨域允许的请求方式 
  res.header("Access-Control-Allow-Methods","DELETE,PUT,POST,GET,OPTIONS");
  if (req.method.toLowerCase() == 'options')
      res.send(200);  //让options尝试请求快速结束
  else
      next();
})
const mysql = require("mysql");
var connection = mysql.createConnection({
  host     : 'localhost',
  user     : 'root',
  password : '',
  database : 'demo'
});
 
connection.connect((err)=>{
    if(err) throw err;
    console.log('成功')
});
  // 查询数据表polygon1
  let sql = 'SELECT * FROM polygon'
  connection.query(sql, function (error, results, fields) {
    if (error) throw error;
    console.log('查询结果', results);
 
    // 定义接口类型以及地址
    app.get("/api/data", function (req, res) {
      res.send(results)
    })
    // 启动服务器
    app.listen(5438, function () {
      console.log("启动服务 http://localhost:5438 ")
    })
  });
                                        
                                    

这样就可以以restful的方式请求到数据库数据了;

小白GIS

5 前端渲染

效果:

小白GIS

全部代码

                                        
<!doctype html>
<html>
  <head>
    <link rel="stylesheet" href="./ol/ol.css" type="text/css">
    <style>
      .map {
        height: 400px;
        width: 100%;
      }
    </style>
<script src="./ol/ol.js" type="text/javascript"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
 
    <title>OpenLayers example</title>
  </head>
  <body>
    <!-- 地图容器 -->
    <div id="map"></div>
    <script type="text/javascript">
      // 创建地图
      var map = new ol.Map({
        target: 'map',
        layers: [
          new ol.layer.Tile({
            source: new ol.source.OSM()
          })
        ],
        view: new ol.View({
          center: ol.proj.fromLonLat([110,39]),
          zoom: 4
        })
      });
      // 创建source
      var vectorSource = new ol.source.Vector();
      // 创建layer
      var vectorLayer = new ol.layer.Vector({
          source: vectorSource
      });
      // 添加图层
      map.addLayer(vectorLayer);
 
      // 请求多边形数据
        axios.get('http://localhost:5438/api/getdata')
        .then(function (response) {
            // 处理字符串坐标为数组
            // let coorStr=response.data[0].coors
            response.data.forEach((item)=>{
              addFeature(item)
            })
        })
        .catch(function (error) {
            console.log(error);
        });
        function addFeature(item){
          let coors=[],result=[];
          item.coors.split(",").map((coor)=>{
                coor=Number(coor)
                coors.push(coor)
            })
            while(coors.length>0){
                result.push(coors.splice(0,2))
            } 
            // 创建feature
            var polygon = new ol.geom.Polygon([result]);
            polygon.applyTransform(ol.proj.getTransform('EPSG:4326', 'EPSG:3857'));
            var feature = new ol.Feature({
                geometry:polygon,
                name:item.name
            });
            // 添加feature
            vectorSource.addFeature(feature);
        }
        // 点击事件获取多边形属性
        var selectClick = new ol.interaction.Select();
        map.addInteraction(selectClick); 
        selectClick.on('select', function(e) {
                var features=e.target.getFeatures().getArray();
                var property=features[0].getProperties();
                debugger;
                alert(property.name)
            })
    </script>
  </body>
</html>
                                        
                                    

QQ:3410192267 | 技术支持 微信:popstarqqsmall

Copyright ©2017 xiaobaigis.com . 版权所有 鲁ICP备17027716号