自动更新系统Server端(php实现)

03年刚毕业的时候,在一家公司里面做彩票的自助售票系统,由于部署的终端比较多,升级系统不能靠人工一台一台的升级,因此当时就接了一个任务设计并实现自动更新系统。当时刚毕业,经验不是很足,网上相关的资料也很少,当时实现的方式很老土,文件的传输采用socket自己来写server段,读取文件数据,然后传送给客户端,而一个补丁中可能存在多个文件,当时也没有产品的概念,补丁都不是打包好的补丁包,而是一个一个文件的下载,而每次更新的时候,都要一个文件一个文件的部署配置。
时隔这么多年,现在网上还是没有找到一个简单易用的自动更新系统,由此产生了自己做一个并开源的想法。在我们的项目中,有很多开源的第三方组件,比如日志记录的,通讯相关的,数据库相关等等。现在做的系统又大多是网络相关,所以自动更新系统,也是一个非常有用的并且可以抽象出来的组件。
鉴于此就有了下面的组件。


<?php
define('ISOK', 0);
define('ISERROR', -1);
define('PATCH_NOTEXIST', 101);
define('SOFTID_NOTEXIST', 102);
define('FROMVERSION_ISNULL', 103);

define('RET', 'ret');
define('COUNT', 'count');
define('SIZE', 'size');
define('URL', 'url');
define('DIR', 'dir');

define('ID', 'id');
define('FV', 'fv');
define('OS', 'os');
define('NAME', 'name');
define('PREFIX', 'prefix');
define('PATCHID', 'patchid');

$id = $_GET[ID];
$fromVersion = $_GET[FV];
$os = $_GET[OS];
$fileName = $_GET[NAME];
$mypath = "patch/$id";

$rsp = array();
$rsp[RET] = ISERROR;
if (!is_dir($mypath)) {
$rsp[RET] = SOFTID_NOTEXIST;
echo json_encode($rsp);
return;
}

if (NULL == $fromVersion) {
$rsp[RET] = FROMVERSION_ISNULL;
echo json_encode($rsp);
return;
}

$regex = "/$fromVersion-([\w.\d]*)/";

$isPatch = FALSE;
$toVersion = "";
$handle = opendir($mypath);
while ($item = readdir($handle)) {
if ('.' == $item || '..' == $item) {
continue;
}
if ($fromVersion == $item) {
$isPatch = TRUE;
}
if (preg_match($regex, $item, $result)) {
if ($result[1] > $toVersion) {
$toVersion = $result[1];
}
}
}
closedir($handle);

if ("" != $toVersion) {
$url = "$mypath/$fromVersion-$toVersion";
if (NULL != $os) {
$url = "$url/$os";
}
$file = $url.'/'.$fileName;
if (is_file($file) && $fileSize = filesize($file)) {
$rsp[RET] = ISOK;
$rsp[COUNT] = 1;
$rsp[URL][0] = $url;
$rsp[NAME][0] = $fileName;
$rsp[SIZE][0] = $fileSize;
} else {
$rsp[RET] = PATCH_NOTEXIST;
}
} else {
if ($isPatch) {
$url = "$mypath/$fromVersion";
if (NULL != $os) {
$url = "$url/$os";
}
$regex = '';
$prefix = $_GET[PREFIX];
if (NULL != $prefix) {
$regex = '/^'.$prefix.'_([\d]+).[A-Za-z0-9]{2,3}$/';
} else {
$regex = '/^([\d]+).[A-Za-z0-9]{3}$/';
}

$count = -1;
$patchID = $_GET[PATCHID];
$handle = opendir($url);
while ($item = readdir($handle)) {
if ('.' == $item || '..' == $item) {
continue;
}
if (preg_match($regex, $item, $result)) {
if ($result[1] > $patchID) {
$count ++;
$file = $url.'/'.$result[0];
if (is_file($file) && $fileSize = filesize($file)) {
$rsp[URL][$count] = $url;
$rsp[NAME][$count] = $result[0];
$rsp[SIZE][$count] = $fileSize;
}
}
}
}
if ($count > -1) {
$rsp[RET] = ISOK;
$rsp[COUNT] = $count + 1;
}
}
}
echo json_encode($rsp);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值