开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 2225|回复: 13
收起左侧

[分享] PHP+MySQL中间件

[复制链接]
结帖率:94% (30/32)
发表于 2024-4-27 12:35:31 | 显示全部楼层 |阅读模式   四川省成都市
分享例程
界面截图:
备注说明: pdo中间件
[PHP] 纯文本查看 复制代码
<?php
// 数据库信息
$host = '127.0.0.1'; // 数据库主机名
$dbname = ''; // 数据库名称
$username = ''; // 数据库用户名
$password = ''; // 数据库密码
$key = 'fegvdvregdb';// 验证密文

try {
    // 创建PDO对象并连接到数据库
    $pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);
    // 设置错误模式为异常模式
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
    // 发生错误时输出错误信息
    echo "Connection failed: " . $e->getMessage();
}
// 获取POST请求中的SQL语句
$sql = $_POST['sql'];

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

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

// 验证msgkey是否与网站内置的一致
if ($msgkey != $key) {
    // 如果不一致,返回code状态码为202和错误信息
    $result['code'] = 202;
    $result['message'] = 'Invalid msgkey';
} else {
    try {
        // 执行SQL语句
        $stmt = $pdo->prepare($sql);
        $stmt->execute();

        // 获取cha询结果
        if (strpos(strtolower($sql), 'select') === 0) {
            $result['data'] = $stmt->fetchAll(PDO::FETCH_ASSOC);
        } else {
            $result['data'] = array('affected_rows' => $stmt->rowCount());
        }
    } catch (PDOException $e) {
        // 发生错误,设置code为201并输出错误信息
        $result['code'] = 201;
        $result['message'] = $e->getMessage();
    }
}

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

以上是PHP代码,填上你的mysql数据库信息,就可以通过api接口操作你的数据库,由于表的设计不同,PHP只有两个参数,一个msgkey用于验证提交信息是否为你设定的key密文,否则拒绝操作,sql就为数据库的sql语句即可,执行成功返回对应结果,失败返回错误信息,反正数据库返回什么,接口就会返回什么,输出格式都是json格式的。



易语言对接示例:
数据 = 编码_utf8到gb2312 (到文本 (网页_访问_对象 (填写你的php文件链接, 1, “msgkey=填写后台拟定的密文&sql=填写对应的sql语句”)))


例子:


数据 = 编码_utf8到gb2312 (到文本 (网页_访问_对象 (#api链接, 1, “msgkey=fegvdvregdb&sql=SELECT * FROM user WHERE 账号 = 4916168”)))



返回示例:


{"code":200,"data":[{"账号":"4916168","密码":"1234567","归属":"教师","登录次数":"18","最后登录时间":"2024-04-23 11:19:16","备注":"开发者账号"}]}


sql.zip (1.02 KB, 下载次数: 47)
结帖率:94% (30/32)

签到天数: 21 天

 楼主| 发表于 2024-7-10 08:28:46 | 显示全部楼层   四川省成都市
本帖最后由 whb666 于 2024-7-10 13:25 编辑

[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 {
            // 创建PDO对象并连接到数据库
            $pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);
            // 设置错误模式为异常模式
            $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

            // 执行解密后的SQL语句
            $stmt = $pdo->prepare($decrypted_sql);
            $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());
            }
        } catch (PDOException $e) {
            // 发生错误,设置code为201并输出错误信息
            $result['code'] = 201;
            $result['message'] = $e->getMessage();
        }
    }
}

// 输出JSON格式的结果
header('Content-Type: application/json');
echo json_encode($result, JSON_UNESCAPED_UNICODE);
?>
回复 支持 反对

使用道具 举报

发表于 2024-7-8 10:39:41 | 显示全部楼层   江西省南昌市
回复 支持 反对

使用道具 举报

发表于 2024-7-7 23:00:26 | 显示全部楼层   江西省南昌市
dddddddddddddddddddddddddddddddddddddddddddddddddddddddddd
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 12 天

发表于 2024-7-2 16:01:53 | 显示全部楼层   山东省青岛市
本帖最后由 kyo9766 于 2024-7-2 16:04 编辑

感觉 key 可以在最开始验证,如果key不对,就不链接mysql,
然后post的SQL语句可以加密一下,然后PHP解密,如果php解密失败,也不连接mysql

解密成功 且 key 正确,然后再执行连接数据库 操作数据库,然后返回数据

感谢分享
回复 支持 反对

使用道具 举报

结帖率:33% (1/3)

签到天数: 5 天

发表于 2024-6-18 01:49:44 | 显示全部楼层   重庆市重庆市
这样直接执行sql语句确实好么~~~~~
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 3 天

发表于 2024-6-14 22:00:34 | 显示全部楼层   广东省佛山市

支持一下!!!!!
回复 支持 反对

使用道具 举报

结帖率:50% (7/14)

签到天数: 6 天

发表于 2024-6-9 15:10:36 | 显示全部楼层   广东省梅州市
每访问一次就连接一次MYSQL,这样会不会导致MYSQL连接次满了。后面的人连接不上
回复 支持 反对

使用道具 举报

签到天数: 16 天

发表于 2024-6-4 22:23:15 | 显示全部楼层   湖北省宜昌市
调试返回空是什么情况啊
回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 2024-5-12 18:01:02 | 显示全部楼层   重庆市重庆市
支持一下!!!!!
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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