公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

關于網站文件自動備份程序的一點思考

admin
2010年12月9日 9:16 本文熱度 3734
摘要:
本文提供了一種使用asp php腳本來實現網站文件備份的思路,可以實現指定文件的按天備份。
個人網站往往在虛擬主機上,對主機的控制權限很小,因此不能使用諸如任務計劃來實現定時備份,我們需要換一種思路來實現相似的自動備份。
我們可以利用用戶對網站的訪問來實現對指定文件的按天備份。
基本思路是:用戶訪問網站 → 讀取最后備份日期、讀取當前日期然后比較,如果這兩個日期不一致則調用備份程序來實現對指定文件的備份,備份完成后再寫入新的日期標記,這時候用戶再訪問網站,日期已經是最新的了,就會跳過備份程序繼而執行其他程序。
分析這個思路:備份程序會在每天的第一個用戶訪問網站的時候啟動,便可以達到按天備份的效果,然而如果這天沒有用戶訪問則不會備份,這個并無多大關系,因為如果沒有用戶訪問網站,則網站內容不會發生很大改變。因此可以忽略這個情況。
需要注意的是,可能存在兩個人同時訪問網站,而同時啟動備份程序的情況,便可能會對備份內容造成覆蓋,對此我們可以在程序中添加判斷語句,如果文件已經存在則不去覆蓋它。
如果是要備份的兩個文件的文件名也相同則也會造成覆蓋,我們假定文件是全不相同的。
還有一個比較重要的問題是,在備份程序中必須采用的時期格式是 4位數年和2位數月、日,不足位數必須補零。 例如:2006-05-31只有這樣才能實現日期大小的比較,在asp中我們可以用一個小程序來實現,在php中已經有這樣的日期格式了。
下面詳細說明程序的構造,以asp為例。
===bak_set.asp===
復制代碼 代碼如下:Dim root_dir
root_dir = "/"
Dim bak_set
Set bak_set = Server.createobject("Scripting.Dictionary")
bak_set.Add "last_bak" , "2006-05-30"
bak_set.Add "file_list" , "data.mdb|system.mdb"
bak_set.Add "file_path" , "database/|database/"
bak_set.Add "bak_dir" , "backup/"
bak_set.Add "bak_date" , "2006-05-27|2006-05-28|2006-05-29|2006-05-30"
bak_set.Add "perfix" , "@"
bak_set.Add "date_out" , "2" 以上是備份設置文件,root_dir 是網站主目錄的路徑,是網站的一個全局設置,剩下的是備份設置,我們需要知道:要備份的文件名、路徑,備份在什么地方,備份保留幾天,備份文件的文件名前綴,兩個經常變化的設置是最后備份日期和備份過的日期的列表。在全部的路徑設置中都需要用“/”結束
Iso標準日期函數:
復制代碼 代碼如下:Function IsoDate(str_date) Dim temp
If IsDate(str_date) Then
temp = Year(str_date)&"-"& Right("0"&Month(str_date),2) & "-"& Right("0" & Day(str_date),2)
Else
temp = str_date
End If
IsoDate=temp
End Function
備份函數的思路:
先將備份設置讀取出到函數中的變量中,并且得到網站的服務器路徑
檢查備份主文件夾(例如:backup/)是否存在,當前備份文件夾(例如:backup/2006-05-30/)是否存在,然后將需要備份的文件保存到當前備份文件夾;
計算出備份文件的保存期,讀取以前的備份日期列表,然后兩者相比較,如果日期小于保存期則將備份文件刪除,如果不需要刪除則將日期轉存到新變量中。
生成新的備份設置并將之寫入原設置文件。
具體程序如下:
復制代碼 代碼如下:'==================================
' Function: 文件定時備份程序backup files
' Need var: root_dir , bak_set , isodate()
' Need file bak_set.asp
' return : true / false
'==================================
Function bak_start()
'1
Dim perfix
perfix = bak_set("perfix")
Dim files
files = split(bak_set("file_list"),"|")
Dim paths
paths = split(bak_set("file_path"),"|")
Dim now_date
now_date = isodate(date)
'response.Write(now_date)
Dim sev_root
sev_root = Server.MapPath(root_dir)
Dim bak_root
bak_root = sev_root & "\" & bak_set("bak_dir")
Dim bak_dir
bak_dir = bak_root & "\" & now_date & "\"
'2 create backup
Dim fso
Set fso = Server.createobject("Scripting.FileSystemObject")
If Not fso.FolderExists(bak_root) Then fso.CreateFolder(bak_root)
If Not fso.FolderExists(bak_dir) Then fso.CreateFolder(bak_dir)
'response.Write(bak_dir)
If Ubound(files) > Ubound(paths) Then
bak_start = false
Exit Function
End If
Dim i
'On Error Resume Next
For i = 0 To Ubound(files)
'response.Write(sev_root & "\" & paths(i) & files(i))
If fso.FileExists( sev_root & "\" & paths(i) & files(i) ) And Not fso.FileExists(bak_dir & perfix & files(i)) Then
fso.CopyFile sev_root & "\" & paths(i) & files(i) , bak_dir & perfix & files(i)
End If
Next
'3 Delete out of date backup
Dim date_out
date_out = isodate( date - Abs(bak_set("date_out")) )
'response.Write(date_out)
Dim dates
Dim bak_date
bak_date = ""
dates = split(bak_set("bak_date"),"|")
For i = 0 To Ubound(dates)
If dates(i) < date_out Then
'On Error Resume Next
If fso.FolderExists(bak_root & "\" & dates(i)) Then fso.DeleteFolder bak_root & "\" & dates(i)
Else
bak_date = bak_date & dates(i) & "|"
End If
Next
bak_date = bak_date & now_date
bak_set("bak_date") = bak_date
'4 update settings
Dim f
Set f = fso.OpenTextFile(Server.MapPath("bak_set.asp"),2,true)'2 寫
Dim temp ,keys
temp = "<%" &vbCrlf & _
"Dim root_dir"&vbCrlf & _
"root_dir = """& root_dir &"""" &vbCrlf & _
"Dim bak_set" &vbCrlf & _
"Set bak_set = Server.createobject(""Scripting.Dictionary"")"&vbCrlf
keys = bak_set.Keys
For i = 0 to Ubound(keys)
temp = temp & "bak_set.Add """&keys(i)&""" , """ & bak_set(keys(i)) & """" & vbCrlf
Next
temp = temp & "%" & ">"
f.write temp
f.Close
Set fso = Nothing
Set f = Nothing
bak_start = true
End Function 最后,也是最重要的,那就是安全問題,如果備份的文件能被瀏覽器打開,那后果可能是很嚴重的!所以應當謹慎選取備份文件夾,如果服務器允許訪問網站的外部目錄,那么應當把備份的路徑也指定到網站外部,例如:網站根目錄解析到了 XXX/htdoc/ 而你對此也有讀寫權限 xxx/ 那么就可以將備份文件加指定到 xxx/backup/ 這樣就比較安全。如果沒有這樣的權限,那么就必須保證,需要備份的文件本身就是安全的。

該文章在 2010/12/9 9:16:27 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产综合中文无码 | 国产精品大陆第一页 | a级毛片高清免费视频在线 a级毛片高清免费视频在线播放 | 精品五月天六月花一区二区 | 国产精品毛片在线大全 | 国产午夜精品1区2区3福利 | 国产成人欧美综合在线影院 | 国产精品无码国模私拍视频 | 成人午夜精品一级毛片 | 极品粉嫩虎白女毛片 | 97精品国产自在现线拍 | av激情亚洲| 高清女厕偷拍一区二区三区 | 91久久亚洲国产成人综合精品 | 1区2区3区4区精品免费视频 | 国产在线精品一区二区不卡麻 | 国产精品白浆无码流出免费看 | 国产日韩av毛片 | 国产在线观看午夜电影视频网站 | 成av人片在线观看无码 | 国产午夜理论片不卡在线观看 | 国产日韩欧美一区二区东京热a | 91在线精品一区二区体验升级 | 国产成人无码午夜视频在线播放 | 国产精品亚洲第一区在线28石 | 国产精品无码网 | 精品无人区一码二码三码四码 | 国产视频一区欧美二区日本三区动 | 国产盗摄xxxx视频xxxx | 国产片婬乱一级毛片视频1 国产片婬乱一级毛片丫丫 国产片婬乱一毛片a | 国产麻豆影视传媒 | 国产轮奸精品一区二区三区 | 精品国无码产在线 | 91久久香蕉国产线看 | 国产日韩精品欧美二区 | 成人色网站欧美大片在线观看 | 国产精品专区第一页 | 国产精品动漫无码1区 | 国产成人午夜片在线观看 | 国产成人免费永久播放视频平台 | 国产一级精品一区二区三区 |