2024-08-07

由于复现漏洞涉及的内容较多,下面我将给出Spring、Struts2、Laravel和ThinkPHP常见的几个漏洞复现实例。

  1. Spring框架的Spring Expression Language (SpEL) 漏洞复现:



import org.springframework.expression.ExpressionParser;
import org.springframework.expression.spel.standard.SpelExpressionParser;
 
public class SpelVulnerability {
    public static void main(String[] args) {
        String payload = "T(java.lang.Runtime).getRuntime().exec('whoami')";
        ExpressionParser parser = new SpelExpressionParser();
        parser.parseExpression(payload).getValue();
    }
}
  1. Struts2框架的S2-059漏洞复现:



import org.apache.struts2.ServletActionContext;
 
public class S2_059_Vulnerability {
    public void execute() throws Exception {
        String param = ServletActionContext.getRequest().getParameter("param");
        Runtime.getRuntime().exec(param);
    }
}
  1. Laravel框架的序列化漏洞复现:



use Illuminate\Contracts\Support\Arrayable;
 
class ArbitraryCode implements Arrayable {
    public function toArray() {
        return [
            'O:21:"Illuminate\Support\Facades\":3:{s:5:"class";O:23:"Illuminate\Support\Facades\Facade":0:{}s:5:"alias";O:20:"Illuminate\Support\Str":0:{}s:12:"resolvedInstance";O:56:"Illuminate\Encryption\Encrypter":2:{s:8:"key";s:3:"key";s:13:"iv";s:16:"iv";}}',
            'O:23:"Illuminate\Support\Facades\Facade":0:{}',
            'O:56:"Illuminate\Encryption\Encrypter":2:{s:8:"key";s:3:"key";s:13:"iv";s:16:"iv";}'
        ];
    }
}
 
$serialized = serialize(new ArbitraryCode());
  1. ThinkPHP框架的跨站请求伪造(CSRF)漏洞复现:



public function csrf() {
    $token = think\facade\Request::token();
    echo '<form method="post" action="http://your-target.com/action">
        <input type="hidden" name="' . $token . '" value="' . $token . '">
        <input type="submit" value="Submit">
    </form>';
}

这些代码实例仅供学习和测试使用,不得用于非法活动。对于复现漏洞,建议在受控环境中进行,并遵守所有适用的法律和政策。

2024-08-07



<?php
// 在ThinkPHP控制器中获取配置信息并传递给Vue组件
namespace app\index\controller;
 
use think\Controller;
use think\View;
 
class Index extends Controller
{
    public function index()
    {
        // 获取配置信息
        $config = $this->getConfig();
        
        // 将配置信息传递给视图
        $this->view->config = $config;
        
        // 渲染视图
        return $this->view->fetch();
    }
    
    protected function getConfig()
    {
        // 从配置文件获取配置信息
        $config = [
            'apiBaseUrl' => config('api.base_url'),
            'appId' => config('api.app_id'),
            'appKey' => config('api.app_key'),
        ];
        
        return json_encode($config); // 将配置信息转换为JSON字符串
    }
}

在这个简化的例子中,我们假设index.html是Vue组件的模板文件,并且在其中有一个Vue实例,它需要从ThinkPHP后端获取配置信息。控制器中的getConfig方法获取了必要的配置信息,并将其转换为JSON字符串,然后传递给视图渲染。视图文件index.html中的Vue组件将会使用这些配置信息。

2024-08-07



// 使用Laravel的方式创建一个简单的路由响应
Route::get('/', function () {
    return 'Hello, World!';
});
 
// 以上代码展示了如何在Laravel框架中创建一个简单的路由,当访问根URL('/')时,它会返回一个字符串'Hello, World!'。这是一个典型的闭包路由,非常简洁和直接。

这段代码演示了在Laravel框架中创建一个简单的路由响应。在Laravel中,路由是用来响应HTTP请求的,闭包是创建简单、独立的路由的快捷方式。这种方式使得开发者能够快速、高效地构建Web应用的路由逻辑。

2024-08-07

在ThinkPHP框架中,MVC模式是核心,控制器是连接模型和视图的桥梁。以下是一个简单的控制器示例,展示了如何创建一个控制器并与模型交互:




<?php
namespace Home\Controller;
use Think\Controller;
 
class BlogController extends Controller {
    public function index(){
        // 实例化模型
        $Blog = M('Blog');
        // 查询数据
        $list = $Blog->select();
        // 分配变量到模板
        $this->assign('list', $list);
        // 显示模板
        $this->display();
    }
    
