开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1485|回复: 5
收起左侧

[分享] PHP+MySQL中间件

[复制链接]
结帖率:100% (27/27)
发表于 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, 下载次数: 10)

签到天数: 3 天

发表于 昨天 18:01 | 显示全部楼层   重庆市重庆市
支持一下!!!!!
回复 支持 反对

使用道具 举报

结帖率:97% (34/35)

签到天数: 12 天

发表于 2024-4-28 09:34:53 | 显示全部楼层   湖南省长沙市

没有太好的想法,  我去做的时候 通常都是  一个接口实现一个业务,  客户Duan没有直接连接数据库来着,  或者  数据库直接由客户Duan去操作。  不通过服务器去访问了
回复 支持 反对

使用道具 举报

签到天数: 8 天

发表于 2024-4-27 17:03:34 | 显示全部楼层   河北省石家庄市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (27/27)

签到天数: 9 天

 楼主| 发表于 2024-4-27 15:38:31 | 显示全部楼层   四川省成都市
大兔崽子 发表于 2024-4-27 15:32
这样的话就太麻烦了。  而且 一个语句就要发送一次请求。  ...

有何高见
回复 支持 反对

使用道具 举报

结帖率:97% (34/35)

签到天数: 12 天

发表于 2024-4-27 15:32:54 | 显示全部楼层   湖南省长沙市
这样的话就太麻烦了。  而且 一个语句就要发送一次请求。  ...
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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