亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP中動態(tài)HTML的輸出技術(shù)

 更新時間:2006年10月09日 00:00:00   作者:  
你可以在php程序中的任何地方使用
echo "hello world!";
來輸出你想輸出的內(nèi)容。

不過你將遇到以下麻煩:

1 -
當(dāng)你試圖在hello和world之間加入兩個(或兩個以上)空格,
你使用:
echo "hello world!";
你得到的輸出還是一個空格,或者你在行首加入一個空格,
你的空格也將被忽略。

2 -
更糟的是輸出用戶輸入的內(nèi)容時,有心或無意的用戶輸入將
使你的輸出變的一團(tuán)糟,甚至給其他用戶帶來麻煩。
比如:

<form action="output.php">
<textarea name="in_txt">
</textarea>
<br>
<input type="submit">
</form>

如果用戶輸入中有不止一行的內(nèi)容,那么你如果簡單地
echo $in_txt;
用戶的換行將被忽略。

3 -
還是上面的例子,大部分情況我們不希望用戶輸入html
代碼,因為你不知道用戶會輸入什么。
用戶甚至可以寫一段代碼使你網(wǎng)站所有的用戶死機(jī)。
當(dāng)然你不希望那樣,但是你如果簡單地
echo $in_txt;
就不可能避免。



解決方法:
對于1,可以使用ereg_replace(" {2}","$nbsp;&nbsp;",$in_txt)
兩個在一起的空格將變成兩個空格的轉(zhuǎn)義符($nbsp)。

對于2,nl2br($in_txt)是最好的選擇,這樣所以的換行就換成
"<br>"了。

對于3,安全地顯示用戶輸入的html代碼,php中也有專門的函數(shù)。
htmlspecialchars($in_txt)就可以了。


另外,如果$in_txt是從mysql數(shù)據(jù)庫中提出的,那么他在以前插入時
一定要使用addslashes(),相應(yīng)的,取出時就一定要stripslashes()。

總結(jié):
如果$in_txt是用戶輸入的文本,一般可以這樣輸出:
echo ereg_replace(" {2}","&nbsp;&nbsp;",nl2br(htmlspecialchars(stripslashes($in_txt))));

相關(guān)文章

最新評論