广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >代码注入(web安全入门)
  • 912
分享到

代码注入(web安全入门)

web安全php安全 2023-09-09 09:09:59 912人浏览 八月长安
摘要

一、原理以及成因 PHP 代码执行(注入)是指应用程序过滤不严,用户可以 Http 通过请求将代码注入到应用中执行。 代码执行(注入)类似于 sql 注入漏洞,SQLi 是将 SQL 语句注入到数据库

一、原理以及成因

PHP 代码执行(注入)是指应用程序过滤不严,用户可以 Http 通过请求将代码注入到应用中执行。
代码执行(注入)类似于 sql 注入漏洞,SQLi 是将 SQL 语句注入到数据库中执行,而代码执行则是可以把代码注入到应用中最终由服务器运行它。这样的漏洞如果没有特殊的过滤,相当于直接有一个 WEB 后门的存在。
1、程序中含有可以执行 php 代码的函数或者语言结构
2、传入第一点中的参数,客户端可控,直接修改或者影响

二、漏洞危害

Web 应用如果存在代码执行漏洞是一件非常可怕的事情,就像一个人没有穿衣服,赤裸裸的暴露在光天化日之下。可以通过代码执行漏洞继承 Web 用户权限,执行任意代码。如果服务器没有正确的配置,Web 用户权限比较高的话,我们可以读写目标服务器任意文件内容,甚至可控制整个网站以及服务器。
本课程以 PHP 为例子来说明,代码执行漏洞。
PHP 中有很多函数和语句都会造成 PHP 代码执行漏洞。

三、相关函数和语句

3.1 eval()

eval() 会将字符串当作 PHP 代码来执行。测试代码如下

?code=phpinfo();"}
?code=phpinfo();"}

提交变量[?code=phpinfo();] 我们提交以下参数也是可以的[?code=${phpinfo()};]
[?code=1;phpinfo();] //可以执行多条语句

2 assert()
assert() 同样会作为 PHP 代码执行测试代码如下

?code=phpinfo();"}

提交参数 [?code=phpinfo()]

3.3 preg_replace()

preg_replace() 函数作用是对字符串进行正则处理,参数和返回值如下
mixed preg_replace(mixed $pattern,mixed $replacement,mixed KaTeX parse error: Expected 'EOF', Got '&' at position 30: …imit = -1[,int &̲count]])
这段代码的含义是搜索 s u b j e c t 中匹配 subject 中匹配 subject中匹配pattern 的部分,以$replacement 进行替换,而
p a t t e r n 处,及第一个参数存在 e 修饰时, pattern 处,及第一个参数存在 e 修饰时, pattern处,及第一个参数存在e修饰时,replacement 的值会被当成 PHP 代码来执行。典型的代码如下

?code=phpinfo();"}

提交参数[?code=[phpinfo()]], phpinfo() 会被执行

3.4 call_user_func()

call_user_func() 等函数都有调用其他函数的功能,其中一个参数作为要调用的函数名,那如果这个传入的函数名可控,那就可以调用以外的函数来执行我们想要的代码,也就是存在任意代码执行漏洞。
以 call_user_func() 为例子,该函数的第一个参数作为回调函数,测试代码如下

提交参数[?fun=assert¶=phpinfo()]
注意:这里不能使用 eval,因为 eval 是语言结构,不是函数。

