当前位置: 首页 > news >正文

可信网站证书/焊工培训班

可信网站证书,焊工培训班,风格 特别的网站,互动平台是什么意思目录 前言 一、Leaflet GeoMan是什么 1、关于Leaflet GeoMan 2、关于开源版和企业版 3、相关的方法介绍 二、使用Geoman来进行自由标绘实战 1、相关资源准备 2、新建html网页 3、初始化地图及绑定Geoman控件 三、自由标绘的成果 1、整体效果 2、添加空间对象 3、开…

目录

前言

一、Leaflet GeoMan是什么

1、关于Leaflet GeoMan

2、关于开源版和企业版

3、相关的方法介绍

二、使用Geoman来进行自由标绘实战

1、相关资源准备

2、新建html网页

3、初始化地图及绑定Geoman控件

三、自由标绘的成果

1、整体效果

2、添加空间对象

3、开启移动和编辑 

 四、总结


前言

        很多人文类GIS、旅游类GIS,通常会采用WebGIS的方式想公众、游客来介绍当前用户感兴趣的地理信息。同时为了增加交互的趣味性,在这类人文类的GIS应用中,不仅可以支持底图的在线加载,同时还可以支持用户自主的来编辑或设置一些标绘,把一些用户自己感兴趣的空间位置信息进行图上标绘,类似于涂鸦的概念,通过这种交互性提高用户的使用欲望,从而让系统和用户结合得更好。而一些历史类的WebGIS应用也会有类似的需求,比如描述某个人物的一生,除了搜集可以获取到的位置信息,还可以基于互联网,自动关联一些感兴趣的位置、面、范围、矩形、多边形等空间信息与人物进行关联,来辅助进行说明目标任务的一生。

        类似于上面的这种操作界面,它支持各种不同的空间对象的创建和编辑,比如点、线、矩形、多边形、圆、圆点,文本标注等,同时还支持对空间对象的移动、剪切、删除、旋转等操作。用户只需要组织好自己的场景,然后基于WebGIS进行场景的创作。就像编剧一样,把各种人物按照一定的关系和出场顺序组织好,让他们依次粉墨登场。在以往的WebGIS应用开发中,我们采用的都是Leaflet.js。因此在这里,我们要想实现各种空间对象的编辑和管理,依然决定在Leaflet的可视化展示组件上来进行开发。

        本文即在这样的需求背景下诞生,首先讲解基于Leaflet开发的一个Leaflet GeoMan组件,介绍这个组件是什么,有哪些特色功能,然后介绍如何在工程中使用这些组件,最后在以一个实际的案例来实现之前我们提出来的场景。通过本文,您不但可以了解什么是Leaflet geoMan,还可以掌握它的基本用法,了解如何创建第一个基本应用,最后学会如何在WebGis界面中进行自由标绘。掌握GIS,用GIS来表达,用GIS来讲故事,从这里开始。

一、Leaflet GeoMan是什么

        本节依然来重点讲解Leaflet Geoman是什么?究竟这个组件能做些什么,它有哪些特别之处呢?在使用的时候,有哪些方法可以使用呢?这些内容都将在本节给出答案。

1、关于Leaflet GeoMan

        首先,我们来看一下在GitHub上,关于Leaflet GeoMan这个项目的简要介绍,感兴趣的朋友可以在GitHub上来查找它的源码。从而更加了解它的代码编写和设计思路。传送门。

         可以看到,在github上面,leaflet-geoman这个项目的start 数已经有2.1k,作为一个前端组件,尤其是面向webgis的前端组件,非常厉害了。下面我们结合它的官网资料来进行一些简要介绍。让您提前了解一些知识。

        首先看得到的是,这个项目的开源协议采用的MIT协议,这个协议是非常宽松的协议。首先来看一下这个项目的主要介绍。

          The most powerful leaflet plugin for drawing and editing geometry layers。Leaflet Plugin For Creating And Editing Geometry Layers Draw, Edit, Drag, Cut, Rotate, Split, Scale, Measure, Snap and Pin Layers Supports Markers, CircleMarkers, Polylines, Polygons, Circles, Rectangles, ImageOverlays, LayerGroups, GeoJSON, MultiLineStrings and MultiPolygons。

        上述文字是在其官网上的详细内容介绍,翻译成中文就是:用于绘制和编辑几何图层的最强大的Leaflet插件。用于创建和编辑几何图层的Leaflet插件绘制、编辑、拖动、剪切、旋转、分割、缩放、测量、捕捉和固定图层支持标记、圆标记、折线、多边形、圆、直角、图像叠加、图层组、GeoJSON、多线串和多多边形。从以上内容可知,其是针对Leaflet的一种扩展。

