node怎么将geojson转shp返回给前端
小编给大家分享一下node怎么将geojson转shp返回给前端,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
node将geojson转shp需要调用[ogr2ogr][1]库来实现,在调用ogr2ogr库时,因为其通过调用gdal的工具来实现将
geojson转shp,所以需要安装gdal并配置环境变量。
第一:你要确定你的.node 是好的,然后你可以继续下一步了
第二:你的.node发现不了可能是因为缺少了依赖关系,简单点说,就是缺少了.dll
第三:下载 Dependency Walker,这个软件可以帮你确定一下缺少什么.dll,下载地址:http://www.dependencywalker.com/
第四:下载完Dependency Walker 直接打开.node 文件,将提示缺少的重要.dll 放在.node 同一级的目录下,当然你也可以不用下软件,直接把重要的.dll放在.node目录下就可以了。
第五:运行,就不会报错了。
环境配置完,可以进行代码实现了。
首先引入ogr2ogr库
const ogr2ogr = require('ogr2ogr')
生成shp文件压缩包
// 声明一个geojson变量也可以是geojson文件目录
var geojson = {
type: 'FeatureCollection',
features: [
{
type: 'Feature',
geometry
}
]
}
// shp保存目录
const zipPath = './export/shpfile.zip'
// 创建文件写入流
var file = fs.createWriteStream(zipPath)
// 调用ogr2ogr进行转化
var ogr = ogr2ogr(geojson).project('EPSG:4326')
.format('ESRI Shapefile')
.skipfailures()
.stream()
ogr.pipe(file)
然后将shp压缩文件传给前端,这里可以通过不同的方法进行传递
(1) 通过sendFile直接进行传递
var resPath = path.join(__dirname, '..', zipPath)
res.sendFile(resPath)
(2)通过流的方式进行传递
var resPath = path.join(__dirname, '..', zipPath)
// 文件写入完成触发事件
file.on('finish', function() {
res.set({
'Content-Type': 'application/zip',
'Content-Disposition':
'attachment; filename=' + encodeURI(name) + '.zip',
'Content-Length': fs.statSync(zipPath).size
})
let fReadStream = fs.createReadStream(zipPath)
fReadStream.pipe(res)
fReadStream.on('end', function() {
fs.unlinkSync(resPath)
})
fReadStream.on('error', function(err) {
console.log(err)
})
})
最后是前端发送请求接收的代码
axios.post('http://localhost:3000/jsontoshp', {
responseType: 'blob'
}).then(res => {
const blobUrl = URL.createObjectURL(res.data)
const a = document.createElement('a')
a.style.display = 'none'
a.download = '文件名称'
a.href = blobUrl
a.click()
URL.revokeObjectURL(blobUrl)
})
这里需要注意的地方是前端发送请求时需要设置一个参数responseType: 'blob',这里用到了Blob对象,这里是从服务器接收到的文件流创建blob对象并使用该blob 创建一个指向类型数组的URL,将该url作为a标签的链接目标,然后去触发a标签的点击事件从而文件下载。
看完了这篇文章,相信你对“node怎么将geojson转shp返回给前端”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网行业资讯频道,感谢各位的阅读!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341