5 动态函数 a ( a( a(b)
由于 PHP 的特性原因,PHP 的函数支持直接由拼接的方式调用,这导致 PHP 再安全上的控制又加大了难度。不少知名程序也用到了动态函数的写法,这种写法跟使用 call_user_func() 的初衷一样,用来更加方便的调用函数,但是一旦过滤不严格就会造成代码执行漏洞。
测试代码如下:

四、漏洞利用

代码执行漏洞的利用方式有很多中

4.1 直接获取shell

提交参数[?code=@eval($_REQUEST[1])],即可构成一句话木马,密码为 1。可以使用菜刀或者蚁剑连接

4.2 获取当前文件的绝对路径

FILE 是 PHP 预定义常量,其含义为当前文件的路径。提交代码[?code=print(FILE);]

3 读文件
我们可以利用 file_get_contents() 函数读取服务器任意文件,前提是知道文件的绝对路径(也可是相对路径)和读取权限。

提交代码[?code=var_dump(file_get_contents(‘c:\windows\system32\drivers\etc\hosts’));] 右键查看源代码

4.4 写文件

我们可以利用 file_put_contents() 函数写入文件,前提是知道可写文件目录。提交代码[?code=var_dump(file_put_contents( P O S T [ 1 ] , _POST[1], POST[1],_POST[2]));]
此时需要借助与 hackbar 通过 post 方式提交参数
[1=shel.php&2=]
即可再当前目录下创建一个文件 shell.php

五、防御方法

尽量不要使用 eval(不是函数,是语言结构) 等函数
2、如果使用的话一定要进行严格的过滤3、preg_replace 放弃使用/e 修饰符
4、修改配置文件 php.ini disable_functions=assert

实战:
海洋 Seacmsv6.26 系统存在代码注入漏洞
漏洞点[/search.php?searchtype=5&tid=&area=phpinfo()]
6.53 6.54 6.55 都存在代码注入漏洞

来源地址:https://blog.csdn.net/qq_32277727/article/details/128378045

--结束END--

本文标题: 代码注入(web安全入门)

本文链接: https://www.lsjlt.com/news/401269.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 代码注入(web安全入门)
    一、原理以及成因 php 代码执行(注入)是指应用程序过滤不严,用户可以 http 通过请求将代码注入到应用中执行。 代码执行(注入)类似于 SQL 注入漏洞,SQLi 是将 SQL 语句注入到数据库...
    99+
    2023-09-09
    web安全 php 安全
  • PHP入门指南:代码注入漏洞
    近年来,网络安全问题越来越频繁地被人们所关注。其中,代码注入漏洞是常见的安全问题之一。PHP作为一种常用的后端编程语言,被广泛应用于网站开发中。然而,PHP由于其灵活性和易用性,在编写代码的过程中会存在安全漏洞,那么,如何避免代码注入漏洞呢...
    99+
    2023-05-20
    漏洞 PHP 代码注入
  • 【web安全】——XXE漏洞快速入门
    作者名:Demo不是emo  主页面链接:主页传送门创作初心:一切为了她座右铭:不要让时代的悲哀成为你的悲哀专研方向:网络安全,数据结构 每日emo:该怎么开口呢?今晚天气不错,但还是想你了 目录  一:初识XXE漏洞 1.XX...
    99+
    2023-08-31
    安全 web安全 php 网络安全
  • Web安全入门基础知识(笔记)
    目录 0x01 基础名词 一、域名 1.什么是域名 2.域名在那里注册 3.什么是二级域名,多级域名,顶级域名 4.域名发现对于安全测试的意义 二、DNS 1.什么是DNS 2.本地host和DNS的关系 3.CDN是什么,和D...
    99+
    2023-09-16
    web安全 服务器 网络
  • 【PHP代码注入】PHP代码注入漏洞
    漏洞原理 RCE为两种漏洞的缩写,分别为Remote Command/Code Execute,远程命令/代码执行 PHP代码注入也叫PHP代码执行(Code Execute)(Web方面),是指应用程序过滤不严,用户可以通过HTTP请...
    99+
    2023-09-01
    PHP代码注入漏洞 PHP代码执行漏洞 PHP常见的代码执行函数和语句 PHP代码执行漏洞利用 PHP代码执行漏洞防御 Powered by 金山文档
  • Java注解入门案例代码分析
    这篇文章主要介绍“Java注解入门案例代码分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java注解入门案例代码分析”文章能帮助大家解决问题。Talk is cheap, show me the...
    99+
    2023-07-05
  • WEB安全入门:如何防止 CSRF 攻击?
    现在,我们绝大多数人都会在网上购物买东西。但是很多人都不清楚的是,很多电商网站会存在安全漏洞。乌云就通报过,国内很多家公司的网站都存在 CSRF 漏洞。如果某个网站存在这种安全漏洞的话,那么我们在购物的过程中,就很可能会被网络黑客盗刷信用卡...
    99+
    2018-07-02
    WEB安全入门:如何防止 CSRF 攻击?
  • web安全之机器学习入门——3.2 决策
    目录 简介 决策树简单用法 决策树检测P0P3爆破 决策树检测FTP爆破 随机森林检测FTP爆破   简介 决策树和随机森林算法是最常见的分类算法; 决策树,判断的逻辑很多时候和人的思维非常接近。 随机森林算法,利用多棵决策树对样本进行...
    99+
    2023-01-31
    入门 机器 web
  • PHP代码审计入门-万能密码入门分析
    0x00  写在前面 从零学习php,最终目的实现代码审计入门,软件采用sublime text,环境使用phpstudy搭建,数据库是navicat,需要有简单的html基础和php基础,跟随流沙前辈视频学习记录。 本章开始,正...
    99+
    2023-10-22
    php 网络安全
  • 安全入门第四天
    一、 文件读取漏洞 进入usafe Filedownload 将地址的down_nba.php改为: execdownload.phpfilename=…/…/…/inc/config.inc....
    99+
    2023-09-04
    安全 php web安全
  • web安全之防止SQL注入的方法
    小编给大家分享一下web安全之防止SQL注入的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!SQL注入,就是通过把SQL命令...
    99+
    2022-10-18
  • Web安全解析Boolean注入攻击原理
    目录1. Boolean注入攻击2. Boolean注入代码分析1. Boolean注入攻击 Boolean注入攻击的测试地址:http://127.0.0.1/sqli/...
    99+
    2022-11-12
  • python必背入门代码
    Python是一种简单易学的编程语言,适合初学者入门。下面是一些必备的Python入门代码,帮助你快速上手编程:1、输出Hello Worldprint("Hello World!")2、变量和数据类型# 定义变量并赋值...
    99+
    2023-10-25
    python
  • Web安全解析报错注入攻击原理
    目录1.报错注入攻击2.报错注入代码分析1.报错注入攻击 报错注入攻击的测试地址:http://127.0.0.1/sqli/error.php?username=1。 访问...
    99+
    2022-11-12
  • Java安全编码SQL该怎样注入
    Java安全编码SQL该怎样注入,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。随着互联网的发展,Java语言在金融服务业、电子商务、大数据技术等方面的应用极其广泛。Java...
    99+
    2023-06-17
  • python入门代码有哪些
    python入门代码有:1、打印语句,会在控制台输出所写代码;2、变量和数据类型,Python中的变量不需要声明,可以直接赋值,常见的数据类型有字符串、整数、浮点数、列表、字典;3、条件语句,用于根据条件的真假执行不同的代码块;4、循环,用...
    99+
    2023-11-20
    python Python代码
  • ajax入门代码怎么写
    这期内容当中小编将会给大家带来有关ajax入门代码怎么写,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。静态页面  代码如下:<!DOCTYPE html ...
    99+
    2022-10-19
  • LINQ入门代码怎么写
    本篇内容主要讲解“LINQ入门代码怎么写”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“LINQ入门代码怎么写”吧!语言集成查询 (LINQ) 是 Visual Studio 2008 和 .NE...
    99+
    2023-06-17
  • [BUUCTF][N1BOOK][第一章 web入门]SQL注入-2(详细解析)
    目录 题目链接: 题目解析: 得到flag: 题目链接: https://buuoj.cn/challenges#[%E7%AC%AC%E4%B8%80%E7%AB%A0%20web%E5%85%A5%E9%97%A8]SQL%E...
    99+
    2023-09-15
    php web安全 开发语言 sql
  • php入门写法PHP入门基础之php代码写法
    一.在web页面嵌入PHP代码的几种风格推荐使用标准风格或简短风格 代码如下: //简短风格 echo 'Hello World!'; > //script风格 echo 'Hello World!'; 二.代码注释的四种方式 代码如下: ...
    99+
    2023-09-14
    php 开发语言 java
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作