2、关于开源版和企业版

        虽然这款软件是开源的,但是其还是有开源版和企业版的区别,关于这两个版本的主要差别,在Leaflet-geoman的官方文档上有简要的说明。与市面上大多数的软件一致,企业版的功能比开源版的要多一些,这也是正常的。企业版(pro)版的功能要比开源版强大一些。如果您在平时的工作中确实需要这些新特性,那不妨去支持一下这个项目。企业版的不同之处主要分几个方面,第一个方面是企业版支持的模式多一些,如下图所示:

        上图红色框中的就是企业版独有的Mode,在开源版中没有。 当然,除了Mode的区别之外,在Options配置方面也是有一些区别。

        在实际的项目中,在引入Leaflet-geoman资源时,需要注意不同的版本的选择,开源版的资源引入使用如下所示:

<linkrel="stylesheet"href="https://unpkg.com/@geoman-io/leaflet-geoman-free@latest/dist/leaflet-geoman.css"
/>

        同时还要引入javascript(请注意,这里使用的是free版本):

<script src="https://unpkg.com/@geoman-io/leaflet-geoman-free@latest/dist/leaflet-geoman.js"></script>

        企业版的相关资源引入,需要申请key等令牌后才能访问。

3、相关的方法介绍

        除了介绍怎么下载geoman项目,还介绍了这个项目的两个不同版本区别,最后还是回归到技术来,就是geoman这个项目的相关方法和属性怎么去设置,工具栏的配置方法是什么?这里将重点介绍一下。首先来介绍一下工具栏的配置,在Leaflet界面中,要想触发编辑或者新增,都需要在工具栏上来统一出发。因此首先介绍工具栏的配置。工具栏的参数如下:

MethodReturnsDescription
addControls(options)-Adds the Toolbar to the map. The options are optional. Buttons can be removed with setting them to false.
removeControls()-Removes the Toolbar from the map.
toggleControls()-Toggle the visiblity of the Toolbar.
controlsVisible()BooleanReturns true if the Toolbar is visible on the map.

        然后我们具体来看下options这个配置参数具体有哪些?

OptionDefaultDescription
position'topleft'Toolbar position, possible values are 'topleft''topright''bottomleft''bottomright'
positionsObjectThe position of each block (draweditcustomoptions⭐) can be customized. If not set, the value from position is taken. Default: {draw: '', edit: '', options: '', custom: ''} Block Position
drawMarkertrueAdds button to draw Markers.
drawCircleMarkertrueAdds button to draw CircleMarkers.
drawPolylinetrueAdds button to draw Line.
drawRectangletrueAdds button to draw Rectangle.
drawPolygontrueAdds button to draw Polygon.
drawCircletrueAdds button to draw Circle.
drawTexttrueAdds button to draw Text.
editModetrueAdds button to toggle Edit Mode for all layers.
dragModetrueAdds button to toggle Drag Mode for all layers.
cutPolygontrueAdds button to cut a hole in a Polygon or Line.
removalModetrueAdds a button to remove layers.
rotateModetrueAdds a button to rotate layers.
oneBlockfalseAll buttons will be displayed as one block Customize Controls.
drawControlstrueShows all draw buttons / buttons in the draw block.
editControlstrueShows all edit buttons / buttons in the edit block.
customControlstrueShows all buttons in the custom block.
optionsControlstrueShows all options buttons / buttons in the option block ⭐.
pinningOptiontrueAdds a button to toggle the Pinning Option ⭐.
snappingOptiontrueAdds a button to toggle the Snapping Option ⭐.
splitModetrueAdds a button to toggle the Split Mode for all layers ⭐.
scaleModetrueAdds a button to toggle the Scale Mode for all layers ⭐.
autoTracingOptionfalseAdds a button to toggle the Auto Tracing Option ⭐.
snapGuidesOptiontrueAdds a button to toggle the SnapGuides Option ⭐.

        请注意,上面的配置选项中,标红色的是企业版采用的功能,如果是用开源版,不用管这些参数即可。篇幅有限,类似于这种设置,大家可以参考管网来进行合理配置,说明文档。其它的文档说明不再进行赘述。

