在很多時(shí)候,干得利索不如想的明白。方案應(yīng)該根據(jù)場(chǎng)景來設(shè)計(jì),不是盲目的依靠經(jīng)驗(yàn),當(dāng)然這也算新經(jīng)驗(yàn)!
需求是把公司的幾套公共系統(tǒng)做成通過郵箱用戶名和密碼認(rèn)證,只需記住一對(duì)用戶名密碼,簡(jiǎn)單為上,只允許用戶在ExtMail的web頁(yè)面修改密碼!在做論壇認(rèn)證的時(shí)候,由于論壇的復(fù)雜性,想到了如下的幾個(gè)方案:
通過OAuth2.0做認(rèn)證,或者自己寫接口,問題是只聽過,沒玩過!
在郵箱修改時(shí),也提交到論壇的數(shù)據(jù)庫(kù)。可惜不會(huì)ExtMail的Perl代碼,且修改代碼工作量太大!
先前已經(jīng)把線上郵箱用戶表同步到內(nèi)網(wǎng),可以做數(shù)據(jù)庫(kù)復(fù)制,可論壇和郵箱的數(shù)據(jù)庫(kù)字段有較大出入,還是要改大量代碼!
使用觸發(fā)器更新論壇數(shù)據(jù)庫(kù)的用戶表!
在仔細(xì)考慮過前面三種辦法之后,在能力范圍內(nèi),已經(jīng)把PHP編寫的論壇認(rèn)證方式修改成適應(yīng)郵箱的加鹽認(rèn)證方式,并測(cè)試了導(dǎo)入郵箱用戶名和密碼認(rèn)證。已經(jīng)修改過論壇數(shù)據(jù)庫(kù)字段類型,部分后端代碼!最后一步是自動(dòng)把郵箱數(shù)據(jù)庫(kù)的用戶表變更同步到論壇數(shù)據(jù)庫(kù)的用戶表。
在討論數(shù)據(jù)庫(kù)復(fù)制時(shí),發(fā)現(xiàn)還是最后一種觸發(fā)器的辦法可行性最好,通過對(duì)論壇用戶表的大多數(shù)字段設(shè)置默認(rèn)值,做到只添加修改其中的賬號(hào),密碼和郵件三個(gè)字段即可完成對(duì)論壇用戶的操作,下面是根據(jù)實(shí)際情況編寫的MySQL觸發(fā)器!
觸發(fā)器添加用戶
use extmail; DELIMITER // create trigger add_bbsuser after insert on extmail.mailbox for each row begin insert into xiuno_bbs.bbs_user(username,password,email) / values (new.name,new.password,new.username); end // DELIMITER ;
觸發(fā)器更新用戶
use extmail; DELIMITER // create trigger update_bbsuser after update on extmail.mailbox for each row begin update xiuno_bbs.bbs_user set username=new.name,/ password=new.password where email=new.username; end // DELIMITER ;
觸發(fā)器刪除用戶
use extmail; DELIMITER // create trigger delete_bbsuser after delete on extmail.mailbox for each row begin delete from xiuno_bbs.bbs_user where email=old.username; end // DELIMITER ;
我踩過的坑
剛開始編寫觸發(fā)器,從網(wǎng)上找來的命令都不能用,完全一籌莫展之際領(lǐng)悟到,觸發(fā)器和數(shù)據(jù)庫(kù)是綁定的,必須先use extmail到要觸發(fā)的extmail數(shù)據(jù)庫(kù)中,才能對(duì)這個(gè)庫(kù)的操作做相應(yīng)的觸發(fā),后來就沒有問題了!我果然是MySQL小白!
新聞熱點(diǎn)
疑難解答
圖片精選