我發現了一個代碼,用於在配置文件中的個人消息中使用bb-codes,但是當我回到設置以更改消息時,它會回顯html標記而不是bb-code替換。反向bb-codes回聲時
BB碼:
if(isset($_POST['submit'])) {
if(isset($_POST['bio_message'])){
//BBCode Parser function
function showBBcodes($text) {
// BBcode array
$find = array(
'~\[b\](.*?)\[/b\]~s',
'~\[i\](.*?)\[/i\]~s',
'~\[u\](.*?)\[/u\]~s',
'~\[quote\](.*?)\[/quote\]~s',
'~\[url\]((?:ftp|https?)://.*?)\[/url\]~s',
'~\[img\](https?://.*?\.(?:jpg|jpeg|gif|png|bmp))\[/img\]~s'
);
// HTML tags to replace BBcode
$replace = array(
'<b>$1</b>',
'<i>$1</i>',
'<p style="text-decoration:underline;">$1</p>',
'<pre>$1</'.'pre>',
'<a href="$1">$1</a>',
'<img src="$1" alt="" />'
);
// Replacing the BBcodes with corresponding HTML tags
return preg_replace($find,$replace,$text);
}
// How to use the above function:
$text = $_POST['bio_message'];
$htmltext = showBBcodes($text);
}
$id = htmlentities($_SESSION['user']['id'], ENT_QUOTES, 'UTF-8');
$bio_sql = "UPDATE users SET bio = '$htmltext' WHERE id = '$id'";
$db->query($bio_sql);
}else{}
呼應生物在textarea的:
<?php
$id = htmlentities($_SESSION['user']['id'], ENT_QUOTES, 'UTF-8');
$SQL = "SELECT * FROM users WHERE id = '$id'";
$result = $db->query($SQL);
/* associative array */
$row = $result->fetch_array(MYSQLI_ASSOC);
print(htmlentities($row['bio'], ENT_QUOTES, 'UTF-8'));
$result->free();
?>
好代碼,你這樣做完全一樣的只是另一種方式圓。 –
嘗試過,但不會工作。 repleaced $ find和$ replace以及切換順序。 –
您還必須編輯正則表達式和替換。 –