二、使用Geoman来进行自由标绘实战

        在大致掌握了Geoman是什么?它的功能是什么?究竟geoman是怎么来操作空间图形对象的呢。在实际开发中,我们怎么进行代码的编写呢。本节主要说明上面的需求实现,主要是采用实际的工程代码编写的方式。通过本节掌握如何进行geoman可编辑代码的编写。

1、相关资源准备

        在进行geoman自由标绘的时候,我们首先将需要的资源准备好。由于使用的Leaflet组件,因此我们将Leaflet需要的css和javascript文件拷贝到资源目录中。关于geom依赖的css和javascript,在前面的内容中有所涉及。

        再来看一下dist文件夹中的包含哪些文件:

         leaflet相关的css和javascript文件请从leaflet相关网站上下载即可。

2、新建html网页

        然后在文件夹中新建一个index.html文件,在这个文件中引入相关的资源,包括leaflet和geoman的css样式文件和javascript脚本文件。文件内容如下:

<!DOCTYPE >
<html lang="zh"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1" /><title>Leaflet Geoman 在线标绘实战</title><link rel="stylesheet" href="./dist/leaflet.css"/><link rel="stylesheet" href="./dist/leaflet-geoman.css" /><link rel="stylesheet" href="demo.css" /></head><body><div class="wrapper"><article><h2> Leaflet Geoman 在线标绘实战</h2><div class="map" id="map"></div></article></div><script src="./dist/leaflet.js"></script><script src="./dist/leaflet-geoman.js"></script><script src="demo.js?t=3"></script></body>
</html>

3、初始化地图及绑定Geoman控件

        在创建index.html文件,同时引入了leaflet和geoman这两个组件的相关资源后,我们来实际的设置具体的控制组件。首先绑定地图容器,同时设置加载的瓦片底图的地址,这里使用天地图的图源,大家在实际展示时,需要先将tdt的tk进行替换,或者直接将地图换成其它的图源。

/* eslint-disable no-console */
const tiles = L.tileLayer('http://t0.tianditu.gov.cn/img_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=img&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=you key', {maxZoom: 18,attribution:'&copy; <a href="hhttps://www.tianditu.gov.cn/">在线图源使用国家天地图</a> contributors',
});const map = L.map('map').setView([51.505, -0.09], 13).addLayer(tiles);

        然后开启工具栏绑定,具体要开启的设置见官网说明,关键代码如下:

layerGroup.pm.toggleEdit({draggable: true,snappable: true,snapDistance: 30,
});

        最后将组件绑定到地图中,这里是将工具栏放置到右上方的位置,关键代码如下所示:

map.pm.addControls({position: 'topright',
});

        到此,已经完成了地图组件的初始化,geoman控件的绑定和渲染展示设置等。

三、自由标绘的成果

        本节以自由标绘的成果为例,主要说明在界面中如何进行使用。因此这里是交作业被检查的时候。

1、整体效果

        首先来看一下整体的效果,我们默认还设置了一些初始化的空间对象,比如线、面还有geojson类型的数据,让大家对主动加载数据有一个直观的了解。

const layerGroupItem1 = L.polyline([[51.51, -0.09],[51.513, -0.08],[51.514, -0.11],],{ pmIgnore: true }
);
const layerGroupItem2 = L.polygon([[51.52, -0.06],[51.51, -0.07],[51.52, -0.05],
]);
const layerGroupItem3 = L.polygon([[51.51549835365031, -0.06450164634969281],[51.51944818307178, -0.08425079345703125],[51.51868369995795, -0.06131630004205801],[51.51549835365031, -0.06450164634969281],
]);
const feature = {type: 'Feature',properties: {},geometry: {type: 'Polygon',coordinates: [[[72.839012, 19.058873],[72.92038, 19.066985],[72.856178, 19.019928],[72.839012, 19.058873],],],},
};
const layerGroup = L.featureGroup([layerGroupItem1]).addTo(map);

         上图是初始化展示的自由标绘底图,同时加载了几个待编辑的空间对象。

2、添加空间对象

        这里主要演示添加线、面、矩形、范围、多边形、文本标记、原型等空间对象。

