
本教程旨在解决php聊天服务中,集成登录功能后出现的用户名无法显示和消息无法发送的问题。文章详细分析了php会话管理、条件判断逻辑以及`header()`重定向函数使用不当导致的常见错误,并提供了优化后的代码示例,帮助开发者正确存储用户会话数据、确保页面重定向的准确性,从而恢复聊天服务的核心功能。
在PHP聊天服务中集成登录功能后,出现消息无法发送和用户名无法显示的问题,通常是由于以下几个方面的原因:
原代码在admin.php中尝试通过来显示用户名。然而,$username变量仅在login.php的表单提交处理逻辑中被定义,并且是一个局部变量。它并未被存储到会话中,因此在admin.php页面中是无法直接访问到的。要解决此问题,需要将登录成功的用户名存储到PHP的$_SESSION全局变量中,以便在其他页面中获取。
根据admin.php中的J*aScript代码,消息的发送是通过AJAX请求post.php来完成的:$.post("post.php", {text: clientmsg});。由于post.php文件的具体实现未提供,我们无法直接诊断其内部问题。但是,如果登录流程本身存在缺陷(例如,用户未能成功登录导致会话未正确建立或用户身份未被post.php识别),可能会间接影响消息的发送功能。本教程将重点解决登录和用户名显示问题,为消息发送功能的正常运作奠定基础。
login.php文件中存在以下几个关键问题:
为了解决上述问题,我们将对login.php和admin.php进行如下优化:
Manus
全球首款通用型AI Agent,可以将你的想法转化为行动。
250
查看详情
核心思想是将所有PHP处理逻辑(包括会话启动、登录验证和重定向)前置到HTML内容输出之前。同时,引入辅助函数以提高代码可读性和复用性,并确保用户名被正确存储到会话中。
<?php
session_start(); // 始终在任何输出之前启动会话
// 辅助函数:设置会话数据
function setSessionData($name, $value) {
$_SESSION[$name] = $value;
}
// 辅助函数:重定向到admin页面并设置会话数据
function redirectWithData($username = '') {
setSessionData('login', true);
setSessionData('username', $username); // 将用户名存储到会话中
header('Location:admin.php'); // 执行重定向
die(); // 确保重定向后脚本停止执行,防止后续代码执行
}
// 如果用户已登录,则直接重定向到admin页面
if (isset($_SESSION['login'])) {
header('Location:admin.php');
die();
}
// 处理表单提交
if (isset($_POST['submit'])) {
$username = $_POST['username'];
$password = $_POST['password'];
// 验证用户名和密码,使用elseif确保逻辑严谨
if ($username === 'admin' && $password === 'password') {
redirectWithData($username);
} elseif ($username === 'admon' && $password === 'password') {
redirectWithData($username);
} else {
// 用户名和密码不匹配时显示错误信息
echo "<div class='alert alert-danger'>Username and Password do not match.</div>";
}
}
?>
<html>
<head>
<meta http-equiv='content-type' content='text/html;charset=utf-8' />
<title>Login</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
</head>
<body>
<div class="container">
<h3 class="text-center">Login</h3>
<!-- 登录表单 -->
<form action="" method="post">
<div class="form-group">
<label for="username">Username:</label>
<input type="text" class="form-control" id="username" name="username" required>
</div>
<div class="form-group">
<label for="pwd">Password:</label>
<input type="password" class="form-control" id="pwd" name="password" required>
</div>
<button type="submit" name="submit" class="btn btn-default">Login</button>
</form>
</div>
</body>
</html>在admin.php中,我们将不再尝试访问不存在的$username['username'],而是从会话中获取已存储的用户名。
<?php
session_start();
if(!isset($_SESSION['login'])) {
header('LOCATION:login.php'); die();
}
if(isset($_GET['logout'])){
//Simple exit message
// 确保 $_SESSION['username'] 存在再使用
$username_for_logout = isset($_SESSION['username']) ? $_SESSION['username'] : 'Guest';
$logout_message = "<div class='msgln'><span class='left-info'>User <b class='user-name-left'>". $username_for_logout ."</b> has left the chat session.</span><br></div>";
file_put_contents("log.html", $logout_message, FILE_APPEND | LOCK_EX);
session_destroy();
header("Location: login.php"); //Redirect the user
}
?>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>English Pricks</title>
<meta name="description" content="A Group Chat." />
<link rel="stylesheet" href="style.css" />
</head>
<body>
<div id="wrapper">
<div id="menu">
<!-- 从会话中获取用户名并显示 -->
<p class="welcome">Welcome, <b><?php echo isset($_SESSION['username']) ? $_SESSION['username'] : 'Guest'; ?></b>. <a href="https://docs.google.com/document/d/1S2O4y2z_8Yu_mibQQGEU4E9pHdeckPfo5pI7FtM0YrI/edit" target="_blank">Image Dump...</a></p>
<p>Emoji's → </p>
<button id="emoji-button" style="border: none;">?</button>
<p class="logout"><a id="exit" href="#">Le*e</a></p>
</div>
<div id="chatbox">
<?php
if(file_exists("log.html") && filesize("log.html") > 0){
$contents = file_get_contents("log.html");
echo $contents;
}
?>
</div>
<form name="message" action="">
<input name="usermsg" type="text" id="usermsg" style="outline: none;" spellcheck="true"/>
<input name="submitmsg" type="submit" id="submitmsg" value="↑" />
</form>
</div>
<script type="text/j*ascript" src="./jquery.min.js"></script>
<script src="emoji.js"></script>
<script type="text/j*ascript">
document.addEventListener('DOMContentLoaded', function () {
var picker = new EmojiButton();
var button = document.querySelector('#emoji-button');
button.addEventListener('click', function () {
picker.showPicker(button);
picker.on('emoji', emoji => {
document.querySelector('#usermsg').value += emoji;
});
});
});
</script>
<script type="text/j*ascript">
$(document).ready(function () {
$("#submitmsg").click(function(){
var clientmsg = $.trim($("#usermsg").val());
if(clientmsg.length >= 1){ // Prevents Spamming the Enter Key
$.post("post.php", {text: clientmsg});
$("#usermsg").val("");
}else{
}
return false;
});
function loadLog() {
var oldscrollHeight = $("#chatbox")[0].scrollHeight - 20; //Scroll height before the request
$.ajax({
url: "log.html",
cache: false,
success: function (html) {
$("#chatbox").html(html); //Insert chat log into the #chatbox div
//Auto-scroll
var newscrollHeight = $("#chatbox")[0].scrollHeight - 20; //Scroll height after the request
if(newscrollHeight > oldscrollHeight){
$("#chatbox").animate({ scrollTop: newscrollHeight }, 'normal'); //Autoscroll to bottom of div
}
}
});
}
setInterval (loadLog, 1000);
$("#exit").click(function () {
var exit = confirm("Are you sure you want to le*e?");
if (exit == true) {
// 将 "index.php?logout=true" 修改为 "?logout=true"
window.location = "?logout=true";
}
});
});
</script>
</body>
</html>将退出链接的重定向目标改为相对路径?logout=true,使其更具通用性,并确保重定向到当前页面以触发admin.php顶部的退出逻辑。
// ... (admin.php 文件中的J*aScript代码)
$("#exit").click(function () {
var exit = confirm("Are you sure you want to le*e?");
if (exit == true) {
// 将 "index.php?logout=true" 修改为 "?logout=true"
window.location = "?logout=true";
}
});
// ... (admin.php 文件中的J*aScript代码)以上就是解决PHP聊天服务登录后消息发送与用户名显示异常问题的详细内容,更多请关注php中文网其它相关文章!
# php
# javascript
# word
# java
# jquery
# css
# 是一个
# 营销推广策略新媒体推广
# 几个
# 网站推广应聘面试题
# 大环境下的网站推广工作
# 长沙推广产品网站
# 网上营销怎么推广
# 企业网站TDK优化
# seo公司外包推广渠道
# 本地网站建设产品
# 面试seo的问题有哪些
# 保定推广网站建设公司
# 怎么改
# 不匹配
# 未被
# 错误报告
# 发送到
# 全局变量
# 表单
# 重定向
# g
# ajax
# bootstrap
# js
# html
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
优化推广96088 】
【
技术知识133117 】
【
IDC资讯59369 】
【
网络运营7196 】
【
IT资讯61894 】
相关推荐:
《火花chat》搜索好友方法
京东快递包裹信息查询入口 京东快递官方查询平台入口
Pandas中基于动态偏移量实现DataFrame列值位移的策略
优酷官网登录入口电脑版 优酷官网网址入口
优化2xN网格最大路径和的动态规划算法实践
易车网官网直达入口 易车网在线登录入口
《tt语音》超级玩家开通方法
铁路12306入口 铁路12306官网版入口登录网址
如何在mysql中比较InnoDB和MyISAM区别
优化CSS动画与J*aScript定时器协同:构建稳定Toast提示
J*aScript中高效处理用户输入:从Keyup事件到表单提交的优化实践
sublime如何配置PHP开发环境_在sublime中运行与调试PHP代码
苹果电脑如何快速截图并编辑 苹果电脑截屏标注快捷操作
批改网官网首页登录 批改网学生用户登录入口
J*aScript实现下拉菜单驱动的动态表格数据展示
PSD转AI文件的简单方法
《盗墓笔记手游》技能介绍
基于 Flink 和 Kafka 实现高效流处理:连续查询与时间窗口
lol小红书怎么|直播|?lol小红书|直播|是什么意思?
QQ阅读小说搜索入口地址_QQ阅读小说搜索入口地址搜索在线阅读
b站怎么设置动态仅粉丝可见_b站动态粉丝可见设置方法
发布小红书怎么屏蔽粉丝?屏蔽粉丝能看到吗?
Google Cloud Functions 时区处理指南:理解与最佳实践
德邦快递会员怎么开通
Lar*el Eloquent中通过Join查询关联数据表:解决多行子查询问题
如何用mysql实现客户反馈管理_mysql客户反馈数据库方法
《procreate》绘制渐变效果教程
《书耽》更换手机号方法
中大网校app做题记录清除方法
创建快捷方式启动系统保护
pubmed数据库官方主页_pubmed学术论文查找官网直达
QQ网页版入口导航 QQ网页版在线访问通道
苹果手机缓存怎么清除_苹果手机缓存如何清除iphone各版本操作步骤
酷狗音乐多音轨设置教程
深入理解随机递归函数的确定性:内部节点、叶节点与时间复杂度分析
iphone16系列配置参数介绍
冬季去哪个城市旅游更有可能观测到极光
Win10截图远程协助 Win10远程桌面截屏法【场景应用】
荣耀magicv5怎么上手测评
PHP页面重载后变量状态保持:实现用户档案连续浏览的教程
sublime text 4如何安装_最新版sublime下载与汉化教程
PHP中获取HTTP响应状态消息:方法与限制
睡觉时心跳快是什么原因 夜间心悸如何应对
一点万象签到领积分指南
word文档中的分隔符有哪些不同类型和用途_Word分隔符类型与用途方法
申通快递查询 申通物流快递单实时查询入口
5G和6G的连接密度有什么区别 6G每平方公里能连接多少设备
Django模型动态关联检查:高效管理复杂关系
支付宝登录刷脸不是本人如何解决
在Django中动态检查模型关联:一种灵活的解决方案
2025-11-12
运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。