2023年最新版200道网络安全面试题合集【内含答案解析】

2023-05-16

1、什么是SQL注入攻击

攻击者在HTTP请求中注入恶意的SQL代码,服务器使用参数构建数据库SQL命令时,恶意SQL被一起构造,并在数据库中执行。

用户登录,输入用户名lianggzone,密码‘ or ‘1’=’1,如果此时使用参数构造的方式,就会出现select * from user where name = ‘lianggzone’ and password = ‘’ or ‘1’=‘1’不管用户名和密码是什么内容,使查询出来的用户列表不为空。如何防范SQL注入攻击使用预编译的PrepareStatement是必须的,但是一般我们会从两个方面同时入手。

Web端

1)有效性检验。

2)限制字符串输入的长度。

服务端

1)不用拼接SQL字符串。

2)使用预编译的PrepareStatement。

3)有效性检验。(为什么服务端还要做有效性检验?第一准则,外部都是不可信的,防止攻击者绕过Web端请求)

4)过滤SQL需要的参数中的特殊字符。比如单引号、双引号。

2、什么是XSS攻击

跨站点脚本攻击,指攻击者通过篡改网页,嵌入恶意脚本程序,在用户浏览网页时,控制用户浏览器进行恶意操作的一种攻击方式。如何防范XSS攻击

1)前端,服务端,同时需要字符串输入的长度限制。

2)前端,服务端,同时需要对HTML转义处理。将其中的”<”,”>”等特殊字符进行转义编码。

防XSS的核心是必须对输入的数据做过滤处理。

3、什么是CSRF攻击

跨站点请求伪造,指攻击者通过跨站请求,以合法的用户的身份进行非法操作。可以这么理解CSRF攻击:攻击者盗用你的身份,以你的名义向第三方网站发送恶意请求。CRSF能做的事情包括利用你的身份发邮件,发短信,进行交易转账,甚至盗取账号信息。如何防范CSRF攻击安全框架,例如Spring Security。

token机制。在HTTP请求中进行token验证,如果请求中没有token或者token内容不正确,则认为CSRF攻击而拒绝该请求。

验证码。通常情况下,验证码能够很好的遏制CSRF攻击,但是很多情况下,出于用户体验考虑,验证码只能作为一种辅助手段,而不是最主要的解决方案。

referer识别。在HTTP Header中有一个字段Referer,它记录了HTTP请求的来源地址。如果Referer是其他网站,就有可能是CSRF攻击,则拒绝该请求。但是,服务器并非都能取到Referer。很多用户出于隐私保护的考虑,限制了Referer的发送。在某些情况下,浏览器也不会发送Referer,例如HTTPS跳转到HTTP。

1)验证请求来源地址;

2)关键操作添加验证码;

3)在请求地址添加token并验证。

4、什么是文件上传漏洞

文件上传漏洞,指的是用户上传一个可执行的脚本文件,并通过此脚本文件获得了执行服务端命令的能力。

许多第三方框架、服务,都曾经被爆出文件上传漏洞,比如很早之前的Struts2,以及富文本编辑器等等,可被攻击者上传恶意代码,有可能服务端就被人黑了。如何防范文件上传漏洞

文件上传的目录设置为不可执行。

1)判断文件类型。在判断文件类型的时候,可以结合使用MIME Type,后缀检查等方式。因为对于上传文件,不能简单地通过后缀名称来判断文件的类型,因为攻击者可以将可执行文件的后缀名称改为图片或其他后缀类型,诱导用户执行。

2)对上传的文件类型进行白名单校验,只允许上传可靠类型。

3)上传的文件需要进行重新命名,使攻击者无法猜想上传文件的访问路径,将极大地增加攻击成本,同时向shell.php.rar.ara这种文件,因为重命名而无法成功实施攻击。

4)限制上传文件的大小。

5)单独设置文件服务器的域名。

5、DDos攻击

客户端向服务端发送请求链接数据包,服务端向客户端发送确认数据包,客户端不向服务端发送确认数据包,服务器一直等待来自客户端的确认

没有彻底根治的办法,除非不使用TCP

DDos预防:

1)限制同时打开SYN半链接的数目

2)缩短SYN半链接的Time out时间

3)关闭不必要的服务

6、重要协议分布图


7、arp协议的工作原理

