首页 > 其他分享 >《Web安全基础》01. 基础知识

《Web安全基础》01. 基础知识

时间:2023-05-26 11:23:26浏览次数:54  
标签:后门 Web 01 请求 数据库 基础知识 漏洞 域名

目录


这里只是起跑线而不是终点线。

1:概念名词

1.1:域名

  • 什么是域名

域名是用于标识 IP 地址的字符串。它用于将易于记忆的名称与 IP 地址相关联。

  • 域名在哪里注册

域名可以在许多互联网注册机构注册(如 GoDaddy、阿里云、腾讯等)。这些注册机构充当域名的托管人,并向公众出售域名。

  • 什么是二级域名或多级域名

二级域名和多级域名是基于域名的层次结构而产生的。

二级域名分为两种。

在国际顶级域名下的二级域名
国际顶级域名下二级域名,一般是指域名注册人选择使用的网上名称,如 “ yahoo.com ” ;
上网的商业组织通常使用自己的商标、商号或其他商业标志作为自己的网上名称,如 “ microsoft.com ” 。

国家顶级域名下二级域名
一般是指类似于国际顶级域名的表示注册人类别和功能的标志。例如,在 “ .com.cn ” 域名结构中,“ .com ” 此时是置于国家顶级域名 “ .cn ” 下的二级域名,表示商业性组织,以此类推。

  • 域名发现对于安全测试意义

在安全测试中,域名发现是指寻找与目标网站相关的所有域名。
这些域名可能包括子域名、备用域名、相关域名等。

域名发现可以揭示潜在的攻击面,可以帮助安全测试人员发现可能存在的漏洞和安全问题。

1.2:DNS

  • 什么是 DNS

DNS(Domain Name System)是一个用于将域名转换为 IP 地址的系统。这个过程被称为域名解析

DNS 使用 UDP 端口 53。对于每一级域名长度的限制是 63 个字符,域名总长度则不能超过 253 个字符。

  • 本地 HOSTS 与 DNS 的关系

本地 HOSTS 文件是一个本地的域名-IP地址映射文件。当计算机需要访问特定的域名时,它会首先查找本地 HOSTS 文件,以确定该域名对应的IP地址。如果本地 HOSTS 文件中没有该域名的映射,则计算机将向 DNS 服务器发送查询以获得 IP 地址。

Hosts 文件路径:C:\Windows\System32\drivers\etc\hosts

  • CDN 是什么

CDN(Content Delivery Network)是构建在数据网络上的一种分布式的内容分发网。是一个由多个服务器组成的网络,用于提供快速可靠的内容传递服务。
CDN 通过将内容存储在靠近用户的服务器上,以加速用户访问网站和应用程序的速度。

  • CDN 与 DNS 的关系

CDN 使用 DNS 来解析访问网站或应用程序所需内容的 IP 地址,并根据用户的位置选择最近的服务器来提供内容。

  • 常见的 DNS 安全攻击有哪些

常见的 DNS 安全攻击包括 DNS劫持、域名劫持、缓存投毒和 DDoS 攻击。

1.3:网站开发语言

  • 常见的网站开发语言有哪些

asp、php、aspx、jsp、java、javascript、python、ruby 等

  • 不同网站开发语言与安全漏洞的关系

关系比较复杂。安全漏洞可能与语言特定的漏洞有关,也可能与编程人员的错误或不安全实践有关。

  • 漏洞挖掘、代码审计与不同网站开发语言的关系

漏洞挖掘和代码审计都需要理解不同语言的语法和特定的漏洞类型,并使用适当的工具和技术来识别和纠正潜在的安全问题。

1.4:后门

  • 什么是后门

后门(Backdoor)是植入到系统或应用程序中的一种特殊代码或程序方法,以便攻击者绕过安全性控制,从而获取应用或系统的访问权。

在软件的开发阶段,程序员常常会在软件内创建后门程序以便可以修改程序设计中的缺陷。

  • 有那些后门

常见的后门类型:后门用户账号、后门服务、后门脚本、后门漏洞

  • 后门在安全测试中的实际意义

安全测试中,安全测试人员需要通过使用各种技术和工具来识别和验证是否存在后门,以便在攻击者之前发现和修复安全漏洞。

  • 关于后门需要了解哪些

