- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
大家好之前我想设置无法更改的重要事实:
我们有一个 webapi(类似于 restful 服务),其中有一个 url,用户可以以 json 方式显示。但是我们有 85k+ 条记录,当我们尝试将它们全部复制时,php 崩溃了(当我们只查找 1 条记录时不会发生这种情况),我们有 2 个代码可以使用,但它们都没有带来所有用户
版本 1
<?php
//security variables
$variableName = 'name';
$variableValue = 'value';
//system variables
ob_end_flush();
ob_start();
if(isset($_GET[$variableName]) && $_GET[$variableName]== $variableValue){
$dbVars = array();
$query = 'SELECT * FROM users_data ';
foreach ($_GET as $key => $value) {
if( $key != $variableName && $key != 'sized' && $key != 'devmode'){
array_push($dbVars, $key."='".$value."'");
}
}
if( count($dbVars) > 0 ){
$query .= 'WHERE '.implode(' AND ', $dbVars);
}
$result = mysql($w['database'], $query);
$results = array();
while($row = mysql_fetch_assoc($result)){
array_push($results, $row);
}
echo json_encode($results);
}
?>
版本 2(使用冲洗)
<?php
//security variables
$variableName = 'name';
$variableValue = 'value';
//system variables
ob_end_flush();
ob_start();
if(isset($_GET[$variableName]) && $_GET[$variableName]== $variableValue){
$dbVars = array();
$query = 'SELECT * FROM users_data ';
foreach ($_GET as $key => $value) {
if( $key != $variableName && $key != 'sized' && $key != 'devmode'){
array_push($dbVars, $key."='".$value."'");
}
}
if( count($dbVars) > 0 ){
$query .= 'WHERE '.implode(' AND ', $dbVars);
}
$result = mysql($w['database'], $query);
echo "[";
while($row = mysql_fetch_assoc($result)){
$results = array();
foreach($row as $key => $value){
array_push($results, '"'.$key.'":"'.$value.'"');
}
echo '{'.implode(',',$results).'}';
ob_flush();
}
echo "]";
}
?>
当我们想要获取数据库中所有用户都是85k时,结果是none,因为内存限制我们如何才能让所有用户都能使用它?
最佳答案
首先,您的代码充满了 SQL 注入(inject)漏洞。任何人都可以拥有您的数据库。这是你的问题。
现在,PHP 内存不足的原因是您正在使用缓冲查询。
http://php.net/manual/en/mysqlinfo.concepts.buffering.php
Queries are using the buffered mode by default. This means that query results are immediately transferred from the MySQL Server to PHP and then are kept in the memory of the PHP process.
阅读我提供的链接(老天爷,它使用 mysqli)并使用无缓冲模式将您的结果集流式传输到客户端。
另外,不要将整个结果集 array_push() 到一个数组中。
另外,显然,
array_push($dbVars, $key."='".$value."'");
如果任何值包含 "或其他转义字符,将生成无效的 JSON。
关于Php MySQL 查询在资源有限的托管中内存不足,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43120434/
我会尝试尽可能详细地描述我的问题,但如果需要更详细的解释,请告诉我。 为了简化,假设我有 3 个 DLL(实际上我有更多,但我猜这不是很重要): managed-1.dll - 托管 DLL(用 C#
我有一个 Tomcat 6 JSF Web 应用程序,我想使用 CDI bean 来设置它。不过,我必须逐渐将项目转换为 CDI。 我的问题是:CDI bean 和传统的 JSF 托管 bean 可以
我计划将 Web 应用程序从使用 JSF 托管 Bean 转换为使用 CDI 托管 Bean。我知道我需要执行以下操作: 在 WEB-INF 中添加一个空 beans.xml 文件。 将所有 JSF
我在裸域上运行我的解析应用程序。 Parse 并没有让我的生活变得轻松。 起初我很难设置它,因为大多数 DNS 托管服务不允许根域上的 CNAME,而 Parse 需要 CNAME。 决定尝试使用 C
如果您使用 Firebase 托管 将请求定向到 云函数 通过重写,“通过”托管的请求流量是否会记入 Firebase 托管 国标转出 ? (忽略 Cloud Function 的计费) 换句话说,
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
我有一个特定的用例,我正尝试使用 Firebase 托管来解决,它如下: 我正在使用 Gridsome 生成静态网站 在构建之前,Gridsome 使用 Graphql 并从 Headless CMS
您好,我有一个blazor页面,我想在其中显示一个变量。 这个变量从另一个线程(通过Websocket接收数据的另一个线程)获取更新,我想以线程安全的方式显示它: Blazor页面 @page "/n
我想使用 Firebase 托管来托管一个 angular 应用程序,我需要创建一个重定向到另一个 URL 中的一些旧文件。 根据 Firebase 文档,您可以进行基本重定向 "redirects"
我正在尝试找出满足电子学习平台以下要求的最佳方法。 我在其中编辑视频的后端,以便可以将它们彼此链接(例如youtube-comment函数) 用户只能在访问平台时观看视频(不允许下载!) 视频只能通过
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
我想这是一个相当深入的主题,因此任何带有洞察信息的网址也很乐意接受。我一直在使用原生 DirectX,但从未管理过。另一方面,大多数情况下,在开发不需要高级 GPU 渲染的其他类型的应用程序时,我通常
我刚刚将一个网站部署到 Firebase 托管,效果非常好 - 设置非常简单。 但是,我的问题是,有什么方法可以使访问该网站受到身份验证的限制吗?这是一个管理面板,只有我的团队才能访问。有什么方法可以
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找书籍、工具、软件库、教程或其他场外资源的问题对于 Stack Overflow 来说是
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
我刚刚将一个网站部署到 Firebase 托管,它运行良好 - 设置非常简单。 但是,我的问题是,有什么方法可以通过身份验证限制对网站的访问?这是一个只有我的团队才能访问的管理面板。有什么方法可以用密
如果我想托管一个对公众用处不大的应用程序(例如,一个将点打印到控制台的程序,它们的数量取决于现在的时间),我喜欢在启动板中的方式不必乱扔全局托管站点的命名空间并用诸如 HourDot 之类的名称填充它
我是一名优秀的程序员,十分优秀!