地址解析协议,即ARP(Address Resolution Protocol),是根据IP地址获取物理地址的一个TCP/IP协议。

1.发送ARP请求的以太网数据帧广播到以太网上的每个主机,ARP请求帧中包含了目的主机的IP地址。

2.目的主机收到了该ARP请求之后,会发送一个ARP应答,里面包含了目的主机的MAC地址。

ARP协议工作原理:

每个主机都会在自己的ARP缓冲区中建立一个ARP列表,以表示IP地址和MAC地址之间的对应关系。

主机(网络接口)新加入网络时(也可能只是mac地址发生变化,接口重启等),会发送免费ARP报文把自己IP地址与Mac地址的映射关系广播给其他主机。

网络上的主机接收到免费ARP报文时,会更新自己的ARP缓冲区。将新的映射关系更新到自己的ARP表中。

某个主机需要发送报文时,首先检查ARP列表中是否有对应IP地址的目的主机的MAC地址,如果有,则直接发送数据,如果没有,就向本网段的所有主机发送ARP数据包,该数据包包括的内容有:源主机IP地址,源主机MAC地址,目的主机的IP地址等。

当本网络的所有主机收到该ARP数据包时:

(A)首先检查数据包中的IP地址是否是自己的IP地址,如果不是,则忽略该数据包。

(B)如果是,则首先从数据包中取出源主机的IP和MAC地址写入到ARP列表中,如果已经存在,则覆盖。

(C)然后将自己的MAC地址写入ARP响应包中,告诉源主机自己是它想要找的MAC地址。

源主机收到ARP响应包后。将目的主机的IP和MAC地址写入ARP列表,并利用此信息发送数据。如果源主机一直没有收到ARP响应数据包,表示ARP查询失败。ARP高速缓存(即ARP表)是ARP地址解析协议能够高效运行的关键

8、什么是RARP?

工作原理概括:反向地址转换协议,网络层协议,RARP与ARP工作方式相反。RARP使只知道自己硬件地址的主机能够知道其IP地址。

RARP发出要反向解释的物理地址并希望返回其IP地址,应答包括能够提供所需信息的RARP服务器发出的IP地址。

原理:

(1)网络上的每台设备都会有一个独一无二的硬件地址,通常是由设备厂商分配的MAC地址。主机从网卡上读取MAC地址,然后在网络上发送一个RARP请求的广播数据包,请求RARP服务器回复该主机的IP地址。

(2)RARP服务器收到了RARP请求数据包,为其分配IP地址,并将RARP回应发送给主机。

(3)PC1收到RARP回应后,就使用得到的IP地址进行通讯。

9、dns是什么?dns的工作原理

将主机域名转换为ip地址,属于应用层协议,使用UDP传输。(DNS应用层协议,以前有个考官问过)

过程:

总结:

浏览器缓存,系统缓存,路由器缓存,IPS服务器缓存,根域名服务器缓存,顶级域名服务器缓存,主域名服务器缓存。

一、主机向本地域名服务器的查询一般都是采用递归查询。

二、本地域名服务器向根域名服务器的查询的迭代查询。

1)当用户输入域名时,浏览器先检查自己的缓存中是否这个域名映射的ip地址,有解析结束。

2)若没命中,则检查操作系统缓存(如Windows的hosts)中有没有解析过的结果,有解析结束。3)若无命中,则请求本地域名服务器解析(LDNS)。

4)若LDNS没有命中就直接跳到根域名服务器请求解析。根域名服务器返回给LDNS一个主域名服务器地址。

5)此时LDNS再发送请求给上一步返回的gTLD(通用顶级域),接受请求的gTLD查找并返回这个域名对应的Name Server的地址

6)Name Server根据映射关系表找到目标ip,返回给LDNS

7)LDNS缓存这个域名和对应的ip,把解析的结果返回给用户,用户根据TTL值缓存到本地系统缓存中,域名解析过程至此结束

10、rip协议是什么?

rip的工作原理RIP动态路由选择协议(网络层协议)

RIP是一种基于距离矢量(Distance-Vector)算法的协议,它使用跳数(Hop Count)作为度量来衡量到达目的网络的路由距离。RIP通过UDP报文进行路由信息的交换,使用的端口号为520。

工作原理:

