PHP:URL 传参时 MySQL 记录只显示一个单词的解决方案

花韻仙語
发布: 2025-08-07 16:52:00
原创
282人浏览过

php:url 传参时 mysql 记录只显示一个单词的解决方案

本文将解决 PHP 从 MySQL 数据库读取数据并通过 URL 传递时,由于空格导致参数值截断的问题。我们将介绍如何使用 rawurlencode() 函数对 URL 参数进行编码,确保完整地传递包含空格的字符串,并简要提及接收端页面参数处理的注意事项。

在 PHP 开发中,经常需要将从数据库中读取的数据通过 URL 传递给其他页面。然而,当数据中包含空格等特殊字符时,直接拼接 URL 可能会导致参数值被截断,只传递了第一个单词。这是因为 URL 本身不允许直接包含空格。要解决这个问题,我们需要对 URL 参数进行编码。

使用 rawurlencode() 函数进行 URL 编码

PHP 提供了 rawurlencode() 函数,可以将字符串进行 URL 编码,将空格替换为 %20 等 URL 安全的字符。

立即学习PHP免费学习笔记(深入)”;

以下是修改后的代码示例:

<?php
    foreach($conn->query('SELECT book_category, COUNT(*) FROM books GROUP BY book_category') as $row) {
        echo "<tr>";
        echo "<td>" . "<a href='sidebar_cat_display.php?book_cat=" . rawurlencode($row['book_category']) . "'>" . $row['book_category'] . "</a>" . "</td>";
        echo "</tr>"; 
    }
?>
登录后复制

在这个示例中,rawurlencode($row['book_category']) 将 book_category 字段的值进行 URL 编码,确保包含空格的字符串能够完整地传递到 sidebar_cat_display.php 页面。

千图设计室AI海报
千图设计室AI海报

千图网旗下的智能海报在线设计平台

千图设计室AI海报 172
查看详情 千图设计室AI海报

接收端页面参数处理

在 sidebar_cat_display.php 页面,你需要使用 $_GET 数组来获取传递过来的 book_cat 参数。由于我们使用了 rawurlencode() 进行编码,因此接收到的参数值是经过编码的。如果需要使用原始的字符串,可以使用 rawurldecode() 函数进行解码。

例如:

<?php
$book_category = isset($_GET['book_cat']) ? rawurldecode($_GET['book_cat']) : '';

// 现在 $book_category 变量包含了原始的 book_category 值
echo "你选择的分类是:" . htmlspecialchars($book_category); // 使用 htmlspecialchars 防止 XSS 攻击
?>
登录后复制

注意事项

  • 始终使用 rawurlencode() 对 URL 参数进行编码,特别是当参数值可能包含空格、特殊字符或非 ASCII 字符时。
  • 在接收端页面,根据需要使用 rawurldecode() 对接收到的参数值进行解码。
  • 为了防止跨站脚本攻击 (XSS),在使用接收到的参数值之前,始终使用 htmlspecialchars() 函数对其进行转义。

总结

通过使用 rawurlencode() 函数对 URL 参数进行编码,可以有效地解决由于空格等特殊字符导致参数值截断的问题,确保数据能够完整地传递到目标页面。同时,在接收端页面需要注意对接收到的参数值进行解码和转义,以确保数据的安全性和正确性。

以上就是PHP:URL 传参时 MySQL 记录只显示一个单词的解决方案的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号