需要了解攻击者通常会利用后门访问系统来获取敏感信息、篡改数据、窃取证书、加密文件等。
此外,攻击者还可能使用各种技术和工具来免杀后门与隐藏后门,或通过零日漏洞等未知漏洞来绕过安全控制。

1.5:Web

  • Web 的组成架构模型

网站源码:分为脚本类型,分为应用方向
操作系统:windows、linux
中间件(Web搭建平台):apache iis tomcat nginx 等
数据库:access、mysql、oracle、sybase 等

  • 架构漏洞安全测试简要介绍

架构漏洞指在系统设计或实现中存在的潜在安全问题。

架构漏洞安全测试主要包括:系统架构分析、模拟攻击、风险评估、测试报告编写。

  • 为什么要从 Web 层面为主为首

原因:
Web 应用通常是面向公众的,具有高度可访问性,易受攻击。
Web 网站漏洞相对较多,便于入侵服务器。
Web 作为跳板深入到其他资源相对容易。

1.6:Web 相关安全漏洞

  • Web 源码类漏洞

SQL 注入,文件上传,XSS,代码执行,变量覆盖,逻辑漏洞,反序列化等

  • Web 中间件漏洞

未授权访问,变量覆盖

  • 数据库漏洞

弱口令,权限提升

  • 系统层漏洞

提权,远程代码执行

  • 第三方应用漏洞
  • APP 或 PC 应用结合类

2:数据包

2.1:HTTP

HTTP 协议运行在 TCP 之上,所有传输内容都是明文。端口:80

HTTP 简要通信过程

  1. 浏览器建立与 web 服务器之间的连接。
  2. 浏览器将请求数据打包(生成请求数据包)并发送到 web 服务器。
  3. web 服务器将处理结果打包(生成响应数据包)并发送给浏览器。
  4. 关闭连接。

2.2:HTTPS

HTTPS 运行在 SSL/TLS 之上,SSL/TLS 运行在 TCP 之上,所有传输的内容都经过加密。端口:443

HTTPS 简要通信过程

在这里插入图片描述

HTTPS 协议需要到 CA 申请证书,一般免费证书很少,需要交费。

2.3:请求数据包

详见《网络协议从入门到底层原理》系列。这里只简单介绍。

2.3.1:Request 请求

HTTP 规划定义了 8 种可能的请求方法:

请求方法 含义
GET 检索 URL 中标识资源的一个简单请求
HEAD 与 GET 方法相同,但服务器只返回状态行和头标,并不返回请求文档
POST 服务器接受被写入客户端输出流中的数据的请求
PUT 服务器保存请求数据作为指定 URL 新内容的请求
DELETE 服务器删除 URL 中命令的资源的请求
OPTIONS 关于服务器支持的请求方法信息的请求
TRACE web 服务器反馈 Http 请求和其头标的请求
CONNECT 已文档化,但当前未实现的一个方法,预留做隧道处理

请求头由 关键字/值 组成,每行一对,关键字和值用冒号分隔:

请求头 含义
Host 主机或域名地址
Accept 指浏览器或其他客户可以接爱的 MIME 文件格式。Servlet 可以根据它判断并返回适当的文件格式
User-Agent 客户浏览器名称
Accept-Langeuage 指出浏览器可以接受的语言种类
Connection 用来告诉服务器是否可以维持固定的 HTTP 连接
Cookie 浏览器用这个属性向服务器发送 Cookie
Referer 表明产生请求的网页 URL。这个属性可以用来跟踪 Web 请求是从什么网站来的
Content-Type 用来表名 request 的内容类型
Accept-Charset 指出浏览器可以接受的字符编码
Accept-Encoding 指出浏览器可以接受的编码方式

使用 POST 传送,最常使用的是 Content-TypeContent-Length 头标。

2.3.2:Response 响应

HTTP 响应码:

  • 1xx:信息,请求收到,继续处理
  • 2xx:成功,行为被成功地接受、理解和采纳
  • 3xx:重定向,为了完成请求,必须进一步执行的动作
  • 4xx:客户端错误
  • 5xx:服务器错误

可根据状态码来初步判断请求的文件在服务器的状况:

  • 200:存在文件
  • 403:存在文件夹
  • 3xx:均可能存在
  • 404:不存在文件及文件夹
  • 500:均可能存在

3:网站搭建介绍

3.1:网站环境