    public function add(){
        // 实例化模型
        $Blog = D('Blog');
        // 如果是POST请求,则处理数据
        if(IS_POST){
            // 接收提交的数据
            $data = I('post.');
            // 验证数据
            if ($vo = $Blog->create($data)) {
                // 插入数据
                $result = $Blog->add($data);
                if ($result) {
                    // 成功操作
                    $this->success('添加成功!', U('index'));
                } else {
                    // 失败操作
                    $this->error('添加失败!');
                }
            } else {
                // 验证失败操作
                $this->error($Blog->getError());
            }
        } else {
            // 显示添加表单
            $this->display();
        }
    }
}

这个控制器BlogController包含了两个基本的操作:index用于显示博客列表,add用于添加新博客。它展示了如何实例化模型,处理用户输入,以及如何在操作成功或失败后给用户反馈。这个示例遵循了ThinkPHP的MVC模式和框架约定,并且是学习ThinkPHP开发的基础。

2024-08-07



<?php
// 确保cURL库已经启用
if (!function_exists("curl_init")) {
    die("Sorry cURL is not installed right");
}
 
// 创建一个新的cURL资源
$ch = curl_init();
 
// 设置URL和相应的选项
curl_setopt($ch, CURLOPT_URL, "http://example.com/api/data_mining");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, "key=value&foo=bar"); // POST参数
 
// 执行cURL会话
$response = curl_exec($ch);
 
// 检查是否有错误发生
if (curl_errno($ch)) {
    echo 'Error:' . curl_error($ch);
} else {
    // 处理返回的数据
    $data = json_decode($response, true);
    if ($data['status'] == 'success') {
        // 数据挖掘成功,处理数据
        $analysisResult = $data['data'];
        // ... 进行数据处理和分析的代码 ...
    } else {
        echo 'Error: ' . $data['message'];
    }
}
 
// 关闭cURL资源,并释放系统资源
curl_close($ch);
?>

这段代码展示了如何使用PHP的cURL库发送POST请求到外部API,并处理返回的JSON数据。它还包括了错误处理,以确保在API调用失败时能够给出提示。在实际应用中,你需要替换URL和POST参数,并根据API返回的数据结构来调整数据处理部分的代码。

2024-08-07

在PHP中,反序列化是将序列化的字符串还原为PHP的值的过程。这通常用于存储或传输数据,以便在以后恢复原始的数据类型或对象。

PHP提供了unserialize()函数来执行反序列化。

例子:




// 假设我们有一个序列化的字符串
$serializedStr = 'O:8:"stdClass":1:{s:4:"data";s:6:"sample";}';
 
// 使用unserialize()函数进行反序列化
$originalData = unserialize($serializedStr);
 
// 现在$originalData包含了原始的对象或数据
print_r($originalData);

在这个例子中,$serializedStr是一个序列化的字符串,它代表了一个包含data属性的stdClass对象。反序列化后,我们可以通过print_r查看或者直接访问$originalData->data来获取原始的数据。

注意:反序列化不安全,如果接收到的序列化字符串来自不可信的来源,可能会导致安全问题,如远程代码执行。因此,在使用unserialize()时应该小心,并考虑使用例如json_encodejson_decode来替代,因为JSON是设计为人类可读的,不容易造成安全问题。

2024-08-07

在PHP正则表达式中,转义符用于匹配特殊字符。如果你想要在正则表达式中匹配一个特殊字符,比如 .()* 等,你需要在该字符前面加上反斜杠 \ 来转义它。

例如,如果你想要匹配一个点号 .,你需要在正则表达式中写成 \.

以下是一个简单的PHP代码示例,展示了如何使用转义符在正则表达式中匹配一个点号:




<?php
$text = "This is a sentence. This is another sentence.";
$pattern = "/\./"; // 转义点号以在正则表达式中匹配它
preg_match_all($pattern, $text, $matches);
print_r($matches[0]); // 输出匹配到的点号
?>

这段代码会输出所有在 $text 中出现的点号。由于点号在正则表达式中是特殊字符,所以我们需要用 \ 进行转义,以便正则表达式能够正确识别并匹配它。

2024-08-07

在实现数据抓取时,通常需要先抓取列表页面上的文章链接,然后再逐个抓取每篇文章的内容。以下是一个简单的PHP代码示例,展示了如何实现这一过程:




