前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[MySQL数据库多条件检索 ]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
转载文章
...次攻击,拿到用户隐私数据。 攻击者需要诱骗点击 反馈率低,所以较难发现和响应修复 盗取用户敏感保密信息 为了防止出现非持久型 XSS 漏洞,需要确保这么几件事情: Web 页面渲染的所有内容或者渲染的数据都必须来自于服务端。 尽量不要从 URL,document.referrer,document.forms 等这种 DOM API 中获取数据直接渲染。 尽量不要使用 eval, new Function(),document.write(),document.writeln(),window.setInterval(),window.setTimeout(),innerHTML,document.creteElement() 等可执行字符串的方法。 如果做不到以上几点,也必须对涉及 DOM 渲染的方法传入的字符串参数做 escape 转义。 前端渲染的时候对任何的字段都需要做 escape 转义编码。 escape 转义的目的是将一些构成 HTML 标签的元素转义,比如 <,>,空格 等,转义成 <,>, 等显示转义字符。有很多开源的工具可以协助我们做 escape 转义。 持久型 XSS 持久型 XSS 漏洞,也被称为存储型 XSS 漏洞,一般存在于 Form 表单提交等交互功能,如发帖留言,提交文本信息等,黑客利用的 XSS 漏洞,将内容经正常功能提交进入数据库持久保存,当前端页面获得后端从数据库中读出的注入代码时,恰好将其渲染执行。 主要注入页面方式和非持久型 XSS 漏洞类似,只不过持久型的不是来源于 URL,refferer,forms 等,而是来源于后端从数据库中读出来的数据。持久型 XSS 攻击不需要诱骗点击,黑客只需要在提交表单的地方完成注入即可,但是这种 XSS 攻击的成本相对还是很高。攻击成功需要同时满足以下几个条件: POST 请求提交表单后端没做转义直接入库。 后端从数据库中取出数据没做转义直接输出给前端。 前端拿到后端数据没做转义直接渲染成 DOM。 持久型 XSS 有以下几个特点: 持久性,植入在数据库中 危害面广,甚至可以让用户机器变成 DDoS 攻击的肉鸡。 盗取用户敏感私密信息 为了防止持久型 XSS 漏洞,需要前后端共同努力: 后端在入库前应该选择不相信任何前端数据,将所有的字段统一进行转义处理。 后端在输出给前端数据统一进行转义处理。 前端在渲染页面 DOM 的时候应该选择不相信任何后端数据,任何字段都需要做转义处理。 基于字符集的 XSS 其实现在很多的浏览器以及各种开源的库都专门针对了 XSS 进行转义处理,尽量默认抵御绝大多数 XSS 攻击,但是还是有很多方式可以绕过转义规则,让人防不胜防。比如「基于字符集的 XSS 攻击」就是绕过这些转义处理的一种攻击方式,比如有些 Web 页面字符集不固定,用户输入非期望字符集的字符,有时会绕过转义过滤规则。 以基于 utf-7 的 XSS 为例 utf-7 是可以将所有的 unicode 通过 7bit 来表示的一种字符集 (但现在已经从 Unicode 规格中移除)。 这个字符集为了通过 7bit 来表示所有的文字, 除去数字和一部分的符号,其它的部分将都以 base64 编码为基础的方式呈现。 <script>alert("xss")</script>可以被解释为:+ADw-script+AD4-alert(+ACI-xss+ACI-)+ADw-/script+AD4- 可以形成「基于字符集的 XSS 攻击」的原因是由于浏览器在 meta 没有指定 charset 的时候有自动识别编码的机制,所以这类攻击通常就是发生在没有指定或者没来得及指定 meta 标签的 charset 的情况下。 所以我们有什么办法避免这种 XSS 呢? 记住指定 XML 中不仅要指定字符集为 utf-8,而且标签要闭合 牛文推荐:http://drops.wooyun.org/papers/1327 (这个讲的很详细) 基于 Flash 的跨站 XSS 基于 Flash 的跨站 XSS 也是属于反射型 XSS 的一种,虽然现在开发 ActionScript 的产品线几乎没有了,但还是提一句吧,AS 脚本可以接受用户输入并操作 cookie,攻击者可以配合其他 XSS(持久型或者非持久型)方法将恶意 swf 文件嵌入页面中。主要是因为 AS 有时候需要和 JS 传参交互,攻击者会通过恶意的 XSS 注入篡改参数,窃取并操作cookie。 避免方法: 严格管理 cookie 的读写权限 对 Flash 能接受用户输入的参数进行过滤 escape 转义处理 未经验证的跳转 XSS 有一些场景是后端需要对一个传进来的待跳转的 URL 参数进行一个 302 跳转,可能其中会带有一些用户的敏感(cookie)信息。如果服务器端做302 跳转,跳转的地址来自用户的输入,攻击者可以输入一个恶意的跳转地址来执行脚本。 这时候需要通过以下方式来防止这类漏洞: 对待跳转的 URL 参数做白名单或者某种规则过滤 后端注意对敏感信息的保护, 比如 cookie 使用来源验证。 CSRF CSRF(Cross-Site Request Forgery),中文名称:跨站请求伪造攻击 那么 CSRF 到底能够干嘛呢?你可以这样简单的理解:攻击者可以盗用你的登陆信息,以你的身份模拟发送各种请求。攻击者只要借助少许的社会工程学的诡计,例如通过 QQ 等聊天软件发送的链接(有些还伪装成短域名,用户无法分辨),攻击者就能迫使 Web 应用的用户去执行攻击者预设的操作。例如,当用户登录网络银行去查看其存款余额,在他没有退出时,就点击了一个 QQ 好友发来的链接,那么该用户银行帐户中的资金就有可能被转移到攻击者指定的帐户中。 所以遇到 CSRF 攻击时,将对终端用户的数据和操作指令构成严重的威胁。当受攻击的终端用户具有管理员帐户的时候,CSRF 攻击将危及整个 Web 应用程序。 CSRF 原理 下图大概描述了 CSRF 攻击的原理,可以理解为有一个小偷在你配钥匙的地方得到了你家的钥匙,然后拿着要是去你家想偷什么偷什么。 csrf原理 完成 CSRF 攻击必须要有三个条件: 用户已经登录了站点 A,并在本地记录了 cookie 在用户没有登出站点 A 的情况下(也就是 cookie 生效的情况下),访问了恶意攻击者提供的引诱危险站点 B (B 站点要求访问站点A)。 站点 A 没有做任何 CSRF 防御 你也许会问:「如果我不满足以上三个条件中的任意一个,就不会受到 CSRF 的攻击」。其实可以这么说的,但你不能保证以下情况不会发生: 你不能保证你登录了一个网站后,不再打开一个 tab 页面并访问另外的网站,特别现在浏览器都是支持多 tab 的。 你不能保证你关闭浏览器了后,你本地的 cookie 立刻过期,你上次的会话已经结束。 上图中所谓的攻击网站 B,可能是一个存在其他漏洞的可信任的经常被人访问的网站。 预防 CSRF CSRF 的防御可以从服务端和客户端两方面着手,防御效果是从服务端着手效果比较好,现在一般的 CSRF 防御也都在服务端进行。服务端的预防 CSRF 攻击的方式方法有多种,但思路上都是差不多的,主要从以下两个方面入手: 正确使用 GET,POST 请求和 cookie 在非 GET 请求中增加 token 一般而言,普通的 Web 应用都是以 GET、POST 请求为主,还有一种请求是 cookie 方式。我们一般都是按照如下规则设计应用的请求: GET 请求常用在查看,列举,展示等不需要改变资源属性的时候(数据库 query 查询的时候) POST 请求常用在 From 表单提交,改变一个资源的属性或者做其他一些事情的时候(数据库有 insert、update、delete 的时候) 当正确的使用了 GET 和 POST 请求之后,剩下的就是在非 GET 方式的请求中增加随机数,这个大概有三种方式来进行: 为每个用户生成一个唯一的 cookie token,所有表单都包含同一个伪随机值,这种方案最简单,因为攻击者不能获得第三方的 cookie(理论上),所以表单中的数据也就构造失败,但是由于用户的 cookie 很容易由于网站的 XSS 漏洞而被盗取,所以这个方案必须要在没有 XSS 的情况下才安全。 每个 POST 请求使用验证码,这个方案算是比较完美的,但是需要用户多次输入验证码,用户体验比较差,所以不适合在业务中大量运用。 渲染表单的时候,为每一个表单包含一个 csrfToken,提交表单的时候,带上 csrfToken,然后在后端做 csrfToken 验证。 CSRF 的防御可以根据应用场景的不同自行选择。CSRF 的防御工作确实会在正常业务逻辑的基础上带来很多额外的开发量,但是这种工作量是值得的,毕竟用户隐私以及财产安全是产品最基础的根本。 SQL 注入 SQL 注入漏洞(SQL Injection)是 Web 开发中最常见的一种安全漏洞。可以用它来从数据库获取敏感信息,或者利用数据库的特性执行添加用户,导出文件等一系列恶意操作,甚至有可能获取数据库乃至系统用户最高权限。 而造成 SQL 注入的原因是因为程序没有有效的转义过滤用户的输入,使攻击者成功的向服务器提交恶意的 SQL 查询代码,程序在接收后错误的将攻击者的输入作为查询语句的一部分执行,导致原始的查询逻辑被改变,额外的执行了攻击者精心构造的恶意代码。 很多 Web 开发者没有意识到 SQL 查询是可以被篡改的,从而把 SQL 查询当作可信任的命令。殊不知,SQL 查询是可以绕开访问控制,从而绕过身份验证和权限检查的。更有甚者,有可能通过 SQL 查询去运行主机系统级的命令。 SQL 注入原理 下面将通过一些真实的例子来详细讲解 SQL 注入的方式的原理。 考虑以下简单的管理员登录表单: <form action="/login" method="POST"><p>Username: <input type="text" name="username" /></p><p>Password: <input type="password" name="password" /></p><p><input type="submit" value="登陆" /></p></form> 后端的 SQL 语句可能是如下这样的: let querySQL = SELECT FROM userWHERE username='${username}'AND psw='${password}'; // 接下来就是执行 sql 语句… 目的就是来验证用户名和密码是不是正确,按理说乍一看上面的 SQL 语句也没什么毛病,确实是能够达到我们的目的,可是你只是站在用户会老老实实按照你的设计来输入的角度来看问题,如果有一个恶意攻击者输入的用户名是 zoumiaojiang’ OR 1 = 1 --,密码随意输入,就可以直接登入系统了。WFT! 冷静下来思考一下,我们之前预想的真实 SQL 语句是: SELECT FROM user WHERE username='zoumiaojiang' AND psw='mypassword' 可以恶意攻击者的奇怪用户名将你的 SQL 语句变成了如下形式: SELECT FROM user WHERE username='zoumiaojiang' OR 1 = 1 --' AND psw='xxxx' 在 SQL 中,-- 是注释后面的内容的意思,所以查询语句就变成了: SELECT FROM user WHERE username='zoumiaojiang' OR 1 = 1 这条 SQL 语句的查询条件永远为真,所以意思就是恶意攻击者不用我的密码,就可以登录进我的账号,然后可以在里面为所欲为,然而这还只是最简单的注入,牛逼的 SQL 注入高手甚至可以通过 SQL 查询去运行主机系统级的命令,将你主机里的内容一览无余,这里我也没有这个能力讲解的太深入,毕竟不是专业研究这类攻击的,但是通过以上的例子,已经了解了 SQL 注入的原理,我们基本已经能找到防御 SQL 注入的方案了。 如何预防 SQL 注入 防止 SQL 注入主要是不能允许用户输入的内容影响正常的 SQL 语句的逻辑,当用户的输入的信息将要用来拼接 SQL 语句的话,我们应该永远选择不相信,任何内容都必须进行转义过滤,当然做到这个还是不够的,下面列出防御 SQL 注入的几点注意事项: 严格限制Web应用的数据库的操作权限,给此用户提供仅仅能够满足其工作的最低权限,从而最大限度的减少注入攻击对数据库的危害 后端代码检查输入的数据是否符合预期,严格限制变量的类型,例如使用正则表达式进行一些匹配处理。 对进入数据库的特殊字符(’,",\,<,>,&,,; 等)进行转义处理,或编码转换。基本上所有的后端语言都有对字符串进行转义处理的方法,比如 lodash 的 lodash._escapehtmlchar 库。 所有的查询语句建议使用数据库提供的参数化查询接口,参数化的语句使用参数而不是将用户输入变量嵌入到 SQL 语句中,即不要直接拼接 SQL 语句。例如 Node.js 中的 mysqljs 库的 query 方法中的 ? 占位参数。 mysql.query(SELECT FROM user WHERE username = ? AND psw = ?, [username, psw]); 在应用发布之前建议使用专业的 SQL 注入检测工具进行检测,以及时修补被发现的 SQL 注入漏洞。网上有很多这方面的开源工具,例如 sqlmap、SQLninja 等。 避免网站打印出 SQL 错误信息,比如类型错误、字段不匹配等,把代码里的 SQL 语句暴露出来,以防止攻击者利用这些错误信息进行 SQL 注入。 不要过于细化返回的错误信息,如果目的是方便调试,就去使用后端日志,不要在接口上过多的暴露出错信息,毕竟真正的用户不关心太多的技术细节,只要话术合理就行。 碰到要操作的数据库的代码,一定要慎重,小心使得万年船,多找几个人多来几次 code review,将问题都暴露出来,而且要善于利用工具,操作数据库相关的代码属于机密,没事不要去各种论坛晒自家站点的 SQL 语句,万一被人盯上了呢? 命令行注入 命令行注入漏洞,指的是攻击者能够通过 HTTP 请求直接侵入主机,执行攻击者预设的 shell 命令,听起来好像匪夷所思,这往往是 Web 开发者最容易忽视但是却是最危险的一个漏洞之一,看一个实例: 假如现在需要实现一个需求:用户提交一些内容到服务器,然后在服务器执行一些系统命令去产出一个结果返回给用户,接口的部分实现如下: // 以 Node.js 为例,假如在接口中需要从 github 下载用户指定的 repoconst exec = require('mz/child_process').exec;let params = {/ 用户输入的参数 /};exec(git clone ${params.repo} /some/path); 这段代码确实能够满足业务需求,正常的用户也确实能从指定的 git repo 上下载到想要的代码,可是和 SQL 注入一样,这段代码在恶意攻击者眼中,简直就是香饽饽。 如果 params.repo 传入的是 https://github.com/zoumiaojiang/zoumiaojiang.github.io.git 当然没问题了。 可是如果 params.repo 传入的是 https://github.com/xx/xx.git && rm -rf / && 恰好你的服务是用 root 权限起的就惨了。 具体恶意攻击者能用命令行注入干什么也像 SQL 注入一样,手法是千变万化的,比如「反弹 shell 注入」等,但原理都是一样的,我们绝对有能力防止命令行注入发生。防止命令行注入需要做到以下几件事情: 后端对前端提交内容需要完全选择不相信,并且对其进行规则限制(比如正则表达式)。 在调用系统命令前对所有传入参数进行命令行参数转义过滤。 不要直接拼接命令语句,借助一些工具做拼接、转义预处理,例如 Node.js 的 shell-escape npm 包。 还是前面的例子,我们可以做到如下: const exec = require('mz/child_process').exec;// 借助 shell-escape npm 包解决参数转义过滤问题const shellescape = require('shell-escape');let params = {/ 用户输入的参数 /};// 先过滤一下参数,让参数符合预期if (!/正确的表达式/.test(params.repo)) {return;}let cmd = shellescape(['git','clone',params.repo,'/some/path']);// cmd 的值: git clone 'https://github.com/xx/xx.git && rm -rf / &&' /some/path// 这样就不会被注入成功了。exec(cmd); DDoS 攻击 DDoS 又叫分布式拒绝服务,全称 Distributed Denial of Service,其原理就是利用大量的请求造成资源过载,导致服务不可用,这个攻击应该不能算是安全问题,这应该算是一个另类的存在,因为这种攻击根本就是耍流氓的存在,「伤敌一千,自损八百」的行为。出于保护 Web App 不受攻击的攻防角度,还是介绍一下 DDoS 攻击吧,毕竟也是挺常见的。 DDoS 攻击可以理解为:「你开了一家店,隔壁家点看不惯,就雇了一大堆黑社会人员进你店里干坐着,也不消费,其他客人也进不来,导致你营业惨淡」。为啥说 DDoS 是个「伤敌一千,自损八百」的行为呢?毕竟隔壁店还是花了不少钱雇黑社会但是啥也没得到不是?DDoS 攻击的目的基本上就以下几个: 深仇大恨,就是要干死你 敲诈你,不给钱就干你 忽悠你,不买我防火墙服务就会有“人”继续干你 也许你的站点遭受过 DDoS 攻击,具体什么原因怎么解读见仁见智。DDos 攻击从层次上可分为网络层攻击与应用层攻击,从攻击手法上可分为快型流量攻击与慢型流量攻击,但其原理都是造成资源过载,导致服务不可用。 网络层 DDoS 网络层 DDos 攻击包括 SYN Flood、ACK Flood、UDP Flood、ICMP Flood 等。 SYN Flood 攻击 SYN flood 攻击主要利用了 TCP 三次握手过程中的 Bug,我们都知道 TCP 三次握手过程是要建立连接的双方发送 SYN,SYN + ACK,ACK 数据包,而当攻击方随意构造源 IP 去发送 SYN 包时,服务器返回的 SYN + ACK 就不能得到应答(因为 IP 是随意构造的),此时服务器就会尝试重新发送,并且会有至少 30s 的等待时间,导致资源饱和服务不可用,此攻击属于慢型 DDoS 攻击。 ACK Flood 攻击 ACK Flood 攻击是在 TCP 连接建立之后,所有的数据传输 TCP 报文都是带有 ACK 标志位的,主机在接收到一个带有 ACK 标志位的数据包的时候,需要检查该数据包所表示的连接四元组是否存在,如果存在则检查该数据包所表示的状态是否合法,然后再向应用层传递该数据包。如果在检查中发现该数据包不合法,例如该数据包所指向的目的端口在本机并未开放,则主机操作系统协议栈会回应 RST 包告诉对方此端口不存在。 UDP Flood 攻击 UDP flood 攻击是由于 UDP 是一种无连接的协议,因此攻击者可以伪造大量的源 IP 地址去发送 UDP 包,此种攻击属于大流量攻击。正常应用情况下,UDP 包双向流量会基本相等,因此发起这种攻击的攻击者在消耗对方资源的时候也在消耗自己的资源。 ICMP Flood 攻击 ICMP Flood 攻击属于大流量攻击,其原理就是不断发送不正常的 ICMP 包(所谓不正常就是 ICMP 包内容很大),导致目标带宽被占用,但其本身资源也会被消耗。目前很多服务器都是禁 ping 的(在防火墙在可以屏蔽 ICMP 包),因此这种攻击方式已经落伍。 网络层 DDoS 防御 网络层的 DDoS 攻击究其本质其实是无法防御的,我们能做得就是不断优化服务本身部署的网络架构,以及提升网络带宽。当然,还是做好以下几件事也是有助于缓解网络层 DDoS 攻击的冲击: 网络架构上做好优化,采用负载均衡分流。 确保服务器的系统文件是最新的版本,并及时更新系统补丁。 添加抗 DDos 设备,进行流量清洗。 限制同时打开的 SYN 半连接数目,缩短 SYN 半连接的 Timeout 时间。 限制单 IP 请求频率。 防火墙等防护设置禁止 ICMP 包等。 严格限制对外开放的服务器的向外访问。 运行端口映射程序或端口扫描程序,要认真检查特权端口和非特权端口。 关闭不必要的服务。 认真检查网络设备和主机/服务器系统的日志。只要日志出现漏洞或是时间变更,那这台机器就可能遭到了攻击。 限制在防火墙外与网络文件共享。这样会给黑客截取系统文件的机会,主机的信息暴露给黑客,无疑是给了对方入侵的机会。 加钱堆机器。。 报警。。 应用层 DDoS 应用层 DDoS 攻击不是发生在网络层,是发生在 TCP 建立握手成功之后,应用程序处理请求的时候,现在很多常见的 DDoS 攻击都是应用层攻击。应用层攻击千变万化,目的就是在网络应用层耗尽你的带宽,下面列出集中典型的攻击类型。 CC 攻击 当时绿盟为了防御 DDoS 攻击研发了一款叫做 Collapasar 的产品,能够有效的防御 SYN Flood 攻击。黑客为了挑衅,研发了一款 Challenge Collapasar 攻击工具(简称 CC)。 CC 攻击的原理,就是针对消耗资源比较大的页面不断发起不正常的请求,导致资源耗尽。因此在发送 CC 攻击前,我们需要寻找加载比较慢,消耗资源比较多的网页,比如需要查询数据库的页面、读写硬盘文件的等。通过 CC 攻击,使用爬虫对某些加载需要消耗大量资源的页面发起 HTTP 请求。 DNS Flood DNS Flood 攻击采用的方法是向被攻击的服务器发送大量的域名解析请求,通常请求解析的域名是随机生成或者是网络世界上根本不存在的域名,被攻击的DNS 服务器在接收到域名解析请求的时候首先会在服务器上查找是否有对应的缓存,如果查找不到并且该域名无法直接由服务器解析的时候,DNS 服务器会向其上层 DNS 服务器递归查询域名信息。域名解析的过程给服务器带来了很大的负载,每秒钟域名解析请求超过一定的数量就会造成 DNS 服务器解析域名超时。 根据微软的统计数据,一台 DNS 服务器所能承受的动态域名查询的上限是每秒钟 9000 个请求。而我们知道,在一台 P3 的 PC 机上可以轻易地构造出每秒钟几万个域名解析请求,足以使一台硬件配置极高的 DNS 服务器瘫痪,由此可见 DNS 服务器的脆弱性。 HTTP 慢速连接攻击 针对 HTTP 协议,先建立起 HTTP 连接,设置一个较大的 Conetnt-Length,每次只发送很少的字节,让服务器一直以为 HTTP 头部没有传输完成,这样连接一多就很快会出现连接耗尽。 应用层 DDoS 防御 判断 User-Agent 字段(不可靠,因为可以随意构造) 针对 IP + cookie,限制访问频率(由于 cookie 可以更改,IP 可以使用代理,或者肉鸡,也不可靠) 关闭服务器最大连接数等,合理配置中间件,缓解 DDoS 攻击。 请求中添加验证码,比如请求中有数据库操作的时候。 编写代码时,尽量实现优化,并合理使用缓存技术,减少数据库的读取操作。 加钱堆机器。。 报警。。 应用层的防御有时比网络层的更难,因为导致应用层被 DDoS 攻击的因素非常多,有时往往是因为程序员的失误,导致某个页面加载需要消耗大量资源,有时是因为中间件配置不当等等。而应用层 DDoS 防御的核心就是区分人与机器(爬虫),因为大量的请求不可能是人为的,肯定是机器构造的。因此如果能有效的区分人与爬虫行为,则可以很好地防御此攻击。 其他 DDoS 攻击 发起 DDoS 也是需要大量的带宽资源的,但是互联网就像森林,林子大了什么鸟都有,DDoS 攻击者也能找到其他的方式发起廉价并且极具杀伤力的 DDoS 攻击。 利用 XSS 举个例子,如果 12306 页面有一个 XSS 持久型漏洞被恶意攻击者发现,只需在春节抢票期间在这个漏洞中执行脚本使得往某一个小站点随便发点什么请求,然后随着用户访问的增多,感染用户增多,被攻击的站点自然就会迅速瘫痪了。这种 DDoS 简直就是无本万利,不用惊讶,现在大站有 XSS 漏洞的不要太多。 来自 P2P 网络攻击 大家都知道,互联网上的 P2P 用户和流量都是一个极为庞大的数字。如果他们都去一个指定的地方下载数据,成千上万的真实 IP 地址连接过来,没有哪个设备能够支撑住。拿 BT 下载来说,伪造一些热门视频的种子,发布到搜索引擎,就足以骗到许多用户和流量了,但是这只是基础攻击。 高级的 P2P 攻击,是直接欺骗资源管理服务器。如迅雷客户端会把自己发现的资源上传到资源管理服务器,然后推送给其它需要下载相同资源的用户,这样,一个链接就发布出去。通过协议逆向,攻击者伪造出大批量的热门资源信息通过资源管理中心分发出去,瞬间就可以传遍整个 P2P 网络。更为恐怖的是,这种攻击是无法停止的,即使是攻击者自身也无法停止,攻击一直持续到 P2P 官方发现问题更新服务器且下载用户重启下载软件为止。 最后总结下,DDoS 不可能防的住,就好比你的店只能容纳 50 人,黑社会有 100 人,你就换一家大店,能容纳 500 人,然后黑社会又找来了 1000 人,这种堆人头的做法就是 DDoS 本质上的攻防之道,「道高一尺,魔高一丈,魔高一尺,道高一丈」,讲真,必要的时候就答应勒索你的人的条件吧,实在不行就报警吧。 流量劫持 流量劫持应该算是黑产行业的一大经济支柱了吧?简直是让人恶心到吐,不吐槽了,还是继续谈干货吧,流量劫持基本分两种:DNS 劫持 和 HTTP 劫持,目的都是一样的,就是当用户访问 zoumiaojiang.com 的时候,给你展示的并不是或者不完全是 zoumiaojiang.com 提供的 “内容”。 DNS 劫持 DNS 劫持,也叫做域名劫持,可以这么理解,「你打了一辆车想去商场吃饭,结果你打的车是小作坊派来的,直接给你拉到小作坊去了」,DNS 的作用是把网络地址域名对应到真实的计算机能够识别的 IP 地址,以便计算机能够进一步通信,传递网址和内容等。如果当用户通过某一个域名访问一个站点的时候,被篡改的 DNS 服务器返回的是一个恶意的钓鱼站点的 IP,用户就被劫持到了恶意钓鱼站点,然后继而会被钓鱼输入各种账号密码信息,泄漏隐私。 dns劫持 这类劫持,要不就是网络运营商搞的鬼,一般小的网络运营商与黑产勾结会劫持 DNS,要不就是电脑中毒,被恶意篡改了路由器的 DNS 配置,基本上做为开发者或站长却是很难察觉的,除非有用户反馈,现在升级版的 DNS 劫持还可以对特定用户、特定区域等使用了用户画像进行筛选用户劫持的办法,另外这类广告显示更加随机更小,一般站长除非用户投诉否则很难觉察到,就算觉察到了取证举报更难。无论如何,如果接到有 DNS 劫持的反馈,一定要做好以下几件事: 取证很重要,时间、地点、IP、拨号账户、截屏、URL 地址等一定要有。 可以跟劫持区域的电信运营商进行投诉反馈。 如果投诉反馈无效,直接去工信部投诉,一般来说会加白你的域名。 HTTP 劫持 HTTP 劫持您可以这么理解,「你打了一辆车想去商场吃饭,结果司机跟你一路给你递小作坊的广告」,HTTP 劫持主要是当用户访问某个站点的时候会经过运营商网络,而不法运营商和黑产勾结能够截获 HTTP 请求返回内容,并且能够篡改内容,然后再返回给用户,从而实现劫持页面,轻则插入小广告,重则直接篡改成钓鱼网站页面骗用户隐私。能够实施流量劫持的根本原因,是 HTTP 协议没有办法对通信对方的身份进行校验以及对数据完整性进行校验。如果能解决这个问题,则流量劫持将无法轻易发生。所以防止 HTTP 劫持的方法只有将内容加密,让劫持者无法破解篡改,这样就可以防止 HTTP 劫持了。 HTTPS 协议就是一种基于 SSL 协议的安全加密网络应用层协议,可以很好的防止 HTTP 劫持。这里有篇 文章 讲的不错。HTTPS 在这就不深讲了,后面有机会我会单独好好讲讲 HTTPS。如果不想站点被 HTTP 劫持,赶紧将你的站点全站改造成 HTTPS 吧。 服务器漏洞 服务器除了以上提到的那些大名鼎鼎的漏洞和臭名昭著的攻击以外,其实还有很多其他的漏洞,往往也很容易被忽视,在这个小节也稍微介绍几种。 越权操作漏洞 如果你的系统是有登录控制的,那就要格外小心了,因为很有可能你的系统越权操作漏洞,越权操作漏洞可以简单的总结为 「A 用户能看到或者操作 B 用户的隐私内容」,如果你的系统中还有权限控制就更加需要小心了。所以每一个请求都需要做 userid 的判断 以下是一段有漏洞的后端示意代码: // ctx 为请求的 context 上下文let msgId = ctx.params.msgId;mysql.query('SELECT FROM msg_table WHERE msg_id = ?',[msgId]); 以上代码是任何人都可以查询到任何用户的消息,只要有 msg_id 就可以,这就是比较典型的越权漏洞,需要如下这么改进一下: // ctx 为请求的 context 上下文let msgId = ctx.params.msgId;let userId = ctx.session.userId; // 从会话中取出当前登陆的 userIdmysql.query('SELECT FROM msg_table WHERE msg_id = ? AND user_id = ?',[msgId, userId]); 嗯,大概就是这个意思,如果有更严格的权限控制,那在每个请求中凡是涉及到数据库的操作都需要先进行严格的验证,并且在设计数据库表的时候需要考虑进 userId 的账号关联以及权限关联。 目录遍历漏洞 目录遍历漏洞指通过在 URL 或参数中构造 …/,./ 和类似的跨父目录字符串的 ASCII 编码、unicode 编码等,完成目录跳转,读取操作系统各个目录下的敏感文件,也可以称作「任意文件读取漏洞」。 目录遍历漏洞原理:程序没有充分过滤用户输入的 …/ 之类的目录跳转符,导致用户可以通过提交目录跳转来遍历服务器上的任意文件。使用多个… 符号,不断向上跳转,最终停留在根 /,通过绝对路径去读取任意文件。 目录遍历漏洞几个示例和测试,一般构造 URL 然后使用浏览器直接访问,或者使用 Web 漏洞扫描工具检测,当然也可以自写程序测试。 http://somehost.com/../../../../../../../../../etc/passwdhttp://somehost.com/some/path?file=../../Windows/system.ini 借助 %00 空字符截断是一个比较经典的攻击手法http://somehost.com/some/path?file=../../Windows/system.ini%00.js 使用了 IIS 的脚本目录来移动目录并执行指令http://somehost.com/scripts/..%5c../Windows/System32/cmd.exe?/c+dir+c:\ 防御 方法就是需要对 URL 或者参数进行 …/,./ 等字符的转义过滤。 物理路径泄漏 物理路径泄露属于低风险等级缺陷,它的危害一般被描述为「攻击者可以利用此漏洞得到信息,来对系统进一步地攻击」,通常都是系统报错 500 的错误信息直接返回到页面可见导致的漏洞。得到物理路径有些时候它能给攻击者带来一些有用的信息,比如说:可以大致了解系统的文件目录结构;可以看出系统所使用的第三方软件;也说不定会得到一个合法的用户名(因为很多人把自己的用户名作为网站的目录名)。 防止这种泄漏的方法就是做好后端程序的出错处理,定制特殊的 500 报错页面。 源码暴露漏洞 和物理路径泄露类似,就是攻击者可以通过请求直接获取到你站点的后端源代码,然后就可以对系统进一步研究攻击。那么导致源代码暴露的原因是什么呢?基本上就是发生在服务器配置上了,服务器可以设置哪些路径的文件才可以被直接访问的,这里给一个 koa 服务起的例子,正常的 koa 服务器可以通过 koa-static 中间件去指定静态资源的目录,好让静态资源可以通过路径的路由访问。比如你的系统源代码目录是这样的: |- project|- src|- static|- ...|- server.js 你想要将 static 的文件夹配成静态资源目录,你应该会在 server.js 做如下配置: const Koa = require('koa');const serve = require('koa-static');const app = new Koa();app.use(serve(__dirname + '/project/static')); 但是如果配错了静态资源的目录,可能就出大事了,比如: // ...app.use(serve(__dirname + '/project')); 这样所有的源代码都可以通过路由访问到了,所有的服务器都提供了静态资源机制,所以在通过服务器配置静态资源目录和路径的时候,一定要注意检验,不然很可能产生漏洞。 最后,希望 Web 开发者们能够管理好自己的代码隐私,注意代码安全问题,比如不要将产品的含有敏感信息的代码放到第三方外部站点或者暴露给外部用户,尤其是前端代码,私钥类似的保密性的东西不要直接输出在代码里或者页面中。也许还有很多值得注意的点,但是归根结底还是绷住安全那根弦,对待每一行代码都要多多推敲。 请关注我的订阅号 本篇文章为转载内容。原文链接:https://blog.csdn.net/MrCoderStack/article/details/88547919。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-01-03 14:51:12
494
转载
HBase
1. 背景 当你的数据量比较多,而且又有要求响应较快的查询场景。你会如何选型? mysql、mongo、elasticsearch等完全可以,当然,你肯定不会忘了hbase。“海量数据存储”的海量,非hbase莫属。 几种常见数据库的对比如下: 2. hbase应用场景 如果你的查询场景就是根据key拿到结果,没有其它的过滤筛选条件,这就是经典的“点查”,“点查”在hbase上是非常合适的。 当然,除了hbase,还有很多适合“点查”的数据库,比如aws的dynamodb、google的bigtable。但一般公司或自用站点,还是用hbase更合适。 不用很纠结技术选型,hbase依旧非常经典,而且版本也在源源不断的迭代,适合自己的就是最好的。 3. hbase安装依赖 如果你的机器资源不足或只有一两台机器的站点,那么不建议使用hbase,因为它严格依赖hdfs存储系统和hadoop计算架构,以及zookeeper。 如果你的机器配置不高,在安装完这一些,还没安装完hbase的时候,内存就已经被占据了不少了。 4. 场景解析 本篇文章更关注于选型的探讨,不涉及原理的解析。所以当什么场景下应该会使用到hbase,我们再来回顾一下。 hbase的查询方式是通过rowkey做交互。所以,如果你的查询能够抽象为用rowkey直接获取,那么就适合用hbase查询。 这里的rowkey不仅仅是一个id或uuid,它甚至可以是几个字段组成的一个有限长度的字符串,比如“zhangsan-18-beijing”都是可以的。 但是,hbase不能带有其它的filter,比如你要过滤age<18,虽然可以使用hbase的一些协处理器实现,但性能会十分让你惊讶。性能是不好的。 所以,如果你的查询能够抽象为有意义的rowkey,那直接用hbase存储和查询是没有问题的。而且要注意rowkey的长度和散列,太长的rowkey会带来性能的损失,不具备散列特性的rowkey会带来热点问题。 5 自定义过滤下的hbase 从本篇文章的第一小节可以看到,极好的一列出现了三位选手:hbase、redis和elasticsearch 大数据情况下,或海量数据场景下,咱就先让redis休个假吧。如果你的数据较为海量,使用elasticsearch+hbase的搜索存储架构是非常好的选择。 这里引用阿里云的一篇文章:https://developer.aliyun.com/article/941191 6 总结 只有点查的场景,你只需要使用hbase。 只有搜索的场景,其实你完全可以只使用elasticsearch。 但当数据量不断扩大,而且参数搜索的字段可能只是所有字段的一部分,你不妨使用elasticsearch+hbase架构。搜索字段放elasticsearch,需要拿出来数据计算或展示的字段放hbase。各司其职,索引库+存储库分离。 索引库+存储库这个思想也不是为elasticsearch+hbase特定准备的,比如索引库你可以替换为lucene或solr,存储库可以替换为casandra或berkeleydb等都是可以的。任意两个组件都可以组合。
2024-01-27 18:28:18
559
admin-tim
MySQL
MySQL是一种很广泛应用的关系型数据库管理系统软件。在采用MySQL时,我们经常需要往要添加记录的列里写入数据。下面就介绍一下如何在MySQL中写入数据。 首先,我们需要接入到MySQL数据库,可以采用下面的代码: $conn = mysqli_connect("localhost", "username", "password", "dbname"); if (!$conn) { die("接入失败: " . mysqli_connect_error()); } 其中,localhost指接入的服务器地址,username和password分别指接入的账号和口令,dbname指接入的数据库实例。 接下来,我们需要创建执行语句,以往数据库里添加记录。简单的执行语句可以采用下面的模板: INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...); 其中,table_name指要添加记录的表格名称,column1,column2,column3, ...分别指要添加记录的字段名称,value1,value2,value3, ...分别指要添加记录的数据项。 此处为一个添加记录的示例: $sql = "INSERT INTO students (name, age, gender, class) VALUES ('张三', 18, '男', '一班')"; if (mysqli_query($conn, $sql)) { echo "新条目成功添加"; } else { echo "错误信息: " . $sql . " " . mysqli_error($conn); } 其中,students指要添加记录的表格名称,name、age、gender、class分别指要添加记录的字段名称,后面的数据项分别为'张三'、18、'男'、'一班'。 最后,我们需要关闭接入: mysqli_close($conn); 通过上面的步骤,我们可以在MySQL中往明确字段里写入数据。
2023-06-05 22:29:31
72
算法侠
MySQL
MySQL是一种普遍的关系型数据库管理系统,时常应用于构建Web应用程序。在构建或管理MySQL数据库时,时常需要查看MySQL的版本号。以下是一些方法来查找MySQL的版本号。 方法1:通过命令行查找MySQL版本号。 1. 启动终端或命令行窗口。 2. 键入命令 "mysql --version",然后按Enter键。 3. MySQL版本号将显示在命令行窗口中。 例如: $ mysql --version mysql Ver 14.14 Distrib 5.7.19, for Linux (x86_64) using EditLine wrapper 方法2:通过MySQL命令行客户端查找MySQL版本号。 1. 启动MySQL命令行客户端。 2. 键入命令 "SELECT VERSION();",然后按Enter键。 3. MySQL版本号将显示在MySQL命令行客户端中。 例如: mysql>SELECT VERSION(); +-------------------------+ | VERSION() | +-------------------------+ | 5.7.19-0ubuntu0.16.04.1 | +-------------------------+ 1 row in set (0.00 sec) 无论您选择哪种方法,从中获得的MySQL版本号都是相同的。查看MySQL版本号是一个重要的工作,因为MySQL的版本可能会改变,从而可能会引起应用程序或Web应用程序的行为也随之发生改变。
2023-10-03 21:22:15
106
软件工程师
MySQL
MySQL 是一款普遍的关联型DBMS,我们可以通过一些基础操作来看 MySQL 中的表格基本信息。 首先,我们需要登陆到 MySQL 数据库中。下面是用命令行方式登陆 MySQL 的示例脚本: mysql -h host -u user -p 其中, host 表示 MySQL 数据库服务器 IP 地址或服务器名称, user 是接入 MySQL 数据库所使用的账户名, -p 是要求输入口令,用于校验登陆。 接着,我们可以查看 MySQL 中当前所有的数据库,使用 的命令为: SHOW DATABASES; 然后,我们需要选择一个数据库进行操作,使用的命令为: USE database; 其中, database 表示需要操作的数据库名称。 现在,我们已经成功进入到了 MySQL 数据库中,可以看到库中的表格基本信息,使用命令如下: SHOW TABLES; 执行该命令后,MySQL 将会显示该库中所有的表名称。 最后,我们可以查看特定表中的所有信息,使用的命令如下: DESCRIBE table; 其中, table 表示需要查看的表名称。 通过上述基础操作,我们可以轻松地了解 MySQL 数据库中的基础表信息。
2023-08-18 09:15:20
64
算法侠
MySQL
关系型数据库管理系统 , 关系型数据库管理系统(RDBMS)是一种基于关系模型的数据库管理系统,它以表格的形式存储数据,并通过预定义的关系或键将这些表格连接起来。在MySQL中,这种系统允许用户使用结构化查询语言(SQL)对数据进行操作,如插入、更新、删除和查询记录。其特点是数据结构化强、易于理解且支持事务处理。 Web应用程序 , Web应用程序是一种可以通过互联网访问的应用程序,通常由客户端(浏览器)和服务器端两部分构成。用户通过浏览器向服务器发送请求,服务器则运行相应的程序并返回HTML、CSS、JavaScript等构建的动态网页给客户端。MySQL作为后台数据库,可以为Web应用程序提供数据存储和检索服务,例如存储用户信息、产品列表、订单数据等。 SQL语法 , SQL(Structured Query Language)是用于管理关系型数据库的标准计算机语言。在MySQL中,SQL语句用于执行各种数据库操作,包括创建表、插入数据、更新记录、删除数据以及从数据库中检索信息等。例如,MySQL中的插入数据语句“INSERT INTO table_name (column1, column2,...) VALUES (value1, value2,...)”就是遵循SQL语法,用于将新行数据插入到指定表中的特定字段。
2023-09-26 10:25:10
68
编程狂人
MySQL
MySQL是一种普遍的关联式数据库,许多应用软件都要选用它。在特定情境下,你可能需要从异地服务端连接MySQL数据库。本文将向你介绍如何检查MySQL是否支持异地访问。 要检查MySQL是否支持异地访问,需要连接MySQL服务端。然后,选用以下步骤: $ mysql -u用户名 -p密码 Enter password: mysql>use mysql; mysql>SELECT host, user FROM user WHERE host != 'localhost'; 代码中的第一个命令是接入MySQL服务端。将用户名和密码替换为你的登录信息。在输入密码后,你将进入MySQL的终端界面。在此界面下,运行以下步骤: 第1步: use mysql; 上述命令将选用MySQL的自带mysql数据库。 第2步: SELECT host, user FROM user WHERE host != 'localhost'; 上述命令将检索MySQL的user表,它包括所有用户的信息。在显示结果中,你将看到近似以下的结果: +-----------+------------------+ | host | user | +-----------+------------------+ | localhost | root | | 127.0.0.1 | root | | ::1 | root | | % | your_username | +-----------+------------------+ 一般情况下,你会看到像上面那个表格数据的显示结果。这意味着你可以从任何异地服务端连接MySQL服务端。 如果host列只有'localhost',这意味着MySQL不支持从异地服务端连接。你可以选用以下命令修改这个设置: GRANT ALL PRIVILEGES ON . TO 'your_username'@'%' IDENTIFIED BY 'your_password' WITH GRANT OPTION; 上述命令将your_username赋予连接MySQL服务端的所有许可权。请将your_username和your_password替换为你自己的登录信息。 最后,你可以重复运行之前的命令,确保host列包括'%'。
2023-12-17 16:15:36
63
数据库专家
MySQL
...中,我们频繁需求输出MySQL资料库的架构和备注数据。但是MySQL预设条件下不一定会输出备注数据,这给我们的研制带来不便。下面我们将介绍如何输出MySQL资料库备注。 步骤如下: 1.使用以下命令登录到MySQL命令行终端: mysql -u root -p 2.选择需求输出备注的资料库: use database_name; 3.执行以下命令查看当前表的备注数据: SHOW TABLE STATUS; 4.执行以下命令输出含有备注的SQL架构: mysqldump -h localhost -u root -p --skip-comments -d database_name >file.sql 其中,-d表示只输出架构,不包含数据;--skip-comments表示跳过备注数据,避免备注被过滤掉;file.sql为输出的文件名,可以根据需求自行设置。 通过以上操作,我们就可以成功地输出MySQL资料库含有备注的SQL架构了。注意,如果需求输出数据,可以将-d替换为--extended-insert,输出的SQL文件会包含数据和备注数据。
2023-03-21 16:29:33
108
电脑达人
MySQL
MySQL是一种普遍的关联型DBMS,它被广泛使用在工业实时数据管理中。 MySQL的优势在于它的稳定性和高效能。使用者可以使用SQL语言进行表的建立、更改、移除、检索等操作,而MySQL会自动地进行改进和运行。 CREATE TABLE example ( id int(11) NOT NULL AUTO_INCREMENT, name varchar(255) NOT NULL, age int(11) NOT NULL, gender varchar(16) NOT NULL, PRIMARY KEY (id) ); MySQL还支持多种不同的数据存储引擎,包括InnoDB、MyISAM、Memory等。每种存储引擎有其各自的优缺点,使用者可以根据需要进行选择和配置。 SHOW ENGINES; 在工业实时数据管理中,MySQL的主要使用场景包括数据采集、生产监控、质量控制、故障诊断等。使用者可以通过对MySQL的数据表进行操作,快速地获取到所需的数据并进行实时分析和处理。 总结来说,MySQL是一种可靠、高效的工业实时数据库,可以为使用者提供完善的数据管理和分析功能。
2024-02-07 16:13:02
55
逻辑鬼才
MySQL
在深入理解了如何使用MySQL的COUNT函数统计一列数据个数的基础上,进一步探讨数据库管理与数据分析的实际应用。近期,随着大数据和云计算技术的发展,数据库优化与深度统计分析的需求日益凸显。例如,在电商领域,企业需要精准统计用户行为数据以优化商品推荐策略;而在金融行业,实时统计交易数据对风险控制至关重要。 实际工作中,除了基本的计数操作,MySQL还提供了GROUP BY、HAVING等高级功能,结合COUNT函数可用于实现更复杂的业务逻辑,如按类别统计商品销售数量、筛选出特定条件下的用户活跃度等。另外,对于海量数据处理,可以借助于诸如分区表、索引优化等技术手段提升COUNT查询性能。 值得注意的是,现代数据库系统如Google BigQuery、Amazon Redshift等云数据库服务,不仅提供了对大规模数据高效计算COUNT值的能力,还支持SQL标准的扩展特性,便于进行更深层次的数据挖掘和分析工作。因此,掌握MySQL统计函数的同时,紧跟行业发展趋势,了解并熟练运用新型数据库技术,是当前数据从业者提高工作效率、满足业务需求的重要路径。
2023-03-09 20:28:54
148
诗和远方_t
MySQL
何为MySQL服务 MySQL是一种普遍的关联型DBMS,它使用SQL语言来检索、添加、修改和移除数据。MySQL服务是指在本地计算机上运行的一个MySQL例子,允许用户在命令行和其他客户端应用程序中访问和管控数据。 装配MySQL服务 在开启MySQL服务之前,您需要先装配MySQL安装包。您可以从MySQL官方网站获取适合您系统软件版次的安装包,并按照指示运行装配向导。装配完成后,您将获得一个MySQL服务器并可以开始开启服务。 开启MySQL服务 使用Windows的用户可以通过打开命令提示符(cmd)程序来开启MySQL服务。在开始菜单的搜索栏中输入“cmd”,然后选择打开程序。在命令提示符窗口中,输入以下命令: net start mysql 按下回车键后,MySQL服务将开始运行,您现在可以通过其他客户端应用程序(如MySQL Workbench)访问数据库。 关闭MySQL服务 有时候您需要关闭MySQL服务。在命令提示符窗口,输入以下命令: net stop mysql 按下回车键后,MySQL服务将停止运行。在您需要再次使用MySQL服务时,需要再次以相同方式开启服务。 总结 通过在命令提示符窗口输入简单的命令,您可以轻松开启和停止MySQL服务。如果您有其他需要处理的数据库任务,可以使用客户端数据库管控软件(如MySQL Workbench)来运行更高级的操作。MySQL服务是非常有用的工具,在适当的配置和使用下,可以帮助您轻松管控和处理大量的数据。
2023-04-15 17:10:20
128
键盘勇士
MySQL
关系型数据库管理系统 , 关系型数据库管理系统(RDBMS)是一种基于关系模型的数据库管理系统,它通过表格、行和列的形式组织数据,并利用SQL(Structured Query Language)语言进行数据查询、更新等操作。在MySQL中,数据以表的形式存储,各个表之间可以建立关联,形成复杂的数据关系网络,以此实现高效、可靠的数据管理。 SQL语言 , SQL(Structured Query Language)是一种用于管理关系数据库的标准计算机编程语言,包括数据查询、数据插入、更新和删除以及数据库结构管理等功能。在MySQL环境中,用户可以使用SQL语句创建、修改或删除数据库及其中的表结构,同时也可以对数据进行复杂的检索、排序、统计与聚合操作。 mysqldump命令 , mysqldump是MySQL提供的一种用于备份数据库的重要工具,它可以将MySQL数据库中的所有数据和表结构生成为一个可移植的SQL脚本文件。通过执行mysqldump命令,用户能够完整地备份整个数据库或者部分特定的数据库表,便于在数据丢失或需要恢复时快速还原到某个时间点的状态,确保数据的安全性和完整性。例如,在MySQL中,用户可以通过命令行运行mysqldump命令,指定要备份的数据库名和其他相关参数来完成备份任务。
2023-02-05 14:43:17
74
程序媛
Mongo
...、文档型的NoSQL数据库,它以JSON-like格式存储数据,支持水平扩展和高可用性。在本文中,MongoDB被用于高效处理和查询地理位置信息,提供了丰富的地理位置索引和查询操作符。 GeoJSON , GeoJSON是一种基于JSON的标准格式,用于编码地理空间数据。在MongoDB 4.2版本及后续版本中,GeoJSON得到了原生支持,使得用户可以更加灵活且标准地存储和查询包含点、线、多边形等地理要素的数据。 $geoWithin操作符 , 在MongoDB中,$geoWithin是针对地理位置查询的一种查询操作符。当对集合中的文档执行查询时,若文档中的地理位置字段满足特定几何形状范围(如圆形、矩形或多边形)条件,则该文档会被返回。例如,在文章中提到,通过$geoWithin配合$centerSphere子句,可以找到距离指定坐标一定半径内的所有记录。 $near操作符 , $near是MongoDB中用于地理位置查询的另一个重要操作符,它可以查找与指定点最近的文档,并按照距离进行排序。结合$geometry参数和$maxDistance参数,可以实现搜索给定经纬度坐标附近一定距离内的数据点,并按距离远近排列结果。 地理位置索引(Geospatial Indexes) , 在MongoDB中,地理位置索引是对存储的地理位置数据建立的一种特殊索引类型,它允许数据库对包含地理位置信息的字段进行高效的查询操作。通过创建地理位置索引,MongoDB能够快速检索出符合特定地理位置条件的文档,极大地提高了地理数据处理效率。
2023-07-13 14:14:37
40
梦幻星空-t
JSON
...SON 是一种小型的数据交换格式,在前端和后端编程中都被广泛应用。在编程过程中,我们经常需求根据某个前提检索 JSON 中的数据。然而,对于大型 JSON 数据,检索效能可能会成为一个重要的难题。下面我们来对比一下不同的检索方式在效能上的差别。 首先,我们以一个基础的 JSON 数据为例: { "users": [ { "id": 1, "name": "Alice", "age": 30 }, { "id": 2, "name": "Bob", "age": 25 }, { "id": 3, "name": "Charlie", "age": 35 } ] } 接下来,我们将应用三种不同的方式来检索这个 JSON 数据中年龄大于等于 30 的用户: (1)应用 for 循环循环 JSON 数据,检索符合前提的数据: const users = data.users; const result = []; for (let i = 0; i< users.length; i++) { if (users[i].age >= 30) { result.push(users[i]); } } (2)应用数组的 filter() 方式来筛选符合前提的数据: const users = data.users; const result = users.filter(user =>user.age >= 30); (3)应用 jsonpath 来检索符合前提的数据: const jsonpath = require('jsonpath'); const result = jsonpath.query(data, '$..[?(@.age >= 30)]'); 通过在相同的硬件前提下试验,我们得到了以下结论: (1)for 循环循环在加工 100000 条数据时需求 5.84 秒。 (2)数组的 filter() 方式在加工同样数目的数据时需求 1.55 秒。 (3)jsonpath 在同样的数据量下仅需 0.46 秒。 通过以上试验结论可以看出,应用 JSONPath 需求的耗时最少,其次是 filter() 方式,最慢的是 for 循环循环。当需求加工海量 JSON 数据时,在效能方面应用 JSONPath 会是最佳的选择。
2023-09-15 23:03:34
486
键盘勇士
MySQL
关系型数据库管理系统 , 关系型数据库管理系统是一种以表格形式存储数据,并使用结构化查询语言(SQL)进行交互的软件系统。在MySQL中,这种系统将数据组织成一系列相互关联的表格,通过预定义的关系或键来建立这些表格之间的联系,确保数据的一致性和完整性。用户可以通过执行SQL语句对数据进行增删改查等操作。 主键 , 在MySQL的表格设计中,主键是一个或一组列,其值能够唯一标识表中的每一行记录。例如,在上述customers表格中,id字段被定义为主键,它具有自动递增属性,这意味着每当新增一行记录时,系统会自动为该字段赋予一个唯一的、大于已有记录的数值,从而保证了每条客户记录的唯一性。 自动递增 , 自动递增是MySQL中主键的一种特殊属性。当某个字段被标记为自动递增(AUTO_INCREMENT),在插入新记录时不需手动指定该字段的值,MySQL会自动为该字段分配下一个可用的唯一整数值。比如在创建customers表格时,id字段设置为自动递增,每次插入新客户信息时,系统会自动为新记录分配一个比现有记录更大的id值,确保了主键字段的唯一性和连续性。 INSERT INTO 语句 , 在MySQL中,INSERT INTO 是用于向表格中添加新记录的关键SQL语句。它允许用户指定要插入数据的表格名称以及相应的列名和对应值。例如,INSERT INTO customers (first_name, last_name, email, age) VALUES ( John , Doe , john@example.com , 30 )这条语句会在customers表格中插入一条包含姓名、电子邮件和年龄的新客户记录。 SELECT 语句 , SELECT 是MySQL中用于从数据库表格中检索数据的核心SQL命令。通过编写不同的SELECT语句,可以实现对表格中数据的不同筛选、排序和组合需求。如 SELECT FROM customers; 这条语句表示从customers表格中选择所有列的所有记录,返回整个表格的内容。 DROP TABLE 语句 , 在MySQL中,DROP TABLE 是一种DDL(数据定义语言)命令,用于删除不再需要的数据库表格及其所有相关数据。例如,执行 DROP TABLE customers; 将永久删除名为customers的表格,包括其中的所有客户记录,这个操作不可逆,所以在执行前应确保已备份重要数据或确实不需要该表格。
2023-01-01 19:53:47
73
代码侠
MyBatis
...用技巧外,了解最新的数据库优化技术和行业动态也至关重要。近日,随着云原生技术的发展,许多数据库服务提供商如阿里云、AWS等正积极推出与MyBatis兼容并针对批量操作深度优化的产品特性。 例如,阿里云RDS MySQL版已支持批处理执行计划功能,可以显著提升包括批量插入在内的大批量数据操作性能。通过智能分析SQL模式,实现对批量DML语句的合并执行,有效减少网络传输开销和数据库引擎内部的并发控制成本,进一步提高整体系统的吞吐量。 此外,在企业级应用开发中,结合MyBatis-Plus等增强工具集,开发者能够更加便捷地进行批量插入以及其他复杂操作,同时这些工具集也提供了更强大的插件机制,可无缝接入自定义拦截器,确保在进行高效数据操作的同时,满足日志记录、权限控制等多样化业务需求。 因此,对于持续追求高效率、高性能数据库操作的技术人员来说,关注数据库技术前沿动态,深入理解并灵活运用MyBatis框架及其周边生态工具,无疑将大大提升项目实施的成功率和系统的稳定性。
2023-10-03 13:28:23
117
林中小径_t
PostgreSQL
...L是一种开源的关系型数据库管理系统,支持SQL标准并提供了丰富的特性集,如事务处理、视图、触发器和复杂的查询语言等。在本文中,它被用来演示如何创建不同类型的索引以提升数据检索性能。 索引(Index) , 在数据库系统中,索引是一种特殊的数据结构,通常用于加速对表中数据的检索速度。就像图书目录可以帮助读者更快地定位到具体页码一样,数据库索引能帮助查询引擎快速找到符合条件的数据行,从而显著提高查询效率。 唯一性索引(Unique Index) , 在PostgreSQL等数据库系统中,唯一性索引是一种特殊的索引类型,用于确保指定列中的数据具有唯一性,不允许出现重复值。创建唯一性索引后,如果试图插入或更新与现有索引键相同的数据,数据库将抛出错误,以此来保证数据的一致性和完整性。例如,在用户表的email列上创建唯一性索引,可以避免同一电子邮件地址对应多个账户的情况发生。
2023-11-16 14:06:06
486
晚秋落叶_t
MySQL
MySQL , MySQL是一种广泛使用的关系型数据库管理系统(RDBMS),采用SQL结构化查询语言进行数据操作。在现代互联网和移动应用开发中,MySQL因其开源、稳定、高效和可扩展性等特点而被广泛应用,支持多用户访问控制、事务处理、安全备份以及与其他系统的高度兼容性。 数据同步 , 数据同步是指在多个数据库或数据存储系统之间保持数据一致性的过程。在手机MySQL管理工具如Navicat for MySQL中,数据同步功能能够让用户实现不同MySQL服务器间的数据实时更新或者按计划任务更新,确保所有相关系统中的数据时刻保持最新状态,减少数据冗余和不一致的风险。 数据迁移 , 数据迁移是指将一个数据库中的数据转移到另一个数据库的过程,通常在数据库升级、系统重构或者跨平台迁移时发生。在本文提到的手机MySQL管理工具中,数据迁移功能可以方便地帮助开发者将MySQL数据库从一个环境迁移到另一个环境,比如从开发环境迁移到生产环境,或者在不同的MySQL版本之间迁移数据。 关系型数据库管理系统(RDBMS) , 关系型数据库管理系统是一种建立在关系模型基础上的数据库管理系统,它以表格的形式存储数据,并通过预定义的数据结构和关系来组织数据。在MySQL中,数据以表的形式存在,各表之间可以通过设定键值关联形成复杂的逻辑关系,便于数据检索、更新和管理。 手机MySQL管理工具 , 这类工具是专为移动设备设计的数据库管理软件应用程序,允许开发人员在智能手机或平板电脑上远程连接并管理MySQL数据库。它们通常提供数据查询、编辑、报表生成、备份恢复、权限管理等一系列与MySQL数据库相关的功能,旨在提升开发团队在移动办公场景下的数据管理效率和协作能力。
2024-01-03 20:49:40
142
数据库专家
MySQL
...个非常实用的功能——MySQL数据库的排序功能。在我们每天的日常工作中,甭管是做数据分析还是捣鼓系统设计,都免不了要和大量的数据打交道,尤其是排序这一步必不可少。这时候,MySQL就是咱们的一大神器,它能帮我们飞快又准确地搞定这个难题,让数据乖乖听话,排好队列。接下来,我们就一起学习一下怎么根据MySQL数据库进行排序吧。 二、MySQL基本排序语法 首先,我们要了解的是MySQL的基本排序语法。在MySQL中,我们可以使用ORDER BY语句来对查询结果进行排序。其基本语法如下: sql SELECT column1, column2, ... FROM table_name ORDER BY column1 [ASC|DESC], column2 [ASC|DESC], ...; 其中,column1, column2等是我们想要排序的列名,table_name是我们想要查询的数据表名。而ASC表示升序排列,DESC则表示降序排列。 让我们通过一个简单的例子来看看这个语法是如何使用的。假设我们有一个用户表,其中包含用户的ID、姓名和年龄三列。现在我们想要按照年龄从小到大对用户进行排序,应该如何操作呢? sql SELECT ID, NAME, AGE FROM USER ORDER BY AGE ASC; 这样,我们就可以得到一个按照年龄从小到大排序的用户列表了。 三、多列排序 如果我们想要对多列进行排序,只需要在ORDER BY子句中加入更多的列名即可。例如,如果我们还想再按照姓名进行排序,那么我们的SQL语句就会变成这样: sql SELECT ID, NAME, AGE FROM USER ORDER BY AGE ASC, NAME ASC; 这样,我们就可以先按照年龄进行排序,然后再在同一年龄的用户中按照姓名进行排序了。 四、特殊字符排序 在实际应用中,我们常常需要对字符串进行排序。这个时候,咱们得留心了,如果不特意去处理一下,MySQL这家伙可会按照字母表顺序对字符串进行排序,而这很可能并不是咱们期望的结果。为了克服这个问题,我们可以使用函数来对字符串进行特殊处理。例如,我们可以使用UCASE函数将所有字符串转换为大写,然后再进行排序: sql SELECT ID, NAME, AGE FROM USER ORDER BY UCASE(NAME) ASC, AGE ASC; 这样,我们就可以保证所有的姓名都是按照字母表顺序进行排序的了。 五、NULL值排序 在实际应用中,我们还常常需要对包含NULL值的数据进行排序。这时候,千万要注意了哈,MySQL这家伙有个默认习惯,就是会把NULL值当作小尾巴,统统放在非NULL值的后面。如果你想让NULL值率先出场,那你就得在ORDER BY这个排序句子里头加个特殊的小条件。例如,我们可以使用IS NULL函数来判断是否为空,然后将其放在列名的前面: sql SELECT ID, NAME, AGE FROM USER ORDER BY AGE ASC, (CASE WHEN NAME IS NULL THEN 1 ELSE 0 END) ASC; 这样,我们就可以保证NULL值总是被排在最前面了。 六、总结 总的来说,MySQL提供了丰富的排序功能,可以帮助我们快速有效地对大量数据进行排序。在实际操作中,咱们得瞅准具体需求,灵活选择最合适的排序方法。同时呢,千万记得要避开那些时常冒泡的常见错误陷阱。只要掌握了这些基础知识,我们就能够在MySQL的世界里游刃有余了。
2023-05-16 20:21:51
58
岁月静好_t
MySQL
加入数据入MySQL的流程 MySQL是一种广泛使用的关系型资料库,用于处理大量的数据和交易。在使用MySQL时,我们经常需要往资料库中加入数据。下面是使用MySQL加入数据的流程。 链接资料库 加入数据前,我们需要首先运行MySQL用户端并链接到资料库。使用以下代码可以链接到MySQL资料库: $ conn = mysqli_connect ($ servername,$ username,$ password,$ dbname); 其中,$ servername是MySQL服务端的名称,$ username是我们的资料库账号,$ password是我们的资料库口令,$ dbname是我们要链接的资料库的名称。 选定表格 在链接到资料库后,我们需要选定要加入数据到的表格。使用以下代码可以选定要加入数据的表格: $ sql = “SELECT FROM customers”; $ result = mysqli_query ($ conn,$ sql); 这段代码中,“customers”是我们选定的表格的名称。使用mysqli_query函数,我们可以检索表格的内容并将显示保存在参数$result中。 加入数据 完成以上流程后,我们可以开始加入数据。使用以下代码可以向表格中加入添加数据: $ sql = “INSERT INTO customers (name,email,phone) VALUES ('John Doe','johndoe@example.com','555-555-5555')”; 在这个示例中,我们向名为“customers”的表格加入三个新数据:姓名为“John Doe”,电子邮箱为“johndoe@example.com”,电话号码为“555-555-5555”。 使用mysqli_query函数可以将SQL检索发送到资料库服务端,并运行检索。 展示显示 最后,我们需要展示添加数据。使用以下代码可以显示已加入的添加数据: if ($ result->num_rows>0) { // 显示数据 while ($ row = $ result->fetch_assoc ()) { echo “Name:”。$ row [“name”]。” - Email:”。$ row [“email”]。” - Phone:”。$ row [“phone”]。”\ n”; } } else { echo “暂无显示”; } 在这个示例中,我们使用while循环循环遍历新加入的数据,并通过echo语句输出每条数据的姓名、电子邮箱和电话号码。 总结 使用以上流程,我们可以成功地向MySQL资料库中加入添加数据,以及正确地展示添加数据。将此过程反复实践,您就可以轻松地加入和管理数据,从而更好地利用MySQL资料库的功能。
2024-02-04 16:16:22
70
键盘勇士
Java
...碰到需要根据多个ID检索账号和口令的情况。这时候可以采用多种方法实现。 一个常用手段是采用Map来保存ID和相应的的账号口令数据,然后采用foreach循环逐个检索。 Map<String,String> userMap = new HashMap<>(); userMap.put("id1","username1:password1"); userMap.put("id2","username2:password2"); userMap.put("id3","username3:password3"); List<String> ids = new ArrayList<>(); ids.add("id1"); ids.add("id2"); ids.add("id3"); for(String id : ids){ String userData = userMap.get(id); String[] userInfo = userData.split(":"); String username = userInfo[0]; String password = userInfo[1]; System.out.println("ID "+id+": username="+username+"\t password="+password); } 上述代码中,我们首先将ID和相应的的用户信息存在Map中。然后我们把需要检索的ID加入一个List中,然后采用foreach循环逐个检索Map中相应的的数据,并且将数据按照“账号:口令”的模式分割,最终打印账号和口令。 另外,如果用户信息量过大,我们也可以采用数据库进行检索。下面是一个采用JDBC从MySQL数据库中检索数据的示例代码。 String url = "jdbc:mysql://localhost:3306/userdb"; String user = "root"; String password = "123456"; List<String> ids = new ArrayList<>(); ids.add("id1"); ids.add("id2"); ids.add("id3"); Connection conn = null; PreparedStatement ps = null; ResultSet rs = null; try{ conn = DriverManager.getConnection(url,user,password); String sql = "SELECT username,password FROM user WHERE id=?"; ps = conn.prepareStatement(sql); for(String id:ids){ ps.setString(1,id); rs = ps.executeQuery(); while(rs.next()){ String username = rs.getString("username"); String password = rs.getString("password"); System.out.println("ID "+id+": username="+username+"\t password="+password); } } }catch(SQLException e){ e.printStackTrace(); }finally{ try{ if(rs!=null){ rs.close(); } if(ps!=null){ ps.close(); } if(conn!=null){ conn.close(); } }catch(SQLException e){ e.printStackTrace(); } } 上述代码首先建立了与数据库的连接,然后采用PrepareStatement对象配置查询的SQL语句。在foreach循环中,我们通过配置PreparedStatement的参数并执行SQL查询获取查询结果,然后循环遍历结果集,打印账号和口令。 总之,不管是采用Map还是JDBC建立数据库连接,都可以通过Java实现根据多个ID检索账号和口令的功能。
2023-10-25 12:49:36
342
键盘勇士
PostgreSQL
...PostgreSQL数据库中广泛使用的一种索引类型,它以一种自平衡的树状结构组织数据。在查询时,B-tree索引可以快速定位到满足条件的数据行,特别适合于范围查询和精确匹配操作,能够显著提高查询性能。在文章语境中,创建B-tree索引意味着在特定列上建立这种高效查找结构,以便更快地检索和排序数据。 GiST索引 , Generalized Search Tree(通用搜索树)索引是PostgreSQL支持的一种可扩展索引框架,允许开发人员为不同类型的数据创建定制化的索引方法。GiST索引尤其适用于复杂的数据类型,如地理空间数据或文本搜索,通过提供对这些特殊数据类型的优化搜索能力,进一步提升查询效率。在本文中提及GiST索引,旨在说明不同索引类型在处理特定数据场景时的优势与适用性。 索引类型 , 在数据库管理系统中,索引类型指的是用于存储和检索数据的不同策略或结构。例如,PostgreSQL支持多种索引类型,包括但不限于B-tree、哈希、GiST、SP-GiST和GIN等。每种索引类型都有其独特的优缺点和适用场景,选择合适的索引类型对于优化查询性能至关重要。在文章的上下文中,创建“可以显示值的索引”实际上是指根据需求选择恰当的索引类型来提高特定列的查询速度。
2023-11-30 10:13:56
262
半夏微凉_t
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
journalctl -u service_name
- 查看特定服务的日志。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"