常见搭建平台语言
asp,php,aspx,jsp,py,javaweb 等环境。

域名、IP目录解析安全问题
域名扫描只能扫描出来域名文件,而域名文件只占服务器资源的一小部分;IP扫描可以直接扫描服务器根目录,得到的信息更多。

Web 源码中敏感文件
后台路径,数据库配置文件,备份文件等。

文件后缀解析对应安全
可能存在下载或解析问题。

3.2:后门注意事项

  • 后门是否给予执行权限
  • 后门是否给予操作目录或文件权限
  • 后门是否给予其他用户权限

4:Web 源码

Web 源码在安全测试中是非常重要的信息来源,源码的获取将为后期的安全测试提供更多的思路,可以用来代码审计也可用来做信息突破口,其中 Web 源码有很多技术需要简明分析。

4.1:知识点

  • Web 源码目录结构
  • Web 源码脚本类型
  • Web 源码应用分类
  • Web 源码其他说明

4.2:信息敏感点

  • 敏感目录结构
    数据库配置文件,后台目录,模版目录,数据库目录等

  • Web 脚本类型
    asp,php,aspx,jsp,javaweb 等脚本类型源码

  • 应用分类

    • 电商:业务逻辑漏洞
    • 论坛:xss 逻辑漏洞
    • 门户:综合类漏洞
    • 第三方:根据功能决定
    • 博客:漏洞较少
  • 开源,未开源问题

    • 开源:直接找漏洞或代码审计
    • 内部:常规漏洞测试
  • 框架,非框架问题

  • CMS 识别问题
    style.css 文件可以用来生成 md5 值来查寻 cms 框架。
    可以通过网页刷新时加载的文件来搜索 cms。

关于源码获取的相关途径:搜索,咸鱼淘宝,第三方源码站

5:数据库拓展

识别数据库类型常用方法

nmap -O ip地址
nmap ip地址 -p 端口(通过端口开放反推数据库)

数据库类型识别意义

  • 数据库漏洞和类型相关性很强。
  • 不同数据库漏洞爆发点不太一样。
  • 能确定数据库类型、版本,会对渗透有很大帮助。

数据库常见漏洞类型及攻击

  • 弱口令
  • sql 注入

数据库层面漏洞要参考数据库的重要程度来判定影响范围。

常见语言与数据库

  • asp + access
  • php + mysql
  • axpx + mssql
  • jsp + mssql,oracle
  • python + mongodb

数据库端口

  • 关系型数据库:

MySQL:3306
SqlServer:1433
Oracle:1521

  • 非关系型数据库:

MongoDB:27017
Redis:6379
memcached:11211

6:操作系统拓展

识别操作系统常见方法

  • Windows 对大小写不敏感,Linux 敏感。
  • 看 ping 命令的 ttl 值
    • ttl 在 64 左右:Linux
    • ttl 在 128 左右:Windows
  • nmap -O ip

操作系统识别意义

  • 可以明确思路
  • 可以筛选掉不不适用系统的情况

操作系统层面漏洞

  • 覆盖面广
  • 获取的权限高
  • 危害性大

7:第三方拓展

判断第三方平台或软件

  • 端口扫描
  • 特征匹配

识别第三方的意义

  • 可以提供额外的攻击面

常见第三方漏洞

  • 弱口令

除去常规 web 安全及 app 安全测试外,服务器单一或复杂的其他服务(邮件,游戏,负载均衡等)),也可以作为安全测试目标,此类目标测试原则只是少了 Web 应用或其他安全问题方面。

8:密码算法

常见密码、编码等算法

  • MD5
  • SHA
  • ASC
  • 进制
  • 时间戳
  • URL
  • BASE64
  • Unescape
  • AES
  • DES
  • ...

常见加密形式

  • 直接加密
  • 带 salt
  • 带密码
  • 带偏移
  • 带位数
  • 带模式
  • 带干扰
  • 自定义组合
  • ...

常见解密方式

  • 枚举
  • 自定义逆向算法
  • ...

了解常规加密算法的特性

  • 长度位数
  • 字符规律
  • 代码分析
  • 搜索获取
  • ...

南湖秋水夜无烟,耐可乘流直上天。

——《游洞庭湖五首 · 其二》(唐)李白