<?php
// 抓取列表页面的所有文章链接
function crawlListPage($listPageUrl) {
    $html = file_get_contents($listPageUrl);
    preg_match_all('/<a[^>]+href="(?<url>[^"]+)"[^>]*>/i', $html, $matches);
    $articleUrls = $matches['url'];
    return $articleUrls;
}
 
// 抓取单篇文章的内容
function crawlArticleContent($articleUrl) {
    $html = file_get_contents($articleUrl);
    // 这里使用简单的正则表达式来提取文章内容,实际项目中应该根据具体HTML结构调整
    preg_match('/<div[^>]+class="content"[^>]*>(?<content>.+?)<\/div>/is', $html, $matches);
    $content = $matches['content'];
    return $content;
}
 
// 示例使用
$listPageUrl = 'http://example.com/news';
$articleUrls = crawlListPage($listPageUrl);
 
foreach ($articleUrls as $url) {
    $content = crawlArticleContent($url);
    // 这里可以将内容保存到数据库或文件中
    echo $content;
}
?>

这个示例代码提供了两个函数crawlListPagecrawlArticleContent,分别用于抓取列表页面上的所有文章链接和抓取单篇文章的内容。在实际应用中,你需要根据实际的HTML结构调整正则表达式,并添加必要的错误处理和额外的功能,如处理分页、登录验证、限制抓取频率等。

2024-08-07

获取淘宝、天猫、京东和1688等电商平台的商品详情API接口通常需要遵循相应的API使用政策,并且通常这些接口都需要注册并获取API密钥。以下是一个使用PHP获取淘宝商品详情的示例代码,其他平台(如天猫、京东和1688)的接口获取方式类似。




<?php
 
$appKey = 'your_app_key'; // 替换为你的App Key
$appSecret = 'your_app_secret'; // 替换为你的App Secret
$sessionKey = 'your_session_key'; // 替换为你的Session Key
 
$taobaoMethod = 'taobao.item.get';
$itemId = '572050270876'; // 替换为你想获取详情的商品ID
 
// 构造请求参数
$params = [
    'method' => $taobaoMethod,
    'sessionKey' => $sessionKey,
    'app_key' => $appKey,
    'v' => '2.0',
    'format' => 'json',
    'item_id' => $itemId
];
 
// 构造请求签名
$params['sign'] = createSign($params, $appSecret);
 
// 发送请求
$response = sendRequest($params);
 
// 处理响应
print_r($response);
 
// 签名函数
function createSign($params, $appSecret) {
    ksort($params);
    $stringToSign = '';
    foreach ($params as $key => $value) {
        if ($key != 'sign' && $value !== '') {
            $stringToSign .= $key . $value;
        }
    }
    $stringToSign .= $appSecret;
    return strtoupper(md5($stringToSign));
}
 
// 发送请求函数
function sendRequest($params) {
    $url = 'https://api.taobao.com/router/rest';
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_POST, true);
    curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($params));
    $response = curl_exec($ch);
    curl_close($ch);
    return json_decode($response, true);
}
 
?>

在使用以上代码之前,请确保你已经注册了应用,并且拥有对应的App Key、App Secret和Session Key。以上代码中的createSign函数负责生成请求签名,sendRequest函数负责发送HTTP请求并获取响应。

注意:以上代码仅为示例,实际使用时需要处理可能出现的错误和异常,并确保遵守相关电商平台的API使用政策。

2024-08-07

在ThinkPHP 6.x 到 8.x 的多应用结构中使用注解路由,你需要确保你的项目已经启用了注解路由的支持。以下是一个简单的步骤和示例代码:

  1. 确保config/route.php文件中已经启用了注解路由:



// 启用注解路由
\think\facade\Route::rule('annotation');
  1. 在应用的控制器中使用注解定义路由。例如,在application/admin/controller/Index.php文件中:



namespace app\admin\controller;
 
use think\annotation\Route;
 
class Index
{
    /**
     * 首页
     * @Route("index")
     */
    public function index()
    {
        return 'Admin Index';
    }
}
  1. application/api/controller/User.php文件中定义另一个路由:



namespace app\api\controller;
 
use think\annotation\Route;
 
class User
{
    /**
     * 用户信息
     * @Route("user")
     */
    public function info()
    {
        return 'User Info';
    }
}

确保你的应用目录结构符合ThinkPHP的多应用规范,并且每个应用下都有controller目录,这样框架才能正确扫描并解析注解路由。

以上代码展示了如何在多应用环境下使用注解路由,你只需要按照这种方式在各个应用的控制器中添加路由注解即可。