3、开启移动和编辑 

        在右边的工具条中,不仅可以添加新的空间对象,同时还可以对整体信息进行编辑,比如剪切、平移、旋转等操作。直接使用鼠标点击工具栏即可完成对应的设置。当打开编辑窗口时,可以拖动关键点进行图形的位置修正。

        下面是一张我们绘制的模拟城市功能区位置示意图 

 四、总结

        以上就是本文的主要内容,本文首先讲解基于Leaflet开发的一个Leaflet GeoMan组件,介绍这个组件是什么,有哪些特色功能,然后介绍如何在工程中使用这些组件,最后在以一个实际的案例来实现之前我们提出来的场景。通过本文,您不但可以了解什么是Leaflet geoMan,还可以掌握它的基本用法,了解如何创建第一个基本应用,最后学会如何在WebGis界面中进行自由标绘。行文仓促,定有不足之处,如有不当或者需要补充的地方,还行各位专家和朋友在评论区留言指正,鄙人不胜感激。

相关文章:

使用Leaflet GeoMan结合天地图进行自由标绘实战

目录 前言 一、Leaflet GeoMan是什么 1、关于Leaflet GeoMan 2、关于开源版和企业版 3、相关的方法介绍 二、使用Geoman来进行自由标绘实战 1、相关资源准备 2、新建html网页 3、初始化地图及绑定Geoman控件 三、自由标绘的成果 1、整体效果 2、添加空间对象 3、开…...

Flutter自定义通用防抖的实现

在前端项目开发中&#xff0c;点击事件的防抖是一个永远无法错开的点&#xff0c;特别是针对一些复杂的业务场景&#xff0c;如果不做好防抖操作&#xff0c;就会导致页面或功能触发多次&#xff0c;引发异常或闪退。 在Flutter中可以通过扩展函数的特性 对Function增加全局扩…...

C# Unity 面向对象补全计划 之 继承(字段与属性)

本文仅作学习笔记与交流&#xff0c;不作任何商业用途&#xff0c;作者能力有限&#xff0c;如有不足还请斧正 本系列旨在通过补全学习之后&#xff0c;给出任意类图都能实现并做到逻辑上严丝合缝 Q&#xff1a;为什么要单讲继承字段与属性&#xff0c;不讲继承方法了吗&#x…...

leetcode202. 快乐数,双指针法巧用

leetcode202. 快乐数 编写一个算法来判断一个数 n 是不是快乐数。 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。 然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不到 1。 如果这个过程…...

基于Cobbler实现多版本系统批量部署

一、实验题目 基于Cobbler实现多版本操作系统的批量部署。 二、实验目的 掌握Cobbler服务器的安装与配置方法。 学会使用Cobbler进行多版本操作系统的批量部署。 理解PXE网络启动原理及其在操作系统部署中的应用。 提高在实际生产环境中快速部署和管理操作系统的能力。 …...

一投就中不是梦,录取率>80%,最快1个月就见刊,计算机沾边就收,认可度还不低

本次模术狮精心整理5本期刊&#xff0c;最快1个月就见刊&#xff0c;计算机沾边就收&#xff0c;认可度还不低&#xff01; 1 Knowledge-Based Systems ▲ 图片来源&#xff1a;Knowledge-Based Systems官网 期刊简介&#xff1a;《Knowledge-Based Systems》是人工智能领域的…...

【课程系列06】某乎AI大模型全栈工程师-第6期

网盘链接 链接&#xff1a;https://pan.baidu.com/s/1QLkRW_DmIm1q9XvNiOGwtQ --来自百度网盘超级会员v6的分享 课程目标 【知乎大模型课程】学习的四个维度 &#x1f449;指挥层&#xff1a;学高阶指令工程 AI编程等&#xff0c;指挥大模型完成90%代码任务&#xff0c;包…...

Prompt——3分钟掌握,润色论文的7条经典指令。帮助很大,一定要看!

这是一篇帮助你润色论文的ChatGPT指令合集&#xff0c;整理了润色过程中语法优化、审阅校对、专业风格等7个主要方面。 建议收藏&#xff0c;需要的时候直接CtrlV即可&#xff0c;一定对你科研有所帮助~ 1. 修复语法和句法 第一个提示是修复语法和句法。这是任何写作的关键部…...

ARM学习(31)编译器对overlay方式的支持

