在PHP中保存和加载活动日志的最佳方法是什么?
在我开始之前,这是一项任务。我只是在寻求帮助和指导:) 我正在开发一个健身房会员网站,允许用户注册、登录和预订活动 除了活动预订系统外,我的一切都正常工作,这就是我需要的指导。我有一个txt文件,其中包含每个活动的名称、时间、总共可以参加多少活动的活动日志。我想在每项活动的末尾加上一行确切的参与者。因此,允许用户预订活动,从而将其用户名添加到活动中 这正是我目前打印activity.txt文件的方式(除了最右边的“Book”按钮之外)在PHP中保存和加载活动日志的最佳方法是什么?,php,Php,在我开始之前,这是一项任务。我只是在寻求帮助和指导:) 我正在开发一个健身房会员网站,允许用户注册、登录和预订活动 除了活动预订系统外,我的一切都正常工作,这就是我需要的指导。我有一个txt文件,其中包含每个活动的名称、时间、总共可以参加多少活动的活动日志。我想在每项活动的末尾加上一行确切的参与者。因此,允许用户预订活动,从而将其用户名添加到活动中 这正是我目前打印activity.txt文件的方式(除了最右边的“Book”按钮之外) NumberOne 3 Wednes
NumberOne 3 Wednesday 8am (BOOK)
NumberTwo 7 Thursday 10am (BOOK)
NumberThree 20 Monday 1pm (BOOK)
NumberFour 15 Tuesday 5pm (BOOK)
基本上,我需要的是“Book”按钮的指导。一旦按下“Book”按钮,它将为用户预订活动
以下是我的activity.txt文件当前的外观:
NumberOne,3,Wednesday 8am
NumberTwo,7,Thursday 10am
NumberThree,20,Monday 1pm
NumberFour,15,Tuesday 5pm
这是我目前正在打印活动的代码:
function bookActivity()
{
$fileContentsArray = file("activity.txt");
echo "<table>";
foreach($fileContentsArray as $one_persons_data)
{
echo '<tr>';
$splitted = preg_split('/,/', $one_persons_data);
foreach ($splitted as $one)
{
echo "<td>$one</td>";
}
echo '</tr>';
}
echo "</table>";
}
非常感谢您提供的所有帮助。对于如何做到这一点,我感到非常困惑。这里有一个粗略的指导原则(我不会详细说明,因为这毕竟是家庭作业),我将保留一个假设,即您不允许使用任何与文本文件不同的内容,但可以创建/删除任意数量的文本文件
文件(…)
解析活动txt文件explode()
- 检查请求的活动文件是否存在。如果不存在,请创建 一个空的
- 计算当前已预订的用户数,并将其与允许的最大值进行比较
- 如果更少,则将新用户添加到文件中,否则拒绝预订
内爆()
- 这听起来不像是一个日志;它听起来像是一个基于文件的数据库
- 如果允许,请使用.csv文件(而不是.txt)并使用进行解析
- 因为它是您的数据库,所以您需要对它进行写入。您可以使用它 (FWIW,您的.txt文件已经是csv文件,您只是没有这样对待它。) 根据具体问题:单击“Book”只需将课程名称传递给脚本,脚本将向该课程添加当前用户(如果他们尚未注册)。您可以使用POST(HTML表单)或GET(链接和查询参数)传递课程名称 使用链接(GET)可能如下所示:
- 有几件事:
$bookingUrl = "register.php?courseName=".urlencode($courseName);
<form action="register.php" method="POST">
<input type="hidden" value="<?= $courseName; ?>" />
<input type="submit" value="Book" />
</form>
使用表单(POST)可能如下所示:
$bookingUrl = "register.php?courseName=".urlencode($courseName);
<form action="register.php" method="POST">
<input type="hidden" value="<?= $courseName; ?>" />
<input type="submit" value="Book" />
</form>
这可能是数据库派上用场的情况之一。同意。尽管我们被迫使用txt文件:(你试图做的csv
是最适合的格式,imho.Yeah。虽然不幸的是我们必须使用txt文件。对我来说似乎很不公平,因为XML或csv是行业标准,而不是愚蠢的txt文件。感谢STT LCU的出色指导。感谢Martin Bean的编辑。对PHP来说仍然非常陌生,所以我必须尝试导入。)这是我能做的最好的了…如果我能的话哈哈。不过,我不知道如何创建一个.txtfile@JadeMulholland看我的编辑,它会帮助你。另外,谷歌真的是你的朋友:试着搜索“写一个文件PHP”;)谢谢,编辑清除了一切。文件内容似乎是一个奇妙的功能,我真的很好奇。我想我一定要尝试一下这个方法!啊,很有趣。我不确定csv和txt之间的区别。非常有用。谢谢:)我想我已经决定使用这种方法,因为我不知道如何处理多个txt文件,也不知道如何创建它们。谢谢你的帮助,丹。查看所有的“f”(文件)函数,最重要的是:、、fputcsv和fgetcsv。是的,使用3个文件的想法与真实的数据库结构最为相似(其中有课程表、用户表和注册表)。我的想法更倾向于一种更难构建但更易于使用和解析的方法。您建议我如何将用户名保存到文件中?例如,您可以在我的问题中看到我的activities.txt文件。我将在哪里添加所有用户名?