全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

PHP导出当前登录用户数据到Excel文件的完整教程

本文详解如何安全地从mysql数据库查询并导出当前登录用户的专属数据(如工单记录)到excel,涵盖sql条件过滤、会话变量校验、防sql注入及基础excel生成方法。

在PHP中将数据库查询结果导出为Excel文件,关键在于精准筛选用户数据保障代码安全性。你遇到的问题——WHERE UserName = '".$_SESSION['useruid']."' 无法返回预期结果,通常源于字段名与会话变量名不匹配或类型不一致。

✅ 正确做法:确认字段与会话键名一致

首先,请检查以下三点:

  • 数据库表 tickets_list 中用于标识用户的字段名是 UserName、username 还是 user_id?
  • 当前登录用户信息存入 $_SESSION 时使用的键名是 'username'、'useruid' 还是 'uid'?
  • 若数据库中存储的是用户名(如 john_doe),则应使用 $_SESSION['username'];若存储的是用户ID(如 123),而字段名为 user_id,则需改为:
$query = "SELECT * FROM tickets_list WHERE user_id = ?"; // 推荐使用预处理
$stmt = mysqli_prepare($conn, $query);
mysqli_stmt_bind_param($stmt, "i", $_SESSION['useruid']);
mysqli_stmt_execute($stmt);
$result = mysqli_stmt_get_result($stmt);
⚠️ 注意:直接拼接 $_SESSION 变量(如 "WHERE UserName = '".$_SESSION['useruid']."'")存在严重SQL注入风险,务必避免。

✅ 安全导出Excel(CSV格式示例)

PHP原生导出Excel最轻量、兼容性最好的方式是生成 .csv 文件(Excel可直接打开):

// 1. 设置响应头,触发下载
header('Content-Type: text/csv; charset=utf-8');
header('Content-Disposition: attachment; filename="my_tickets_' . date('Y-m-d') . '.csv"');

// 2. 打开输出缓冲区作为文件句柄
$output = fopen('php://output', 'w');

// 3. 写入表头(根据实际字段调整)
fputcsv($output, ['ID', 'Title', 'Status', 'Created At', 'Priority']);

// 4. 执行安全查询(推荐预处理)
$query = "SELECT id, title, status, created_at, priority 
          FROM tickets_list 
          WHERE username = ?";
$stmt = mysqli_prepare($conn, $query);
mysqli_stmt_bind_param($stmt, "s", $_SESSION['username']); // 假设用 username 字段 & session 键
mysqli_stmt_execute($stmt);
$result = mysqli_stmt_get_result($stmt);

// 5. 写入每行数据
while ($row = mysqli_fetch_assoc($result)) {
    fputcsv($output, $row);
}

fclose($output);
exit;

? 重要注意事项

  • 始终验证会话状态:导出前添加 if (!isset($_SESSION['username'])) { die('Not logged in'); }
  • 字段名大小写敏感:MySQL在Linux下对列名区分大小写,请用 DESCRIBE tickets_list 确认真实字段名。
  • 字符编码统一:CSV中含中文时,务必在 header() 中声明 charset=utf-8,并在首行写入BOM(可选):
    fwrite($output, "\xEF\xBB\xBF"); // UTF-8 BOM for Excel compatibility
  • ❌ 避免 mysql_* 函数(已废弃)和字符串拼接SQL。

✅ 进阶建议

如需生成真正的 .xlsx 文件(支持样式、多Sheet等),推荐使用开源库 PhpSpreadsheet:

composer require phpoffice/phpspreadsheet

然后用 setCellValue() 逐单元格写入,兼顾安全与专业性。

掌握以上方法,你就能稳定、安全地为每位登录用户导出其专属数据,并杜绝越权导出风险。


# mysql  # php  # linux  # excel  # composer  # 编码  # session  # office  # csv  # sql注入  # sql  # if  # die  # 字符串  # bom  # 数据库  # 的是  # 字段名  # 推荐使用  # 数据库查询  # 进阶  # 最好的  # 就能  # 键名  # 句柄  # 并在 


相关文章: C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  实现虚拟支付需哪些建站技术支撑?  如何快速搭建安全的FTP站点?  如何在建站之星绑定自定义域名?  大学网站设计制作软件有哪些,如何将网站制作成自己app?  C#怎么使用委托和事件 C# delegate与event编程方法  建站之星图片链接生成指南:自助建站与智能设计教程  如何用PHP工具快速搭建高效网站?  ,sp开头的版面叫什么?  全景视频制作网站有哪些,全景图怎么做成网页?  网站制作员失业,怎样查看自己网站的注册者?  高防服务器租用首荐平台,企业级优惠套餐快速部署  哈尔滨网站建设策划,哈尔滨电工证查询网站?  文字头像制作网站推荐软件,醒图能自动配文字吗?  南宁网站建设制作定制,南宁网站建设可以定制吗?  如何在腾讯云服务器快速搭建个人网站?  如何快速配置高效服务器建站软件?  七夕网站制作视频,七夕大促活动怎么报名?  建站之星安装后如何自定义网站颜色与字体?  济南专业网站制作公司,济南信息工程学校怎么样?  如何在Windows 2008云服务器安全搭建网站?  建站之星如何优化SEO以实现高效排名?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  建站之星在线客服如何快速接入解答?  建站之星IIS配置教程:代码生成技巧与站点搭建指南  建站VPS推荐:2025年高性能服务器配置指南  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何高效利用200m空间完成建站?  如何选择美橙互联多站合一建站方案?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  视频网站制作教程,怎么样制作优酷网的小视频?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何在阿里云高效完成企业建站全流程?  移民网站制作流程,怎么看加拿大移民官网?  三星网站视频制作教程下载,三星w23网页如何全屏?  网站网页制作专业公司,怎样制作自己的网页?  如何在IIS中新建站点并配置端口与IP地址?  已有域名如何快速搭建专属网站?  如何通过PHP快速构建高效问答网站功能?  手机网站制作与建设方案,手机网站如何建设?  建站ABC备案流程中有哪些关键注意事项?  C#如何在一个XML文件中查找并替换文本内容  如何用免费手机建站系统零基础打造专业网站?  如何配置IIS站点权限与局域网访问?  岳西云建站教程与模板下载_一站式快速建站系统操作指南  建站OpenVZ教程与优化策略:配置指南与性能提升  建站之星后台密码遗忘?如何快速找回? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。