ARM学习&#xff08;31&#xff09;编译器对overlay方式的支持 1、overlay介绍 overlay&#xff1a;重叠得意思&#xff0c;就是可以重复利用得空间&#xff0c;一般在内存上使用这种空间。比如以Windows操作系统为例&#xff0c;其存储空间&#xff08;ROM/FLASH&#xff09;…...

【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常

问题现象 BeetISQL中间件版本&#xff1a;2.13.8.RELEASE 客户在调用BeetISQL提供的api向yashandb的表中执行batch insert并将返回sequence设置到传入的java bean时&#xff0c;报如下异常&#xff1a; 问题的风险及影响 影响业务流程正常执行&#xff0c;无法获得batch ins…...

软件测试——用例篇(上)

概念 什么是测试⽤例&#xff1f; 测试⽤例&#xff08;Test Case&#xff09;是为了实施测试⽽向被测试的系统提供的⼀组集合&#xff0c;这组集合包含&#xff1a;测试环境、操作步骤、测试数据、预期结果等要素 设计测试⽤例原则⼀&#xff1a; 测试⽤例中⼀个必需部分是对…...

Flink中三种模式:YARN Session 模式、YARN Per-Job 模式和 YARN Application 模式提交任务命令

在 Apache Flink 中,YARN 提供了多种模式来提交和管理作业,每种模式都有其独特的特点和适用场景。主要有以下三种模式:YARN Session 模式、YARN Per-Job 模式和 YARN Application 模式。 1. YARN Session 模式 在 YARN Session 模式中,一个长时间运行的 Flink 会话(Sess…...

DBMS-1.2 关系运算

本文章的素材与知识均来自于李国良老师的数据库管理系统课程。 关系代数 一.基本关系代数运算 基本关系代数运算包括&#xff1a;选择、投影、并、差、笛卡尔积、重命名。 1.选择&#xff08;select&#xff09; 选择运算用于从关系R中获取满足条件的元组。 &#xff08;1…...

Python——继承

一、继承 1. 什么是继承&#xff1f; 继承是一种面向对象编程的机制&#xff0c;允许一个类&#xff08;子类&#xff09;从另一个类&#xff08;父类&#xff09;继承属性和方法。子类可以扩展或修改父类的功能。 2. 如何实现继承&#xff1f; 在Python中&#xff0c;实现…...

程序员转型AI大模型好转吗?成功率高吗?

前言 在程序员圈子中&#xff0c;技术转型近年来一直是热门话题。随着AI技术的迅猛发展&#xff0c;优秀人才短缺&#xff0c;程序员向AI大模型转型似乎成为了一条通往职场先机的路径。但是&#xff0c;这条转型之路是否容易走&#xff0c;成功率又如何呢&#xff1f; 一、程…...

关于 Postman 这些你都知道吗?

Postman是接口测试工具&#xff0c;在做接口测试的时候&#xff0c;Postman相当于一个客户端&#xff0c;它可以模拟用户发起的各种http请求&#xff0c;将请求的数据发送到服务端&#xff0c;获取对应的结果&#xff0c;从而测试接口是否能够满足业务功能要求&#xff0c;很直…...

ReentrantLock

ReentrantLock ReentrantLock 是一个可重入的互斥锁&#xff0c;它提供了比 synchronized 关键字更灵活的锁机制。它属于 java.util.concurrent.locks 包。 特点&#xff1a; 可重入性&#xff1a;同一个线程可以多次获取锁而不会造成死锁&#xff0c;锁的计数器会递增。公平…...

python | TypeError: list indices must be integers or slices, not tuple

python | TypeError: list indices must be integers or slices, not tuple 在Python编程中&#xff0c;TypeError: list indices must be integers or slices, not tuple 是一个常见的错误。此错误通常发生在尝试使用非整数&#xff08;如元组&#xff09;作为列表索引时。本…...

链码简介及MATLAB提取彩色图像链码

一、链码 链码&#xff08;又称为freeman code&#xff09;是一种通过带有给定方向的单位长度的线段序列来描述轮廓边界的方法,常被用来在图像处理、计算机图形学、模式识别等领域中表示曲线和区域边界。在二维图像中&#xff0c;链码可以表示为一系列的方向码&#xff0c;每个…...

二叉树,二叉查找树,平衡二叉树

一.绪论: 二.数据结构(二叉树): 1.简介: 1)每一个节点&#xff08;也叫结点&#xff09;都是一个独立的对象-->当中不仅要存数据值&#xff0c;还要存父节点地址值&#xff0c;左子节点地址值&#xff0c;右子 节点地址值 2)没有父节点或者子节点的节点就记为null 2.遍历方…...

