gpt4 book ai didi

php - 使用 PHP 身份验证进行 HTTP 身份验证

转载 作者:行者123 更新时间:2023-11-28 02:54:09 25 4
gpt4 key购买 nike

我正在为我的网站创建一个成员(member)区域,并且它已经在运行。我使用 mysql 和 php 对成员进行身份验证,效果非常好。

但现在出现问题,我想为成员(member)提供将文件上传到系统的可能性,并且这些文件应该仅对登录的成员(member)可用。

我知道我可以将这些文件存储到数据库甚至文件系统中,并通过 php 为它们提供服务,但是当成员上传更大的文件时,这对于服务器来说会变得非常繁重。这些文件可能有 20MB 甚至更大。

我想让 apache 提供文件服务,但只需要找到一种自动进行 http 身份验证的方法,这样用户就不需要登录两次。我想可以在一个用户名和密码后面进行http身份验证,就像当用户登录php和mysql身份验证时,透明地同时javascript等也会执行http身份验证,每个成员都会执行使用相同的凭据进行 http 身份验证。当然,我不想将这些 http 身份验证凭据存储在 javascript 文件中,但类似 ​​ajax 的解决方案可能可以解决问题。我只是不知道该怎么做。

最佳答案

您似乎将身份验证(提供某种登录方式)与 HTTP 身份验证(专门使用 HTTP 协议(protocol)进行身份验证,并且浏览器向用户显示弹出窗口)混淆了。

您可能需要前者,这样您就可以设置登录页面的样式。在这种情况下,您必须使用 PHP 或某些脚本语言来检查用户是否已登录。fpassthrureadfile对于某些网站来说可能是很好的解决方案;它们速度很快,并且针对此类工作进行了优化。

如果您确实想在 Web 浏览器而不是 PHP 中进行文件处理工作,一种解决方案是创建唯一的、短期的文件名。例如,您可以使用 link 在 PHP 中创建指向该文件的硬链接(hard link)。然后将用户重定向到临时文件名。将硬链接(hard link)存储在数据库中并在一段时间后将其删除。

关于php - 使用 PHP 身份验证进行 HTTP 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3074409/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com