- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我来自桌面开发,我习惯于在计算机内存中查看我的应用程序,直到它被用户终止。但对于 PHP,每次向服务器请求新页面时,我们都必须重建所有环境(类、对象、数据库连接等)。我们在 $_SESSION
数组中存储一些变量,以便在用户通过身份验证时保持用户登录状态。
如果在用户身份验证之后,我将 application
对象(以及应用程序创建的所有其他对象)放入当前 session 中,这样解释器就不需要在每个请求上重新加载所有内容,这是一个好主意吗? ? 如果这是一个好主意,那么只有我的服务器是专用的才好吗?
我认为它不会使响应更快,并且内存消耗更少。
<?php
// if user and password match:
session_start()
$_SESSION['Application'] = new TApplication('index/index');
$_SESSION['Application']->SetUser($userName);
$_SESSION['Application']->ConfigureUserPermissions;
$_SESSION['Application']->RUN;
<?php
// any request after user is logged and application is set:
session_start()
if (isSet($_SESSION['Application']) && (!$_SESSION['Application']->GetUser = null))
{
$_SESSION['Application']->ExecuteAction($_GET['url']);
}
我想知道是不是:
MVC
读取所有 PHP
文件来重建应用会更快吗?最佳答案
简短回答:不,这是一个坏主意。
扩展答案:
session 的存储方式取决于您的配置。默认情况下,它们通常存储在一个文件中(每个唯一 session 一个文件)。有时它们存储在数据库中。无论哪种方式,此存储都会首先序列化 $_SESSION
中的所有数据。
序列化速度相当快,但不如执行实际源代码那么快。因此,对每个请求取消序列化并再次序列化整个应用程序的对象树几乎肯定会比仅仅执行应用程序慢。因此,出于性能原因,您不应该这样做。
序列化相对节省空间,但不如源代码节省空间。所有应用程序数据都将序列化到磁盘,即使是每个用户/ session 不会更改的数据。那么,您在某个类(class)中埋藏的状态代码列表是什么呢?连载了。您用来处理上传的 mime 类型的扩展图?连载了。您最终会得到相当大的困惑数据,这些数据将很快耗尽磁盘空间,因为它基本上被复制到每个 session ,而不是仅在应用程序中存在一次。出于空间原因和 session 可管理性原因,您不应该这样做。
只有某些类型的数据可以被序列化。任何指向资源的内容(例如数据库连接、文件句柄等)都将无法序列化,并且在反序列化对象后尝试使用它时会中断。出于兼容性原因,您不应该这样做。
无论对象是否在 session 中,都会使用内存。将应用程序填充到 session 中对于内存没有任何好处。额外的序列化可能会导致内存使用量增加。
the interpreter does not need to reload everything on every request
这实际上并不是现代 PHP 环境(或为 Web 构建的任何其他语言环境)的真正工作方式。大多数(如果不是全部)源代码都已预加载。我认为您低估了环境快速执行代码的能力。与解释器和 Web 服务器对抗通常是一个坏主意。序列化和反序列化大量数据通常比重新执行所有代码的成本要高得多。
session 存储并不便宜。最好只放置处理当前 session 所需的数据,仅此而已,以保持较低的序列化成本。如果计算某些数据很慢并且您不想每次都重新计算它,那么当然,找到一个地方来存储它并且不要每次都重新计算它。如果是用户数据,那可能应该在数据库中。如果它特定于 session ,当然,将其放入 $_SESSION
中一段时间,但理想情况下,$_SESSION
中只有几个指向记录的小键在数据库或其他能够更有效地保存大量数据的地方。
关于php - 将整个应用程序放入$_SESSION 中可以吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19328706/
我最近开始经常做的一件事是在任务开始时检索一些数据并将其存储在 $_SESSION['myDataForTheTask'] 中。 现在这样做似乎很方便,但我对使用这种方法的性能、安全风险或类似情况一无
我注意到人们经常简单地写 我一直在使用: 有人可以解释检查变量是否设置时的区别吗(这就是我要使用它的目的)? 最佳答案 在 PHP 中,如果变量不存在(“未设置”),则 PHP 将吐出一个 E_
我一直被这个问题逼疯了。 我正在动态创建一个 session ID,以便在刷新时保留页面状态。 如果单击了一个页面元素,我会获取该元素的 ID 并将其传递给创建 session 变量的服务器端脚本:
我试过这样做: {{ $_GET['page'] }} 但还是不行。 最佳答案 对于 $_POST 变量使用这个: {{ app.request.parameter.get("page") }} 对于
你好, 我在拼凑一个简单的登录系统时遇到了一些问题。它在 Firefox 和 Chrome 中完美运行,但对于我来说,我似乎无法在 Windows 8 的 IE10 中结束 session 。 这是我
我有一个登录表单,以 session 电子邮件开头。现在,由于我希望能够通过表单更新电子邮件地址,而不破坏 session ,因此我需要将 session 更改为 ID。问题是它不会向我发送 id 值
我想存储一些信息,例如用户名、国家/地区名称等,并且需要在整个 session 期间可用。 实现这一目标的最佳方式是什么? 我有以下代码到 $_session 变量但没有结果。 page1.php
目前,我通过将 session 中的 key 与 MySQl 数据库中的相同 key 相匹配来验证用户 session 。我使用随机数重新生成 session ,该随机数在每个页面加载时都受 MD5
我遇到了这段代码的问题,我无法弄清楚问题出在哪里。所以当我运行这段代码时:if $row["count"] > 0 else块运行和 $_SESSION["error"]设置。 当$row["coun
我有一个关于 php $_SESSION 的问题。 假设我有一个用户 A 输入index.php,它输入了一些信息, $_SESSION['info'] = userA 现在用户B输入index.ph
我目前正在使用 onclick() 处理一张 table 将信息发送到 PHP 页面的元素。 基本思想是,如果单击一门类(class)(例如法语、数学、英语等),PHP 页面会检索该值,然后执行 SQ
我有条件地在给定页面上嵌入两个标题之一:“公司”或“学生和专业人士”。 我在登录时将用户类型(“”、“学生”或“专业”)存储在 $_SESSION 数组中,然后使用简单的 if 语句来确定要嵌入哪个
示例我有 100 个表单字段。每个字段都会有错误 session 。成功提交表单后,我想取消设置任何以 $_SESSION['submit_'] 开头的 session 首先我可以这样做 unset(
我正在处理一个项目,但 $_SESSION['username'] 没有回应 我使用了 var_dump,这就是我从该结果中得到的结果 我的问题是如何修复. array(4) { ["SES
我有条件地在给定页面上嵌入两个标题之一:“公司”或“学生和专业人士”。 我在登录时将用户类型(“”、“学生”或“专业”)存储在 $_SESSION 数组中,然后使用一个简单的 if 语句来确定要嵌入哪
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我正在为一家小公司开发一款供内部使用的简单应用。我很难让帐户登录正常工作,我相信这与 $_SESSION 没有像我预期的那样设置有关。现在我对 PHP 还很陌生,并且一直在学习。 index.php
我最近正在尝试解决一些关于 Session 的问题,现在我需要帮助才能使用 XAMPP 获得一个小页面。 我使用 4 个页面进行测试: 1) index.php是用户填写ID和PW的页面。 2) lo
我有两个单独的页面,一个页面是上传文件的地方,另一个页面显示信息。 在 imageupload.php 页面中,我在下面有这个 session : $_SESSION['fileImage']['na
我正在尝试更新数据库中的表。这是我到目前为止的代码: $query = "UPDATE user SET name='$name', pword='$pword', email='$email', a
我是一名优秀的程序员,十分优秀!