RIP路由协议用“更新(UNPDATES)”和“请求(REQUESTS)”这两种分组来传输信息的。每个具有RIP协议功能的路由器每隔30秒用UDP520端口给与之直接相连的机器广播更新信息。并且在(用“路程段数”(即“跳数”)作为网络距离的尺度。每个路由器在)给相邻路由器发出路由信息时,都会给每个路径加上内部距离。

路由器的收敛机制:

任何距离向量路由选择协议(如RIP)都有一个问题,路由器不知道网络的全局情况,路由器必须依靠相邻路由器来获取网络的可达信息。由于路由选择更新信息在网络上传播慢,距离向量路由选择算法有一个慢收敛问题,这个问题将导致不一致性产生。

RIP较少路由收敛机制带来的问题:

1)记数到无穷大机制:RIP协议允许最大跳数为15。大于15的目的地被认为是不可达。当路径的跳数超过15,这条路径才从路由表中删除。

2)水平分割法:路由器不向路径到来的方向回传此路径。当打开路由器接口后,路由器记录路径是从哪个接口来的,并且不向此接口回传此路径。

3)破坏逆转的水平分割法:忽略在更新过程中从一个路由器获取的路径又传回该路由器

4)保持定时器法:防止路由器在路径从路由表中删除后一定的时间内(通常为180秒)接受新的路由信息。保证每个路由器都收到了路径不可达信息

5)触发更新法:当某个路径的跳数改变了,路由器立即发出更新信息,不管路由器是否到达常规信息更新时间都发出更新信息。

面试题合集

书籍教材

网络安全/Web安全/渗透测试推荐书单:

视频学习

尾言

从时代发展的角度看,信息安全的知识是学不完的,而且以后要学的会更多,同学们要摆正心态,既然选择入门网络安全,就不能仅仅只是入门程度而已,能力越强机会才越多。

不管什么行业,你深耕下去成为人才,发展都不会差。

因为入门学习阶段知识点比较杂,所以我讲得比较笼统,大家如果有不懂的地方可以找我咨询,我保证知无不言言无不尽,需要相关资料也可以找我要,我的网盘里一大堆资料都在吃灰呢。

【一一帮助安全学习,所有资源获取处一一】
①网络安全学习路线
②20份渗透测试电子书
③安全攻防357页笔记
④50份安全攻防面试指南
⑤安全红队渗透工具包
⑥网络安全必备书籍
⑦100个漏洞实战案例
⑧安全大厂内部视频

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