标签:后门,Web,01,请求,数据库,基础知识,漏洞,域名
From: https://www.cnblogs.com/GCom/p/17434247.html

相关文章

  • 皕杰报表为什么不采用web端设计器
    皕杰报表的设计器采用的是针对操作系统的本地端应用程序,是一种针对操作系统的nativeapplication,这种应用程序有诸多的优点和很多的好处,在这里就不一一列举了,现在就皕杰报表设计器当初的技术选型时“为啥不采用web端设计器”做一个简单的说明,主要就是如下5个方面的因素:本地设计器......
  • Spring Web 参数验证常见错误
    案例1:对象参数校验失效在构建Web服务时,我们一般都会对一个HTTP请求的Body内容进行校验,例如我们来看这样一个案例及对应代码。当开发一个学籍管理系统时,我们会提供了一个API接口去添加学生的相关信息,其对象定义参考下面的代码:(https://www.java567.com,搜"spring") importlo......
  • 搭建自动化 Web 页面性能检测系统 —— 设计篇
    我们是袋鼠云数栈UED团队,致力于打造优秀的一站式数据中台产品。我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值。。本文作者:琉易liuxianyu.cn页面性能对于用户体验、用户留存有着重要影响,当页面加载时间过长时,往往会伴随着一部分用户的流失,也会带来一些用户......
  • windows server2016 操作系统修改默认远程端口
    一、需求   远程端口,windows默认的3389.linux的22,这种都是知名端口,如果IP地址暴露,很可能会被攻击,这时候就需要更改端口号。二、操作步骤2.1打开注册表   快捷键WIN+R,命令行窗口输入regedit2.2进入以下路径  这里是默认端口,修改为自己除1024以后,以及未被......
  • Unity2018.2 Standard Assets汉化
    下载中文汉化包拷贝到安装盘:\ProgramFiles\Unity\Editor\Data\Localization下面2018.1+的StandardAssets安装方法“自从我升级到2018.2之后,就再也找不到Unity自带的那些标准资源了,就是那个StandardAssets,里面有好多东西是我的必备资源呢,比如地形的那些贴图,第一人称控制......
  • Exp8 Web综合-20201324
    目录1基础问题回答1.1什么是表单1.2浏览器可以解析运行什么语言1.3WebServer支持哪些动态语言1.4防范注入攻击的方法有哪些2实验过程2.1Web前端HTML2.2Web前端javascipt2.3Web后端MySQL基础2.3.1建库2.3.2建表2.3.3修改密码2.3.4创建用户2.4Web后端PHP2.5最简单的S......
  • P4557 [JSOI2018]战争 题解
    闵可夫斯基和前言入门建议看吉老师(吉如一)的计算几何入门到放弃。感觉应该是讲的最通俗易懂的了。本文借鉴了Winxp的博客,以及吉老师视频中的思路。写这篇博客的初衷是因为我作为一个初学者,此题里的题解对我来说理解起来不算太难,但是实现起来细节比较多,题解里也没有很详细地去解......
  • P4288 [SHOI2014]信号增幅仪 题解
    感谢审核人Description给定\(n\)个点,椭圆长轴的方向\(a\)和放大倍数\(p\),求覆盖全部点的最小椭圆的半短轴长度。Solution让我们求最小覆盖椭圆,但是椭圆不具有什么好的性质,我们可以把椭圆转化成圆来做,这样,题目就转化成了最小覆盖圆,这个用随机增量法来做就可以了。接下来......
  • P5446 [THUPC2018]绿绿和串串 题解
    Description给定一个串\(S\),要求串\(S\)是串\(R\)经过多次翻转后的前缀。问有多少种初始长度的串\(R\)。串\(R\)翻转的定义是将前\(|R|-1\)个字符倒序排列后,插入到串的最后。如\(\mathrm{aaa}\)翻转后得到\(\mathrm{abcdcba}\)。Solution我们先设以\(i\)为......
  • P8081 [COCI2011-2012#4] ZIMA 题解
    题意给定一个长度为\(n\)的序列。当连续\(T\)天温度都小于\(0\)时,则称这\(T\)天为一个冰期,冰期来临之前的\(2T\)天都被标记为警示状态.特殊地,如果一个冰期最长,那么它的前\(3T\)天会被标记为警示状态。如果有多个冰期最长,选一个。思路模拟预处理出每个冰期的长......