开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1495|回复: 21
收起左侧

[其它源码] php+mysql中间件

[复制链接]
结帖率:98% (39/40)
发表于 2024-10-25 18:05:57 | 显示全部楼层 |阅读模式   山东省潍坊市
分享源码
界面截图: -
是否带模块: -
备注说明: -
[PHP] 纯文本查看 复制代码
<?php
// 数据库信息
$host = '127.0.0.1'; // 数据库主机名
$dbname = ''; // 数据库名称
$username = ''; // 数据库用户名
$password = ''; // 数据库密码
$key = 'fegvdvregdb';// 验证密文

// 获取 POST 请求中的 msgkey 参数
$msgkey = $_POST['msgkey'];

// 初始化返回结果
$result = array(
    'code' => 200,
);

// 验证 msgkey 是否与网站内置的一致
if ($msgkey!= $key) {
    // 如果不一致,返回 code 状态码为 202 和错误信息
    $result['code'] = 202;
    $result['message'] = 'Invalid msgkey';
} else {
    // 解密 SQL 语句
    $encrypted_sql = $_POST['sql'];
    $decrypted_sql = openssl_decrypt($encrypted_sql, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);

    if ($decrypted_sql === false) {
        // 解密失败,返回 code 状态码为 203 和错误信息
        $result['code'] = 203;
        $result['message'] = 'Decryption failed';
    } else {
        try {
            // 使用数据库连接池获取连接
            $connectionPool = new ConnectionPool($host, $dbname, $username, $password);
            $pdo = $connectionPool->getConnection();

            // 设置连接超时时间(示例为 5 秒)
            $pdo->setAttribute(PDO::ATTR_TIMEOUT, 5);

            // 预处理 SQL 语句并绑定参数(如果有参数的话)
            $stmt = $pdo->prepare($decrypted_sql);
            // 假设 $params 是包含参数的数组
            if (isset($params)) {
                foreach ($params as $key => $value) {
                    $stmt->bindValue($key, $value);
                }
            }
            $stmt->execute();

            // 获取cha询结果
            if (strpos(strtolower($decrypted_sql), 'select') === 0) {
                $result['data'] = $stmt->fetchAll(PDO::FETCH_ASSOC);
            } else {
                $result['data'] = array('affected_rows' => $stmt->rowCount());
            }

            // 将连接归还到连接池
            $connectionPool->releaseConnection($pdo);
        } catch (PDOException $e) {
            // 记录错误日志
            error_log('Database error: '. $e->getMessage());

            // 发生错误,设置 code 为 201 并输出错误信息
            $result['code'] = 201;
            $result['message'] = $e->getMessage();
        }
    }
}

// 输出 JSON 格式的结果
header('Content-Type: application/json');
echo json_encode($result, JSON_UNESCAPED_UNICODE);

class ConnectionPool
{
    private $host;
    private $dbname;
    private $username;
    private $password;
    private $connections = [];
    private $maxConnections = 10; // 设置最大连接数

    public function __construct($host, $dbname, $username, $password)
    {
        $this->host = $host;
        $this->dbname = $dbname;
        $this->username = $username;
        $this->password = $password;
    }

    public function getConnection()
    {
        if (empty($this->connections)) {
            return new PDO("mysql:host=$this->host;dbname=$this->dbname", $this->username, $this->password);
        } else {
            return array_pop($this->connections);
        }
    }

    public function releaseConnection($connection)
    {
        if (count($this->connections) < $this->maxConnections) {
            $this->connections[] = $connection;
        } else {
            $connection = null;
        }
    }
}
?>


[color=rgba(0, 0, 0, 0.85)]此代码实现了一个与数据库交互的系统,通过验证密文来确保请求的合法性,然后对加密的 SQL 语句进行解密并执行,最后返回执行结果。同时,使用了连接池来管理数据库连接,以提高性能和资源利用率。

评分

参与人数 3好评 +2 精币 +4 收起 理由
kyo9766 + 1 感谢分享,很给力!~
玄骨 + 1 + 1 支持开源~!感谢分享
abpyu + 1 + 2 支持开源~!感谢分享

查看全部评分


结帖率:0% (0/1)

签到天数: 7 天

发表于 2025-2-14 13:38:10 | 显示全部楼层   广东省东莞市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:87% (27/31)

签到天数: 10 天

发表于 2025-1-19 13:50:27 | 显示全部楼层   山东省济宁市
多谢分享
回复 支持 反对

使用道具 举报

结帖率:96% (22/23)

签到天数: 14 天

发表于 2024-12-31 16:29:55 | 显示全部楼层   山东省淄博市
易语涯怎么弄呢  不知道有没有全部例子
回复 支持 反对

使用道具 举报

签到天数: 9 天

发表于 2024-12-4 07:03:11 | 显示全部楼层   北京市北京市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

签到天数: 15 天

发表于 2024-12-2 19:32:21 | 显示全部楼层   浙江省湖州市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:76% (25/33)
发表于 2024-11-9 22:24:11 | 显示全部楼层   江苏省徐州市
#在这里快速回复# 感谢分享啊
回复 支持 反对

使用道具 举报

结帖率:95% (194/204)

签到天数: 25 天

发表于 2024-10-28 22:09:39 | 显示全部楼层   安徽省芜湖市
需要一个对应的易语言加密例子
回复 支持 反对

使用道具 举报

签到天数: 7 天

发表于 2024-10-28 17:45:36 | 显示全部楼层   河南省郑州市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

签到天数: 24 天

发表于 2024-10-28 09:38:48 | 显示全部楼层   浙江省宁波市
感谢分享,支持开源!!!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表