草庐IT

php - 无需回发自动从服务器向客户端发送警报消息

coder 2023-10-12 原文

我正在尝试在我的电子商务网站上实现一项功能,但我不知道如何做或从哪里开始。

我想提醒已经验证并登录到我的网站的客户,如果其他人使用他们的(登录用户的)登录凭据意图进行黑客攻击或任何其他安全风险,请尝试使用任何其他人再次登录计算机或浏览器。我可以提醒已经登录的用户尽快更改密码以提高安全性,或者如果是同一用户试图从多个客户端登录,那么他将被限制。

我将在我的数据库中维护一个已登录用户的列表,并将验证用户是否已登录。但是我如何才能动态发送警报,而无需用户从客户端引发任何回发 因为一旦进行其他登录尝试,我的脚本就会立即提醒已经登录的用户。

我希望我已经明确了我的要求。如果有任何模糊之处,请发表评论,我会澄清。

我正在使用 PHP 5.3 和 MySQL 5.5。该站点将托管在 Linux 主机上。

我认为 AJAX 会有所帮助,但如何。我一直在寻找解决方案很多天,但没有成功。

请帮忙。

最佳答案

你说的是长轮询。

“长轮询”是用来描述一种技术的名称:

  • 发出 AJAX 请求(利用 javascript 框架,例如 jQuery) 服务器等待请求的数据可用, 循环并休眠(您的服务器端 PHP 脚本)
  • 这个循环在数据返回给客户端并处理后重复 (通常在您的 AJAX 请求的 onComplete 回调函数中)

这实质上模拟了从客户端到服务器的连续实时流。出于多种原因,我不会在 PHP 中这样做。这里有一些:

  • PHP 是为快速执行而生的(不是为了等待)
  • PHP 将强制您在服务器端进行某种轮询,并且 依靠sleep()
  • PHP 会占用您的 RAM,同时每个进程的生成进程也是如此 请求(Apache 会这样做)
  • 不要为此目的使用 Apache 服务器!Apache 服务器将能够更好地处理数以万计的短有限连接,而不是几百个持久连接。无论你走哪个方向(长轮询 vs ajax)你可能想要考虑设置一个更轻的网络服务器专用于聊天。像 Lighttpd 或 Nginx 这样的东西,在相同的内存/CPU 条件下,它们可以有更多的 max_clients 或更多的同时请求。

但您可以做到这一点,使用 sleep 、轮询数据库(或更好的缓存 APC/Memcache)。

如果您想做类似的事情,请跳入一些可以处理事件的技术:Python(Tornado、gevent、eventlet、Twisted 等)、Ruby(Eventmachine 等)、Erlang、Scala、服务器端 JavaScript(node .js, …), cometd …

相反,您可以使用简单的方法

看看这张表。

你可以这样做

  1. 创建一些名为 ex 的数据库表。 log 当用户登录到你的网站时,记录一些不同的数据(比如ip,登录日期...)。将 signout_date 字段留空。 (当用户注销时,只需更新此表并放置当前日期)因此,如果有人在您的网站上,注销日期字段必须为空

  2. 然后在每个用户事件中,检查您的表中的 user_id:是否有多个行具有相同的 user_id 和空的注销日期字段。然后只需通知用户,另一台电脑使用您的凭据登录。

关于php - 无需回发自动从服务器向客户端发送警报消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9461801/

有关php - 无需回发自动从服务器向客户端发送警报消息的更多相关文章

  1. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  2. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  3. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  4. ruby-on-rails - 在 Rails 中调试生产服务器 - 2

    您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除

  5. jquery - 我的 jquery AJAX POST 请求无需发送 Authenticity Token (Rails) - 2

    rails中是否有任何规定允许站点的所有AJAXPOST请求在没有authenticity_token的情况下通过?我有一个调用Controller方法的JqueryPOSTajax调用,但我没有在其中放置任何真实性代码,但调用成功。我的ApplicationController确实有'request_forgery_protection'并且我已经改变了config.action_controller.consider_all_requests_local在我的environments/development.rb中为false我还搜索了我的代码以确保我没有重载ajaxSend来发送

  6. ruby - 使用 Ruby 通过 Outlook 发送消息的最简单方法是什么? - 2

    我的工作要求我为某些测试自动生成电子邮件。我一直在四处寻找,但未能找到可以快速实现的合理解决方案。它需要在outlook而不是其他邮件服务器中,因为我们有一些奇怪的身份验证规则,我们需要保存草稿而不是仅仅发送邮件的选项。显然win32ole可以做到这一点,但我找不到任何相当简单的例子。 最佳答案 假设存储了Outlook凭据并且您设置为自动登录到Outlook,WIN32OLE可以很好地完成此操作:require'win32ole'outlook=WIN32OLE.new('Outlook.Application')message=

  7. ruby-on-rails - 在 Flash 警报 Rails 3 中显示错误消息 - 2

    如果我在模型中设置验证消息validates:name,:presence=>{:message=>'Thenamecantbeblank.'}我如何让该消息显示在闪光警报中,这是我迄今为止尝试过的方法defcreate@message=Message.new(params[:message])if@message.valid?ContactMailer.send_mail(@message).deliverredirect_to(root_path,:notice=>"Thanksforyourmessage,Iwillbeintouchsoon")elseflash[:error]

  8. ruby - 是否可以在不实际发送或读取数据的情况下查明 ruby​​ 套接字是否处于 ESTABLISHED 或 CLOSE_WAIT 状态? - 2

    s=Socket.new(Socket::AF_INET,Socket::SOCK_STREAM,0)s.connect(Socket.pack_sockaddr_in('port','hostname'))ssl=OpenSSL::SSL::SSLSocket.new(s,sslcert)ssl.connect从这里开始,如果ssl连接和底层套接字仍然是ESTABLISHED,或者它是否在默认值7200之后进入CLOSE_WAIT,我想检查一个线程几秒钟甚至更糟的是在实际上不需要.write()或.read()的情况下关闭。是用select()、IO.select()还是其他方法完成

  9. ruby - 我的 Ruby IRC 机器人没有连接到 IRC 服务器。我究竟做错了什么? - 2

    require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame

  10. ruby - Rails 开发服务器、PDFKit 和多线程 - 2

    我有一个使用PDFKit呈现网页的pdf版本的Rails应用程序。我使用Thin作为开发服务器。问题是当我处于开发模式时。当我使用“bundleexecrailss”启动我的服务器并尝试呈现任何PDF时,整个过程会陷入僵局,因为当您呈现PDF时,会向服务器请求一些额外的资源,如图像和css,看起来只有一个线程.如何配置Rails开发服务器以运行多个工作线程?非常感谢。 最佳答案 我找到的最简单的解决方案是unicorn.geminstallunicorn创建一个unicorn.conf:worker_processes3然后使用它:

随机推荐