今天遇見一個消除js正則表達(dá)式不區(qū)分大小寫的問題,網(wǎng)上一搜,發(fā)現(xiàn)自己果然是菜鳥。
在js里面//g,其中g(shù)表示全局匹配,如果沒有這個,那么就意味著只能匹配一次就會自動結(jié)束;/i/就表示在匹配的過程中不區(qū)分大小寫。呵呵。。這個在參數(shù)過濾的過程中就很有用了。
代碼如下:
dxycode=dxycode.replace(/<br\s*\/?>/gi,'\n')
都說到這個份上了,自然情不自禁的看了一下.net中的正則表達(dá)式不區(qū)分大小寫的情況。在.net中,regexoption枚舉可以使用影響匹配行為的選項修改正則表達(dá)式模式。比如其中的ingorecase就是匹配過程中忽略大小寫的限定。附上代碼如下:
regex.match (string, string, regexoptions);
regex.replace (string, string, string, regexoptions)
正則表達(dá)式其實是一個很有趣的事情,但是不因正而正則。下面描述一下我今天碰到的問題。
大家可能都會遇到這樣的問題,在進(jìn)行ajax的傳輸后,利用javascript綁定數(shù)據(jù)的時候,經(jīng)常因為注入惡意腳本、html標(biāo)簽未關(guān)閉等問題導(dǎo)致頁面錯版和被別人腳本惡意注入。這個時候的我們想到的第一個解決辦法是:將所有標(biāo)簽全部轉(zhuǎn)換成實體。這樣頁面既不會被惡意腳本注入,又不會出現(xiàn)錯版情況。 很好,這是一種解決途徑,畢竟菜鳥開始想問題了。但是這樣會誤殺一篇有用的html標(biāo)簽,比如img,a等等。因此,第一種想法被否定了。
然后菜鳥開始尋找第二種途徑。先將問題分解,讓我們先解決惡意腳本注入的問題。這個好辦,把其中一部分惡意的腳本過濾掉。好啊,這個簡單,這個時候就用到了我上面說的正則表達(dá)式了。一路走下去,惡意腳本注入得到解決。這里先不指出菜鳥這樣做的缺點。先看下一個問題。那么怎樣防止頁面錯版的問題呢。哎呀。。。這個菜鳥可是想破了腦袋,最后的結(jié)論是用正則表達(dá)式吧為關(guān)閉標(biāo)簽給照出來,要么修補(bǔ)未關(guān)閉標(biāo)簽,要不直接刪除未關(guān)閉標(biāo)簽。
再來評論菜鳥的第二種解決途徑和第三種方法。這樣做有一個共同的確定。就是你手動改變了用戶的內(nèi)容,不經(jīng)意的用戶還會以為你系統(tǒng)有問題,因為缺少很好的用戶體驗。第二,正則表達(dá)式始終是要費能的一個東東,需要不停的比對。雖然給系統(tǒng)的影響可能不是很大,但是能節(jié)約性能為什么不節(jié)約呢?
最終菜鳥找到了一個很好的方法,對于文本框的輸入,采用第一種方法,吧用戶的輸入內(nèi)容直接轉(zhuǎn)換為實體。當(dāng)然如果用戶有輸入圖片和超鏈接的需要,我們也不能不滿足。如何滿足?解決途徑如下:自定義標(biāo)簽,然后再顯示的時候自定義標(biāo)簽轉(zhuǎn)換。此時菜鳥才恍然大悟。
其實菜鳥也在不斷的進(jìn)步的,這個問題的解決體驗了一個思想就是:特殊問題特殊處理的思想。有些東西是不能被大眾化的,那么我們就對其特殊處理吧!
更多信息請查看IT技術(shù)專欄