來源于:
https://qqdie.com/archives/typecho-templates-backup-and-restore.html
typecho模板設置數據會在你換模板的時候被清空,這樣的設置其實我還是蠻喜歡的,不會有數據殘留。
然而WP用戶轉到typecho后跟我抱怨,說模板換成別的然后再切換回來,之前設置好的數據都沒了,希望我在yodu模板上動動手腳解決這個問題。
然而我是有些遲疑的,東西不是你說做我就要做的,我必須試一下...否則答應太快又搞不出來,豈不是很難受!
不過既然發了這篇文章,就說明已經搞定了

代碼
在themeConfig($form)
函數里添加
$db = Typecho_Db::get();
$sjdq=$db->fetchRow($db->select()->from ('table.options')->where ('name = ?', 'theme:Yodu'));
$ysj = $sjdq['value'];
if(isset($_POST['type']))
{
if($_POST["type"]=="備份模板數據"){
if($db->fetchRow($db->select()->from ('table.options')->where ('name = ?', 'theme:Yodubf'))){
$update = $db->update('table.options')->rows(array('value'=>$ysj))->where('name = ?', 'theme:Yodubf');
$updateRows= $db->query($update);
echo '<div class="tongzhi">備份已更新,請等待自動刷新!如果等不到請點擊';
?>
<a href="<?php Helper::options()->adminUrl('options-theme.php'); ?>">這里</a></div>
<script language="JavaScript">window.setTimeout("location=\'<?php Helper::options()->adminUrl('options-theme.php'); ?>\'", 2500);</script>
<?php
}else{
if($ysj){
$insert = $db->insert('table.options')->rows(array('name' => 'theme:Yodubf','user' => '0','value' => $ysj));
$insertId = $db->query($insert);
echo '<div class="tongzhi">備份完成,請等待自動刷新!如果等不到請點擊';
?>
<a href="<?php Helper::options()->adminUrl('options-theme.php'); ?>">這里</a></div>
<script language="JavaScript">window.setTimeout("location=\'<?php Helper::options()->adminUrl('options-theme.php'); ?>\'", 2500);</script>
<?php
}
}
}
if($_POST["type"]=="還原模板數據"){
if($db->fetchRow($db->select()->from ('table.options')->where ('name = ?', 'theme:Yodubf'))){
$sjdub=$db->fetchRow($db->select()->from ('table.options')->where ('name = ?', 'theme:Yodubf'));
$bsj = $sjdub['value'];
$update = $db->update('table.options')->rows(array('value'=>$bsj))->where('name = ?', 'theme:Yodu');
$updateRows= $db->query($update);
echo '<div class="tongzhi">檢測到模板備份數據,恢復完成,請等待自動刷新!如果等不到請點擊';
?>
<a href="<?php Helper::options()->adminUrl('options-theme.php'); ?>">這里</a></div>
<script language="JavaScript">window.setTimeout("location=\'<?php Helper::options()->adminUrl('options-theme.php'); ?>\'", 2000);</script>
<?php
}else{
echo '<div class="tongzhi">沒有模板備份數據,恢復不了哦!</div>';
}
}
if($_POST["type"]=="刪除備份數據"){
if($db->fetchRow($db->select()->from ('table.options')->where ('name = ?', 'theme:Yodubf'))){
$delete = $db->delete('table.options')->where ('name = ?', 'theme:Yodubf');
$deletedRows = $db->query($delete);
echo '<div class="tongzhi">刪除成功,請等待自動刷新,如果等不到請點擊';
?>
<a href="<?php Helper::options()->adminUrl('options-theme.php'); ?>">這里</a></div>
<script language="JavaScript">window.setTimeout("location=\'<?php Helper::options()->adminUrl('options-theme.php'); ?>\'", 2500);</script>
<?php
}else{
echo '<div class="tongzhi">不用刪了!備份不存在!!!</div>';
}
}
}
echo '<form class="protected" action="?yodubf" method="post">
<input type="submit" name="type" class="btn btn-s" value="備份模板數據" /> <input type="submit" name="type" class="btn btn-s" value="還原模板數據" /> <input type="submit" name="type" class="btn btn-s" value="刪除備份數據" /></form>';
SQL
然后將里面出現的所有“yodu”改成你的模板目錄的名字,如果拿不準就去數據庫里看看模板的值名字。
備份
當用戶點擊備份時,先判斷是否已經存在備份,如果不存在就插入一條新的數據,數據name為yodubf,value為模板原本的數據。此時就存在了一條備份數據。
如果再次點擊備份按鈕會發生什么呢?會觸發更新數據的語句,就是讀取模板的設置數據,然后將備份的模板數據更新。
還原
當用戶點擊還原按鈕時,會判斷是否存在備份,如果不存在就發出提示說不存在數據無法恢復;如果存在,就會進行一個反向的更新操作,將備份的數據更新到模板默認設置數據。
這個操作完成后會觸發個小問題,比較影響體驗的。就是在點擊還原按鈕時網頁是先刷新后執行php還原語句的,也就是說還原完成后,你看到的模板設置頁面數據并沒有還原,但是實際數據庫里面已經還原好了的,這一點很影響體驗。
于是乎,我雞賊的弄了個js自動刷新語句,并發出提示文字,這樣一下子就友好多了,注意文章中代碼方面我并未給出css樣式,所以美觀度上需要自行優化。
刪除
刪除就簡單了,判斷是否存在備份,不存在就告訴用戶不用刪了,你壓根就沒有備份數據,如果有備份就執行刪除語句,發出提示。
一些沒用的說明
1,其實這東西應該可以寫成懶人版的,模板名字什么的用php獲取下,就不用我這樣寫死了,但是當時我處于試一試的心態寫的,所以就能簡單就簡單了,現在又懶得弄了,要不是為了水文,這個我都懶得貼出來。
2,別看文章中代碼這么亂,條例就不清晰,其實我當時找了張紙寫的邏輯然后才按照順序一步一步的寫的,也測試了很多回。
3,最開始想寫自動還原模板數據來著,就是檢測到模板啟用就自動還原曾經的備份數據,然而當時想不通如果去判斷模板啟用。
4,當你想將本文章代碼投入使用時,最好再測試博客進行測試,以免傷害你的數據庫,同時建議測試時打開數據庫管理頁面,觀看數據庫對應表的變化
網頁下載(防代碼丟失):
備用網頁
這個主題就使用了這個功能