《零散知识点 · SpringBoot 整合邮件功能》

&#x1f4e2; 大家好&#xff0c;我是 【战神刘玉栋】&#xff0c;有10多年的研发经验&#xff0c;致力于前后端技术栈的知识沉淀和传播。 &#x1f497; &#x1f33b; CSDN入驻不久&#xff0c;希望大家多多支持&#xff0c;后续会继续提升文章质量&#xff0c;绝不滥竽充数…...

编程小白如何成为大神?大学新生的最佳入门攻略

目录 方向一&#xff1a;选择适合的编程语言 方向二&#xff1a;制定有效的学习计划 方向三&#xff1a;避免常见的学习陷阱 方向四&#xff1a;额外建议 编程已成为当代大学生的必备技能&#xff0c;但面对众多编程语言和学习资源&#xff0c;新生们常常感到迷茫。如何选择…...

使用 PyInstaller 和 Hook 文件打包 APK 解析工具

错误信息如下&#xff1a; Traceback (most recent call last):File "test.py", line 4, in <module>File "<frozen importlib._bootstrap>", line 991, in _find_and_loadFile "<frozen importlib._bootstrap>", line 975, …...

【分布式】分库分表知识点大全

为什么要分库分表 随着业务量的增加导致数据库中数据量的增加&#xff0c;可能拖慢查询的性能&#xff0c;影响业务的可用性&#xff1b;如果数据库采用读写分离&#xff0c;可能会导致从库的延迟较大&#xff0c;主库进行写操作后&#xff0c;从库因为延迟无法及时同步&#…...

FreeRTOS中的定时器:xTimerCreate ,xTimerStart ,xTimerStop

1. 创建定时器 定时器的创建使用 xTimerCreate 函数。该函数有以下参数&#xff1a; pcTimerName&#xff1a;定时器的名字&#xff0c;主要用于调试。xTimerPeriodInTicks&#xff1a;定时器的周期&#xff0c;以系统节拍计时。uxAutoReload&#xff1a;定时器是否自动重载。如…...

【网络安全】文件上传黑白名单及数组绕过技巧

不安全的文件上传&#xff08;Unsafe FileUpload&#xff09; 不安全的文件上传是指Web应用程序在处理用户上传的文件时&#xff0c;没有采取足够的安全措施&#xff0c;导致攻击者可能利用这些漏洞上传恶意文件&#xff0c;进而对服务器或用户造成危害。 目录 一、文件上传…...

4.2、存储管理-页式存储

页式存储和段氏存储会考 页式存储几乎必考&#xff0c;段氏存储可能会考 页式存储 页式存储是操作系统的一种存储管理方式。 因为我们的程序往往是远远大于内存的&#xff0c;所以程序在执行的时候&#xff0c;是不会一次性把所有内容都装入到内存中&#xff0c;它会把程序分…...

60个常见的 Linux 指令

常见60个Linux指令 1.ssh 登录到计算机主机2.ls 列出目录内容3.pwd 当前终端会话所在的完整路径4.cd 切换当前工作目录5.touch 创建空文件或更新文件的时间戳6.echo 终端输出文本或变量值7.nano 在终端中编辑文件8.vim 文本编辑器9.cat 查看、连接和创建文件10.shred 安全删除敏…...

DockerRedis基础

目录 Docker 部署MySQL 镜像和容器 解析命令 Docker基础 常见命令 命令别名 数据卷 命令 自定义镜像 Dockerfile 网络 自定义网络设置静态IP Redis概述 NoSQL&#xff08;非关系型数据库&#xff09; Redis Redis命令行客户端 Redis数据结构 Redis通用命令&…...

oracle读写时相关字符集详解

服务器端操作系统&#xff08;Oracle linux&#xff09;字符集 服务器端数据库字符集 客户端操作系统&#xff08;Oracle linux&#xff09;字符集 客户端工具sqlplus字符集 结论1&#xff1a;客户端工具sqlplus的会话&#xff0c;使用的字符集&#xff0c;是数据库字符集。…...