數(shù)據(jù)庫(kù)這么建就好了
在三水等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站設(shè)計(jì)、網(wǎng)站制作 網(wǎng)站設(shè)計(jì)制作按需網(wǎng)站建設(shè),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站制作,全網(wǎng)營(yíng)銷推廣,成都外貿(mào)網(wǎng)站建設(shè),三水網(wǎng)站建設(shè)費(fèi)用合理。
id | belongid | name | img
1 | 0 | 名字A | url //A為根,0代表根級(jí)別
2 | 1 | 名字B | url //B為A的分支
3 | 1 | 名字C | url //C為A的分支
4 | 2 | 名字D | url //D為B的分支
獲取get belongid,然后belongid為空或者為0的時(shí)候顯示數(shù)據(jù)庫(kù)belongid為0的人,點(diǎn)擊任何一個(gè)人,進(jìn)入一個(gè)子頁(yè)面belongid都為被點(diǎn)擊的這個(gè)人的id,在哪個(gè)belongid寫(xiě)入數(shù)據(jù)庫(kù)的信息,那么,添加的這個(gè)人就belongid=GET[“belongid”],這里說(shuō)的是添加
下面來(lái)講講提取數(shù)據(jù),為了方便我們新加一個(gè)字段,表明當(dāng)前用戶在第幾級(jí),tmp字段,你也可以生成緩存表或緩存文件,先select 出 tmp=0的,然后tmp=1的,直到取到最大的一級(jí),然后tmp=1級(jí)的belongid找0級(jí)uid的,這樣子依次就可以獲得所有用戶樹(shù)形關(guān)系了
對(duì)于這個(gè)問(wèn)題:
第1.數(shù)據(jù)庫(kù)主機(jī):若在本地就直接如圖所示不需要修改,若在互聯(lián)網(wǎng)上,填寫(xiě)服務(wù)器IP地址或域名即可
第2.數(shù)據(jù)庫(kù)名:你在本地直接建一個(gè)UTF8格式的數(shù)據(jù)庫(kù)abcde名字你任意寫(xiě)但不能寫(xiě)已有的數(shù)據(jù)庫(kù)名和關(guān)鍵字名。
第3.表前綴:你可以不理,直接默認(rèn)的比較妥當(dāng)!
第4.用戶名:就是你能管理數(shù)據(jù)庫(kù)的帳號(hào),通常為root或mysql
第5.密碼:就是你管理這數(shù)據(jù)庫(kù)的密碼,通常為空或123456
第6.管理員帳號(hào):這就是你管理這個(gè)軟件的管理帳號(hào),通常為admin
第7.密碼:也就是你登錄后臺(tái)的密碼!
這里假設(shè)你的主頁(yè)是index.php,登錄前頁(yè)面是login.php,用戶名user1的密碼為123。當(dāng)然,給你提供的是PHP方法,所以你必須配置好了PHP并且每頁(yè)都必須是PHP。
每個(gè)需要登錄后查看的頁(yè)面的開(kāi)始寫(xiě)(一定要最開(kāi)始,前面不能有任何字符包括回車或者空格)
?php session_start();if(!isset($_SESSION['pass']))header("Location: login.php");?
在登錄頁(yè)面最開(kāi)始寫(xiě):
?php session_start();$usr=array('user1'='123','user2'='456');if(isset[$_POST['usr']]isset[$_POST['pwd']]isset[$usr[$_POST['usr']]]$_POST['pwd']==$usr[$_POST['usr']])$_SESSION['pass']=1;if(isset($_SESSION['pass']))header("Location: index.php");?
登錄頁(yè)內(nèi)容里必須有form元素具有method屬性值為post。
form元素里必須具有兩個(gè)input具有name屬性值分別為usr和pwd,最后一個(gè)按鈕建議用input type=submit。例如:
form method="post"
Name: input name="usr"/br/
Password: input name="pwd"/br/
input type="submit" value="login"/
/form
直接寫(xiě)的沒(méi)測(cè)試,希望能正確吧。
本文只需要讀者具備PHP、HTML的初步知識(shí)就可以基本讀懂了。 譯文:如大家所知PHP對(duì)于用數(shù)據(jù)庫(kù)驅(qū)動(dòng)的網(wǎng)站(making database-driven sites)來(lái)講可謂功能強(qiáng)大,可是我們是否可以用它來(lái)做點(diǎn)其他事情呢?PHP給了我們所有我們期望的工具:for與while的循環(huán)結(jié)構(gòu)、數(shù)學(xué)運(yùn)算等等,還可以通過(guò)兩種方式來(lái)引用文件:直接引用或向服務(wù)器提出申請(qǐng)。其實(shí)何止這些,讓我們來(lái)看一個(gè)如何用它來(lái)做導(dǎo)航條的例子:完整的原代碼:!—— This "?" is how you indicate the start of a block of PHP code, —— ?PHP # and this "#" makes this a PHP comment. $full_path = getenv("REQUEST_URI"); $root = dirname($full_path);$page_file = basename($full_path);$page_num = substr($page_file, strrpos($page_file, "_") + 1, strpos($page_file, ".html") - (strrpos($page_file, "_") + 1)); $partial_path = substr($page_file, 0, strrpos($page_file, "_")); $prev_page_file = $partial_path . "_" . (string)($page_num-1) . ".html";$next_page_file = $partial_path . "_" . (string)($page_num+1) . ".html"; $prev_exists = file_exists($prev_page_file);$next_exists = file_exists($next_page_file); if ($prev_exists) { print "a href="$root/$prev_page_file"previous/a";if ($next_exists) { print " | ";} if ($next_exists) { print "a href="$root/$next_page_file"next/a";} ?//原程序完。 代碼分析:OK! 前面做了足夠的鋪墊工作,現(xiàn)在讓我們來(lái)看看如何來(lái)用PHP來(lái)完成這項(xiàng)工作: !—— This "?" is how you indicate the start of a block of PHP code, —— ?PHP # and this "#" makes this a PHP comment. $full_path = getenv("REQUEST_URI"); $root = dirname($full_path);$page_file = basename($full_path); /* PHP函數(shù)getenv()用來(lái)取得環(huán)境變量的值,REQUEST_URI的值是緊跟在主機(jī)名后的部分URL,假如URL是, 那它的值就為/dinner/tuna_1.html. 現(xiàn)在我們將得到的那部分URL放在變量$full_path中,再用dirname()函數(shù)來(lái)從URL中抓取文件目錄,用basename()函數(shù)取得文件名,用上面的例子來(lái)講dirname()返回值:/dinner/;basename()返回:tuna_1.html.接下來(lái)的部分相對(duì)有些技巧,假如我們的文件名以story_x的格式命名,其中x代表頁(yè)碼,我們需要從中將我們使用的頁(yè)碼抽出來(lái)。當(dāng)然文件名不一定只有一位數(shù)字的模式或只有一個(gè)下劃線,它可以是tuna_2.html,同樣它還可以叫做tuna_234.html甚至是candy_apple_3.html,而我們真正想要的就是位于最后一個(gè)“_”和“。html”之間的東東??刹捎萌缦路椒ǎ?/ $page_num = substr($page_file, strrpos($page_file, "_") + 1, strpos($page_file, ".html") - (strrpos($page_file, "_") + 1));/* substr($string, $start,[$length] )函數(shù)給了我們字符串$string中從$start開(kāi)始、長(zhǎng)為$length或到末尾的字串(方括號(hào)中的參數(shù)是可選項(xiàng),如果省略$length,substr就會(huì)返回給我們從$start開(kāi)始直到字符串末尾的字符串),正如每一個(gè)優(yōu)秀的C程序員告訴你的那樣,代表字符串開(kāi)始的位置開(kāi)始的數(shù)字是“0”而不是“1”。 函數(shù)strrpos($string, $what)告訴我們字符串$what在變量$string中最后一次出現(xiàn)的位置,我們可以通過(guò)它找出文件名中最后一個(gè)下劃線的位置在哪,同理,接著的strpos($string, $what)告訴我們“。html”首次出現(xiàn)的位置。我們通過(guò)運(yùn)用這三個(gè)函數(shù)取得在最后一個(gè)“_”和“。html”之間的數(shù)字(代碼中的strpos()+1代表越過(guò)“_”自己)。 剩下的部分很簡(jiǎn)單,首先為上頁(yè)和下頁(yè)構(gòu)造文件名:*/ $partial_path = substr($page_file, 0, strrpos($page_file, "_")); $prev_page_file = $partial_path . "_" . (string)($page_num-1) . ".html";$next_page_file = $partial_path . "_" . (string)($page_num+1) . ".html"; /*(string)($page_num+1)將數(shù)學(xué)運(yùn)算$page_num+1的結(jié)果轉(zhuǎn)化為字符串類型,這樣就可以用來(lái)與其他字串最終連接成為我們需要的文件名。 */ /*現(xiàn)在檢查文件是否存在(這段代碼假設(shè)所有的文件都位于同樣的目錄下),并最終給出構(gòu)成頁(yè)面導(dǎo)航欄的HTML代碼。