- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我对如何做到这一点感到困惑。假设用户在我的电子商务网站上创建了一个帐户,然后开始将产品添加到他们的购物篮中。如果我将用户的用户名和密码存储在数据库表中,并使用 session /cookie 来管理他们购物篮中的产品,我需要做什么才能将用户的购物篮连接到他们的帐户,以便当他们登录时他们将能够看到他们之前存储的项目?
我是否首先允许用户登录,查询他们是否登录成功,然后为他们的用户名创建一个 session /cookie 变量?或者我是否必须将用户购物车项目存储在数据库中并将其与用户帐户表连接?
我对如何将购物篮中的元素存储到表格中感到困惑。这甚至是正确的方法吗?
还没有代码,我想在开始编码之前正确创建数据库,只需要一些建议。谢谢
最佳答案
如果您有两张表,一张用于用户,一张用于元素,您可以执行如下操作。
通过在序列化数组中添加和删除 item_id 来管理当前的购物篮商品,您可以将其同时存储在用户表和 session 中,使它们保持同步。例如,如果用户是第一次访问您的商店(未登录且购物篮为空),您可以像这样创建 session 。
session_start();
我们开始 session 。
if (isset($_SESSION['current_basket']) {
$current_basket = unserialize($_SESSION['current_basket']);
} else {
$current_basket = array();
}
因为这是我们的访问者第一次访问我们的页面, session 变量 current_basket 将不会被设置,这意味着上面的 if 语句将不会运行,而只是在名为 current_basket 的变量中创建一个空的 PHP 数组。
现在,当访问者将商品添加到购物车时,我们只需要该商品在您的数据库中的 ID 并将其添加到 current_basket 数组中。
$current_basket[] = $item_id;
然后我们立即用新数组更新 session 变量,并在此过程中对其进行序列化。
$_SESSION['current_basket'] = serialize($current_basket);
您现在有一个适当的、可用的数组,其中包含该人购物篮的所有产品 ID。
现在,让我们假设用户已登录。我们会检查这一点,然后再添加一个步骤。
$sql = "UPDATE users SET current_basket=" . serialize($current_basket) . " WHERE id=$user_id"
// Execute that query.
现在相同的数组在数据库中,然后您可以在用户登录时将其提取并设置为 session 变量。
您可以在每次添加或删除产品时运行这一系列步骤,使其在 session 和数据库中保持更新。
为了便于解释,这显然是一个非常淡化的概念。显然,您需要更好地管理阵列。例如,如果产品已经存在,则不将其添加到购物篮中,从数组中删除项目等。
关键是序列化数组,并始终存储在 session 中,如果用户已登录,则存储在用户表中。
然后当用户返回并登录时,您可以使用数据库中的数组为他们设置 session 中的数组,从他们上次访问您的站点开始。
关于php - 将用户购物篮连接到他们的用户帐户? PHP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14531774/
我在 JavaScript 文件中运行 PHP,例如...... var = '';). 我需要使用 JavaScript 来扫描字符串中的 PHP 定界符(打开和关闭 PHP 的 )。 我已经知道使
我希望能够做这样的事情: php --determine-oldest-supported-php-version test.php 并得到这个输出: 7.2 也就是说,php 二进制检查 test.
我正在开发一个目前不使用任何框架的大型 php 站点。我的大问题是,随着时间的推移慢慢尝试将框架融入应用程序是否可取,例如在创建的新部件和更新的旧部件中? 比如所有的页面都是直接通过url服务的,有几
下面是我的源代码,我想在同一页面顶部的另一个 php 脚本中使用位于底部 php 脚本的变量 $r1。我需要一个简单的解决方案来解决这个问题。我想在代码中存在的更新查询中使用该变量。 $name)
我正在制作一个网站,根据不同的情况进行大量 PHP 重定向。就像这样...... header("Location: somesite.com/redirectedpage.php"); 为了安全起见
我有一个旧网站,我的 php 标签从 因为短标签已经显示出安全问题,并且在未来的版本中将不被支持。 关于php - 如何避免在 php 文件中写入
我有一个用 PHP 编写的配置文件,如下所示, 所以我想用PHP开发一个接口(interface),它可以编辑文件值,如$WEBPATH , $ACCOUNTPATH和 const值(value)观
我试图制作一个登录页面来学习基本的PHP,首先我希望我的独立PHP文件存储HTML文件的输入(带有表单),但是当我按下按钮时(触发POST到PHP脚本) )我一直收到令人不愉快的错误。 我已经搜索了S
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: What is the max key size for an array in PHP? 正如标题所说,我想知道
我正在寻找一种让 PHP 以一种形式打印任意数组的方法,我可以将该数组作为赋值包含在我的(测试)代码中。 print_r 产生例如: Array ( [0] => qsr-part:1285 [1]
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我在 MySQL 数据库中有一个表,其中存储餐厅在每个工作日和时段提供的菜单。 表结构如下: i_type i_name i_cost i_day i_start i_
我有两页。 test1.php 和 test2.php。 我想做的就是在 test1.php 上点击提交,并将 test2.php 显示在 div 中。这实际上工作正常,但我需要向 test2.php
我得到了这个代码。我想通过textarea更新mysql。我在textarea中回显我的MySQL,但我不知道如何更新它,我应该把所有东西都放进去吗,因为_GET模式没有给我任何东西,我也尝试_GET
首先,我是 php 的新手,所以我仍在努力学习。我在 Wordpress 上创建了一个表单,我想将值插入一个表(data_test 表,我已经管理了),然后从 data_test 表中获取所有列(id
我有以下函数可以清理用户或网址的输入: function SanitizeString($var) { $var=stripslashes($var); $va
我有一个 html 页面,它使用 php 文件查询数据库,然后让用户登录,否则拒绝访问。我遇到的问题是它只是重定向到 php 文件的 url,并且从不对发生的事情提供反馈。这是我第一次使用 html、
我有一个页面充满了指向 pdf 的链接,我想跟踪哪些链接被单击。我以为我可以做如下的事情,但遇到了问题: query($sql); if($result){
我正在使用 从外部文本文件加载 HTML/PHP 代码 $f = fopen($filename, "r"); while ($line = fgets($f, 4096)) { print $l
我是一名优秀的程序员,十分优秀!