用PHP完成简易博客系统[通俗易懂]

Php (67) 2023-06-21 19:12

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说用PHP完成简易博客系统[通俗易懂],希望能够帮助你!!!。

因为项目需要简单的完成一个页面接收参数并且操作数据库的过程,在老师的指引下决定通过一个博客小项目加深自己的理解。

学习路线是用一天的时间大概熟悉了HTML和PHP的语法,然后结合一些视频课程和相关博客完成目标,这里只完成了博客的基本功能,想要扩展可以自行研究。整体内容参考网易云课堂的PHP100课程的第9,10两节,因为界面没有使用CSS,所以比较丑,但功能还是全面的,主页效果图如下

用PHP完成简易博客系统[通俗易懂]_https://bianchenghao6.com/blog_Php_第1张

准备工作:安装wamp集成开发环境

首先在wamp中创建一个blog表,完全图形化的操作,注意的是需要根据自己添加的字段选择合适的类型及长度

用PHP完成简易博客系统[通俗易懂]_https://bianchenghao6.com/blog_Php_第2张

然后在wamp的按照目录下找到www文件夹,在其中创建blog文件夹,作为我们的操作目录

第一步是创建conn.php文件,用来连接我们的test数据库,账号密码由自己设定,默认账号是root,密码为空,我这里之前设置过密码为root,两行代码就完成了数据库的连接。

<?php
	$link=new mysqli('127.0.0.1','root','root','test');   
	mysqli_select_db($link, "test")or die("数据库连接失败"); //选择操作的数据库
?>

 

第二步创建add.php文件,进行博客的写操作

<a href="index.php"><b>首页</b></a>
<hr>	<!--创建一条水平线-->

<?php
    include("conn.php"); //引入连接数据库
    if (!empty($_POST['sub'])) {    
        $title = $_POST['title'];  //获取title表单内容
        $con = $_POST['con'];      //获取contents表单内容  
		$sql="insert into blog values(null,'$title',now(),'$con')";
		// null用来占位4,因为已经设置为自增
        mysqli_query($link, $sql);  //执行插入语句 
		
		echo "<script>alert('博客创建成功!');location.href='index.php'</script>";
        //echo "成功创建新的博客!";
	}
?>

<form action="add.php" method="post">   <!-- action 属性规定当提交表单时,向何处发送表单数据-->
	标题:<br>
    <input type="text" name="title"><br><br>
    内容:<br>
    <textarea rows="10" cols="100" name="con"></textarea><br><br>	<!--textarea> 标签定义多行的文本输入控件,规定了文本区的可见行数和宽度-->
    <input type="submit"  name="sub" value="提交">
</form>

第三步创建主页,建立index.php文件,代码中包含了HTML和PHP的混编,注意区分

首页的第一部分是一个搜索功能,通过关键字对博客的标题进行模糊搜索,第二部分会循环打印每一篇博客,但是可以通过MySQL的查询语句限制展示博客数量,并且对博客内容进行了截取显示

<h2>欢迎来到我的博客</h2>
<a href="index.php"><b>首页</b></a>
<a href="add.php"><b>写博客</b></a>
<hr>
<form action="index.php" method="get">
	<input type="text" name="keys">
	<input type="submit" name="sub" value="搜索">
</form>

<?php
	include ("conn.php");
	if(!empty($_GET['sub'])){
		$key=$_GET['keys'];
		$t = " title like '%$key%'";
		//echo "$t";
		//$t = 1;
	}else{
		$t = 1;
	}
	$sql ="select * from blog where $t order by id desc limit 5";
	$query = mysqli_query($link, $sql);  // 执行一次
	
	while($rs = mysqli_fetch_array($query)){ //循环打印每一篇博客
	
?>
<h2>标题:<a href="view.php?id=<?php echo $rs['id'];?>"><?php echo $rs['title'];?></a> </h2>
<li><?php echo $rs['data']?></li>
<!--截取部分长度内容进行展示--> 
<p><?php echo iconv_substr($rs['contents'],0,10,"utf-8"); ?></p>
<?php
}
?>

第四步创建view.php文件,这里比较简单,只完成博客的展示

<?php
	include("conn.php"); //引入连接数据库

	if(!empty($_GET['id'])){
		$id = $_GET['id'];
		$sql = "select * from blog where id='$id'";
		$query = mysqli_query($link, $sql);
		$rs = mysqli_fetch_array($query);
	}
?>

<h2>题目  :<?php echo $rs['title'];?></h2>
<h3>日期  :<?php echo $rs['data'];?></h3>
<p><a href="index.php">首页</a>  |<a href="edit.php?id=<?php echo $rs['id'];?>">编辑博客</a>  |  <a href="del.php?id=<?php echo $rs['id'];?>">删除博客</a> </p>
<hr>
<p><?php echo $rs['contents']?></p>

第五步创建edit.php,对博客进行修改操作代码包含两部分,第一部分是博客内容在指定位置的展示,第二部分是完成内容的更新

<a href="index.php"><b>首页</b></a>
<a href="add.php"><b>写博客</b></a>
<hr>	<!--创建一条水平线-->

<?php
    include("conn.php"); //引入连接数据库

	if(!empty($_GET['id'])){
		$edit = $_GET['id'];
		$sql = "select * from blog where id='$edit'";
		$query = mysqli_query($link, $sql);
		$rs = mysqli_fetch_array($query);
	}

    if (!empty($_POST['sub'])) {    
        $title = $_POST['title'];  //获取title表单内容
        $con = $_POST['con'];      //获取contents表单内容  
		$hid = $_POST['hid'];
		$sql="update blog set title='$title', contents='$con' where id='$hid'";
        mysqli_query($link, $sql);  //执行插入语句 
		
        echo "<script>alert('博客修改成功!');location.href='index.php'</script>";
	}
?>

<form action="edit.php" method="post">
    <input type="hidden" name="hid" value="<?php echo $rs['id'];?>">
    标题:<br>
    <input type="text" name="title" value="<?php echo $rs['title'];?>">
    <br><br>
    内容:<br>
    <textarea rows="10" cols="100" name="con" ><?php echo $rs['contents'];?></textarea><br><br>
    <input type="submit"  name="sub" value="提交">
</form>

第六步创建del.php,完成博客的删除操作

<?php    
    include("conn.php"); 	//引入连接数据库
    if (!empty($_GET['id'])) {        
        $del = $_GET['id'];  //删除blog 	
		$sql="delete from blog where id='$del' ";
        mysqli_query($link, $sql); 	
		//echo "删除成功!";	
		header("Location:index.php");	//删除后跳转
	}
?>

至此我们的博客系统基本完成,后续如果有时间也会继续实现阅读量和留言板的功能。点此下载完整项目完整项目

发表回复