PHP中動態HTML的輸出技術

2021-08-02 21:42:34 字數 979 閱讀 7533

你可以在php程式中的任何地方使用

echo "hello world!";

來輸出你想輸出的內容。

不過你將遇到以下麻煩:

1 -當你試圖在hello和world之間加入兩個(或兩個以上)空格,

你使用:

echo "hello world!";

你得到的輸出還是乙個空格,或者你在行首加入乙個空格,

你的空格也將被忽略。

2 -更糟的是輸出使用者輸入的內容時,有心或無意的使用者輸入將

使你的輸出變的一團糟,甚至給其他使用者帶來麻煩。

比如:

如果使用者輸入中有不止一行的內容,那麼你如果簡單地

echo $in_txt;

使用者的換行將被忽略。

3 -還是上面的例子,大部分情況我們不希望使用者輸入html

**,因為你不知道使用者會輸入什麼。

使用者甚至可以寫一段**使你**所有的使用者宕機。

當然你不希望那樣,但是你如果簡單地

echo $in_txt;

就不可能避免。

解決方法:

對於1,可以使用ereg_replace(" ","$nbsp; ",$in_txt)

兩個在一起的空格將變成兩個空格的轉義符($nbsp)。

對於2,nl2br($in_txt)是最好的選擇,這樣所以的換行就換成

""了。

對於3,安全地顯示使用者輸入的html**,php中也有專門的函式。

htmlspecialchars($in_txt)就可以了。

另外,如果$in_txt是從mysql資料庫中提出的,那麼他在以前插入時

一定要使用addslashes(),相應的,取出時就一定要stripslashes()。

總結:如果$in_txt是使用者輸入的文字,一般可以這樣輸出:

echo ereg_replace(" "," ",nl2br(htmlspecialchars(stripslashes($in_txt))));

PHP中動態HTML的輸出技術

你可以在php程式中的任何地方使用 echo hello world 來輸出你想輸出的內容。不過你將遇到以下麻煩 1 當你試圖在hello和world之間加入兩個 或兩個以上 空格,你使用 echo hello world 你得到的輸出還是乙個空格,或者你在行首加入乙個空格,你的空格也將被忽略。2 ...

ASP動態輸出html

您現在的位置 首頁 if bigclassid then dim dh set rs server.createobject adodb.recordset sql select from bigclass where bigclassid bigclassid rs.open sql,conn,1...

PHP生成HTML的技術原理

1 在my sql裡新建一資料庫,命名為database 可自定義 新建一表,命名為news 因為是新聞發布嘛,取個好記的名字即可,可自定義 然後建立這幾個欄位名 引用 id 自動遞增,這是關鍵,型別 int title 顧名思義,新聞標題,型別可取text content 新聞內容,型別可取tex...