2023年最新版200道网络安全面试题合集【内含答案解析】 的相关文章

  • Qt 获取所有进程、终止某个进程

    代码中用到Qt库的地方 xff0c 不使用Qt库的可以替换为自己相应的函数 方法一 xff1a 1 Qt开源库 xff0c 通过QProcess启动系统命令 tasklist exe 获取正在运行的进程 2 QProcess process
  • Qt QPixmap设置图片透明度

    最近看到美图秀秀的一些功能 xff0c 可以手动设置图片的透明度并显示在其它图片上 xff0c 所以自己动手做了个小Demo xff0c 实际效果如下 xff1a xff08 图片仅供参考使用 xff09 可以看到拖动下方进度条 xff0c
  • 【IDEA报错】Failed to start bean ‘documentationPluginsBootstrapper‘问题及解决方案

    使用springfox swagger2进行接口文档输出 编写配置文件Swagger2Config 64 Configuration 64 EnableSwagger2 public class Swagger2Config 64 Bean
  • Android 调整Spinner下拉框高度(避免下拉列表跑到顶部)

    在运用系统原生的Spinner控件做下拉选择功能时 由于选择项的子项Item太多 导致下拉列表跑到上面去了 关键原因是系统下拉默认的高度 spinner所在的位置 超过了屏幕底部的高度 所以就会出现下拉列表跑到控件的头部去了 解决方案 1
  • c++中的随机数rand()

    总结 xff1a 1 RANK MAX 61 32767 2 随机范围 xff1a num 61 rank x C 43 43 中rand 函数的用法 1 rand 不需要参数 xff0c 它会返回一个从0到最大随机数的任意整数 xff0c
  • 最大数和最小数位置交换位置

    输入10个整数 xff0c 用函数编程将其中最大数与最小数的位置互换 然后在主函数中将交换后的数组的所有元素输出 include lt stdio h gt int main int arr 10 61 0 int maxi 61 0 in
  • HDFS基本概念

    目录 零 学习目标 一 导入新课 二 新课讲解 xff08 一 xff09 HFDS的演变 xff08 二 xff09 HDFS的基本概念 1 NameNode xff08 名称节点 xff09 2 DataNode xff08 数据节点
  • 用栈来判断字符串是否回文

    include lt iostream gt include lt bits stdc 43 43 h gt using namespace std define MAX SIZE 100 class Stack private char
  • 技术分享 | 将覆盖反馈融入黑盒模糊测试技术提升测试效率

    引言 近几年来 xff0c 自动化漏洞挖掘技术成为网络安全的重要研究方向 传统的漏洞挖掘技术面临着耗时长 误报多等痛点 xff0c 且无法全面地探测目标软件中的已知与未知漏洞 因此 xff0c 一种简单高效的漏洞挖掘技术 xff0c 即模糊
  • 基于Vue3+Vite实现的移动端天气预报系统

    文章目录 1 前言2 准备工作3 项目创建与配置3 1适配移动端3 2路由配置 4 功能实现4 1Footer组件的实现4 2Mine组件的实现4 3Guide组件的实现4 4GuideInfo组件的实现4 5 Home组件的实现4 6封装
  • 【C++ 将十六进制数转换为二进制数】

    问题描述 将十六进制数转换为二进制数 输入格式 输入一个16进制数 输出格式 输出二进制数 输入样例 在这里给出一组输入 例如 xff1a 23 输出样例 在这里给出相应的输出 例如 xff1a 100011 输入样例 在这里给出一组输入
  • 电力系统强大的Gurobi 求解器的学习(Python&Matlab)

    到底有多强大 xff0c 看看就知道 xff0c 必须 x1f44d x1f44d x1f44d xff1a 目录 1 概述 2 算例理解 Python 2 1 算例1 详细入门 2 2 算例2 一般线性规划问题 2 3 算例3 非凸问题
  • 位移操作符 <<左移 与 >>右移 的基本逻辑

    1 xff1a lt lt 左移操作符 2 xff1a gt gt 右移操作符 xff08 注 xff1a 位移操作符的操作数只能是整数 xff09 lt lt 左移操作符 与 gt gt 右移操作符 都是移二进制位操作符 整数的二进制表现
  • 判断101到200有多少素数,并输出所有素数

    分析 xff1a 1 从101到200 xff0c 我们要用到for语句 xff08 如果有其它条件就把i 61 101到200改成条件的数 xff09 for i 61 101 i lt 61 200 i 43 43 2 判断素数 xff
  • 求最大值,求10 个整数中最大值

    求最大值 求10 个整数中最大值 思路 xff1a 1 采用循环的方式输入一个数组 2 使用max标记数组中的最大值 xff0c 采用循环的方式依次获取数组中的每个元素 xff0c 与max进行比较 xff0c 如果arr i 大于 max
  • Android app后台运行休眠仍然可以运行的方法(确保一直运行)

    在播放器app中由于需要用后台service 来播放音乐 所以一旦进入休眠状态时 就有可能被杀掉进程 所以需要让service 一直运行不被杀掉进程 在android 中WakeLock的相关 API可以确保应用程序中后台任务一直运行 使应
  • 输入N个数,输出最大值和最小值

    include lt stdio h gt int main int max min a b c num scanf 34 d 34 amp a scanf 34 d 34 amp b max 61 b min 61 b for c 61
  • 【C语言学习】数组排序.选择法

    上课学的选择法数组排序 xff0c 老师讲的云里雾里的 xff0c 准备用自己的理解再写一下它的原理及注意点 xff0c 希望对你有所帮助 目录 1 原理 2 注意点 3 代码 1 原理 每一次从待排序的数据元素中选出最小 或最大 的一个元
  • 用C语言,求10个数的最小值和最大值

    用数组a存放10个数 xff0c min max存放最小值和最大值 对数组进行遍历 将a 0 设为最小值和最大值的初值 xff1b 利用a i 和min max进行比较 include lt stdio h gt main int i a
  • [NOIP2012 提高组] 国王游戏(C++,贪心,高精度)

    题目描述 恰逢 H 国国庆 xff0c 国王邀请 n n n 位大臣来玩一个有奖游戏 首先 xff0c 他让每个大臣在左 右手上面分别写下一个整数 xff0c 国王自己也在左 右手上各写一个整数 然后 xff0c 让这 n n

随机推荐