【发布时间】:2010-10-17 22:49:02
【问题描述】:
现在,桌面应用程序自我更新是非常标准的做法。在 Mac 上,我书中使用 Sparkle 的每个非 Apple 程序都是立竿见影的。对于 Windows 开发人员,this has already been discussed at length。我还没有找到关于自我更新网络应用程序的信息,希望您能提供帮助。
我正在构建一个旨在像 Wordpress 或 Drupal 一样安装的 Web 应用程序 - 将其解压缩到一个目录中,点击某个安装页面,然后就可以使用了。为了获得广泛的服务器兼容性,我被要求使用 PHP 和 MySQL —— 那是 **MP 吗?无论如何,它必须是广泛的跨平台。就上下文而言,这基本上是针对小型企业的统一 Web 消息传递应用程序。这不是另一个 CMS 平台,想想 webmail。
我想了解自更新网络应用程序。首先,(1)这是一个坏主意吗?从 Wordpress 2.7 开始,自动更新是一个按钮,这看起来很简单,但我可以想象有很多方法可能会变得非常非常错误。此外,Web 文件可被 Web 进程写入的想法不是安全漏洞吗?
(2) 值得开发时间吗?世界上可能有数百万个 WP 安装,因此 WP 团队花费时间来简化它可能是值得的,在全球范围内节省了数百万工时。我只能想象我的软件安装了几千次 - 构建自我升级值得投入时间,还是我可以假设足够老练的用户首先下载和安装 Web 软件可以通过升级清单?
如果这不是安全灾难或浪费时间,那么 (3) 我正在寻找以前做过的任何人的建议。您是否在数据库中保留版本表?您如何管理数据库升级?在自更新 Web 应用程序的上下文中,您使用什么方法来回滚部分升级?使用 ORM 层是否更容易或更难?您是保留版本更改的增量,还是每次都把整个事情搞砸?
感谢您对此的看法。
【问题讨论】:
-
我刚才问过similar question,这可能会有所帮助。
-
好问题。我认为自我升级不仅减少了安装时间,而且让您能够即时修复分布式安全问题。一旦发现安全漏洞,许多开源应用程序就会被大规模利用。但你是对的,有很多事情可能会出错。如果用户自定义他们的代码怎么办?
标签: php mysql security upgrade