| 项目场景:近几日,博主浏览到许多个人博客,心血来潮也想拥有一个,但市面上的博客虽然功能强大,但大多需要付费或者界面并不美观,因此,博主想自己开发一个博客页面,用于记录自己的内容,由于没有太多时间,因此只开发了博客列表与博客添加功能 
 所遇问题:博主学过一学期的PHP,但后期侧重与Java,故而在开发过程中遇到了许多问题,设计的也存在瑕疵,望诸位不吝赐教 
 准备工作:博主不愿意用那些免费的博客系统的原因就是因为其页面太过普通,故而自己开发时要避免这个问题也就只能借鉴他人成果了(毕竟博主的前端也不咋地)。首先,便去找了一款博客前端模板,这个页面中规中矩还算可以
 
 
  
 开发步骤:博主只要博客列表,那么我们的工作也就很轻快了,想好思路:连接数据库——页面发送ajax请求数据——数据查询返还结果——解析展示
 展示:
 下面是详细代码:数据库连接:
 <?php 
	header("Content-Type: text/html;charset=utf-8"); 
	$conn = new mysqli("localhost", "root", "", "blog")or die ("You cannot connect the database!<br>".mysqli_error());	  
?>
 index.html发送ajax请求 			$.ajax({
                    type:"GET",
                    url:"list.php?cur="+$cur+"&&title="+title,
                    dataType:"json",
                    success:function(result){
					$row.empty();
						data=result.data;
						for(var i=0;i<data.length;i++){
						
						}
					});
 查询数据: <?php
	require 'fun.php';  
	include "msg.php";  
	$cur=$_GET["cur"];  
	$title=$_GET["title"];  
	$sql="select * from blog where title like '%$title%' LIMIT $cur,6";
	$result =mysqli_query($conn,$sql); 
	$num = mysqli_num_rows($result);
	$msg=new Msg();
	$msg->setnum($num);
      if ($num) {
        $search_result = array();
          while($row = mysqli_fetch_array($result)){
              $search_result[] = $row;
          }
          
		  $msg->setdata($search_result);
         echo json_encode($msg); 
        }
?>
 其输出的json字符串:
  分页的方法使用js实现:
  function page($curpage){
				$cur=$curpage
				load($cur);
			 }
			 function prc(){
				$cur=$cur-1
				if($cur<=0){
					$cur=0;
				}
				load($cur);
			 }
			 function next($total){
				$cur=$cur+1
				if($cur>=$total){
					$cur=$total;
				}
				load($cur);
			 }
 msg类: <?php
class Msg {
  
  var $data;
  var $num;
  
  
  function setdata($data){
     $this->data = $data;
  }
  
  function getdata(){
     echo $this->data . PHP_EOL;
  }
  
  function setnum($num){
     $this->num = $num;
  }
  
  function getnum(){
     echo $this->num. PHP_EOL;
  }
}
?>
 然后我们再修改一些样式,看一下最终效果:
  接着,便是添加博客了:添加博客页面:使用了layui框架
 
  页面代码:
 <html>
<head>
<meta charset="utf-8">
<title>鹏翔博客</title>
<link href="layui/css/layui.css" type="text/css" rel="stylesheet">
</head>
<body>
<br><br>
<form class="layui-form" action="upload_file.php" method="post" enctype="multipart/form-data">
  <div class="layui-form-item">
    <label class="layui-form-label">输入框</label>
    <div class="layui-input-block">
      <input type="text" name="title" required  lay-verify="required" placeholder="请输入标题"style="width:400px" autocomplete="off" class="layui-input">
    </div>
  </div>
  <div class="layui-form-item">
    <label class="layui-form-label">选标签</label>
    <div class="layui-input-block">
      <input type="text" name="type" required  lay-verify="required" placeholder="请输入标签"style="width:400px" autocomplete="off" class="layui-input">
    </div>
  </div>
  <div class="layui-form-item">
    <label class="layui-form-label">传封面</label>
    <div class="layui-input-block">
     <input type="file" name="file" id="file"> </div>
  </div>
  </div>
  <div class="layui-form-item layui-form-text">
    <label class="layui-form-label">文本域</label>
    <div class="layui-input-block">
      <textarea name="info" placeholder="请输入内容" style="width:400px" class="layui-textarea"></textarea>
    </div>
  </div>
  <div class="layui-form-item">
    <div class="layui-input-block">
      <button class="layui-btn" >立即提交</button>
      <button type="reset" class="layui-btn layui-btn-primary">重置</button>
    </div>
  </div>
</form>
 
</body>
</html>
 上传图片并插入数据库: <?php
if($_SERVER['REQUEST_METHOD']=='POST'){
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
echo $_FILES["file"]["size"];
$extension = end($temp);     
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 204800)   
&& in_array($extension, $allowedExts))
{
    if ($_FILES["file"]["error"] > 0)
    {
        echo "错误:: " . $_FILES["file"]["error"] . "<br>";
    }
    else
    {
        echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
        echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
        echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
        echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"] . "<br>";
        
        
        
        if (file_exists("upload/" . $_FILES["file"]["name"]))
        {
            echo $_FILES["file"]["name"] . " 文件已经存在。 ";
        }
        else
        {
            
            move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
            echo "文件存储在: " . "upload/" . $_FILES["file"]["name"];
        }
    }
}
else
{
    echo "非法的文件格式";
}
require 'fun.php';
$img=$_FILES["file"]["name"];
$tilte=$_POST["title"];
$info=$_POST["info"];
$type=$_POST["type"];
$times=date("y-m-d h:m:s",time());
$sql="insert into blog(title,img,info,type,times) values('$tilte','$img','$info','$type','$times')";
if (mysqli_query($conn,$sql) === TRUE) {
    header("location:file.html");
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
}
?>
 接下来,便是将其部署到服务器上了:
  然后我们就可以访问了
 鹏翔博客
 这里是博客源码:
 下载地址
 |