我正在从头开始构建个人博客,在从MySQL输出文本正文时,我无法正确显示链接。
例如;
我在博客文章中嵌入了大约200个单词的链接,当我从数据库调用博客文章时链接无法正确显示。我尝试过使用stipslashes()
和htmlentities()
,但这些都没有。
以下是我将博客文章保存到数据库的代码:
function check_input($data, $problem='')
{
$data = trim($data);
$data = stripslashes($data);
$data = htmlspecialchars($data);
if ($problem && strlen($data) == 0)
{
die($problem);
}
return $data;
}
if(isset($_POST['addBlog'])) { //form submitted?
// get form values, escape them and apply the check_input function
$title = $link->real_escape_string($_POST['title']);
$category = $link->real_escape_string(check_input($_POST['category'], "You must choose a category."));
$content = $link->real_escape_string(check_input($_POST['blogContent'], "You can't publish a blog with no blog... dumbass."));
$date = $link->real_escape_string(check_input($_POST['pub_date'], "What day is it foo?"));
mysqli_connect($db_host, $db_user, $db_pass) OR DIE (mysqli_error());
// select the db
mysqli_select_db ($link, $db_name) OR DIE ("Unable to select db".mysqli_error($db_name));
// our sql query
$sql = "INSERT INTO pub_blogs (title, date, category, content) VALUES ('$title', '$date', '$category', '$content');";
//save the blog
mysqli_query($link, $sql) or die("Error in Query: " . mysqli_error($link));
if (!mysqli_error($link))
{
print "<p> Blog Successfully Published! </p>";
}
}
以下是我展示博客帖子的代码:这就是麻烦的地方
// Grab the data
$result = mysqli_query($link, "SELECT * FROM pub_blogs") or die ("Could not access DB: " . mysqli_error($link));
while ($row = mysqli_fetch_assoc($result))
{
$id = $link->real_escape_string($row['id']);
$title = $link->real_escape_string($row['title']);
$date = $link->real_escape_string($row['date']);
$category = $link->real_escape_string($row['category']);
$content = $link->real_escape_string($row['content']);
$id = stripslashes($id);
$title = stripslashes($title);
$date = stripslashes($date);
$category = stripslashes($category);
$content = stripslashes($content);
}
echo "<div class='blog_entry_container'>";
echo "<span class='entry_date'><a href='#'>" .$date. "</a> - </span><span class='blog_title'><a class='blogTitleLink' href='#'>" .$title. "</a></span>";
echo "<p>" .$content. "</p>";
echo "</div>";
问题出在$content
变量
答案 0 :(得分:0)
你应该切换到准备好的语句,摆脱所有逃避和削减的东西。
这应该会在数据库中正确发布您的原始博文,但现在您遇到了问题:您应该使用htmlspecialchars
将内容输出到html(以避免文本变成标签等问题)但这样做会破坏你的链接。
该问题的解决方案是使用标记语言(如markdown)将链接转换为动态链接。另请参阅此blog post by Jeff Atwood,了解有关问题和答案的标记。
另一种方法是在html中完全编写内容并删除周围的<p>
标记,但这只有在您(或可信用户)是唯一可以编写博客条目的人时才有效。或者找到一种清理/验证您输入的好方法......