> 백엔드 개발 > PHP 튜토리얼 > PHP는 간단한 blog_php 예제 생성을 실현합니다.

PHP는 간단한 blog_php 예제 생성을 실현합니다.

WBOY
풀어 주다: 2023-03-02 22:32:01
원래의
1141명이 탐색했습니다.

최근에는 PHP 코드를 살펴보는 시간을 가졌습니다. PHP100 튜토리얼을 참고하여 간단한 블로그를 만들어 여기에 간략하게 기록해보았습니다.

첫 번째는 WAMP가 여기에서 선택되었습니다: http://www.wampserver.com/en/

먼저 phpMyAdmin을 통해 블로그 테이블을 생성하세요.

순수한 인터페이스 작업은 프로세스가 비교적 간단합니다. id가 기본 키이고 auto_increnent 옵션이 설정되어 있으므로 필드가 비어 있으면 자동으로 증가합니다. 다른 필드는 좀 더 캐주얼하므로 유형과 길이에 주의하세요.

데이터 연결 만들기

./wamp/www/blog 디렉토리에 conn.php 파일을 생성합니다.

<&#63;php

@mysql_connect("127.0.0.1:3306","root","") or die("mysql数据库连接失败");
@mysql_select_db("test")or die("db连接失败");
mysql_query("set names 'gbk'");

&#63;>

로그인 후 복사

mysql의 기본 사용자 이름은 root이고 비밀번호는 비어 있습니다. 여기서 생성한 블로그는 테스트 라이브러리에 있으므로 테스트 라이브러리에 연결해야 합니다.

블로그 추가                                       

./wamp/www/blog/ 디렉토리에 add.php 파일을 생성하세요.


<a href="index.php"><B>index</B></a>
<a href="add.php"><B>add blog</B></a>
<hr>


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

if (!empty($_POST['sub'])) {
  $title = $_POST['title']; //获取title表单内容
  $con = $_POST['con'];   //获取contents表单内容
  $sql= "insert into blog values(null,'0','$title',now(),'$con')";
  mysql_query($sql);
  echo "insert success!";

}

&#63;>

<form action="add.php" method="post">
  title  :<br>
  <input type="text" name="title"><br><br>
  contents:<br>
  <textarea rows="5" cols="50" name="con"></textarea><br><br>
  <input type="submit" name="sub" value="submit">
  
</form>

로그인 후 복사
이 코드는 두 부분으로 나누어져 있습니다. 윗 부분은 PHP 코드입니다. include(또는 require) 문은 지정된 파일에 존재하는 모든 텍스트/코드/태그를 가져와서 include 문을 사용하여 파일에 복사합니다. .

그러면 form의 name='sub' 내용이 비어 있지 않다고 판단되면 form의 내용을 가져오고, 그 다음에는 $sql 문이 null로 실행된다는 의미입니다. 비어 있음(증가), now()는 현재 항목을 취함을 의미합니다. 이제부터 $title 및 $con은 사용자가 양식에 제출한 컨텐츠를 취합니다. 마지막으로 eche가 성공적으로 삽입되었습니다.

하단 부분은 블로그 양식 제출 기능을 구현하는 데 사용되는 간단한 HTML 코드입니다.

블로그 홈페이지 만들기                                                  ./wamp/www/blog/ 디렉토리에 index.php 파일을 생성하세요.


이 페이지에는 꽤 많은 기능이 포함되어 있습니다.
<a href="index.php"><B>index</B></a>
<a href="add.php"><B>add blog</B></a>
<br><br>
<form action="" method="get" style='align:"right"'>
  <input type="text" name="keys" >
  <input type="submit" name="subs" >
</form>
<hr>

<&#63;php
include("conn.php"); //引入连接数据库
  
  if (!empty($_GET['keys'])) {
    $key = $_GET['keys'];
    $w = " title like '%$key%'";

  }else{
    $w=1;
  }

  $sql ="select * from blog where $w order by id desc limit 5";
  $query = mysql_query($sql);
  
  while ($rs = mysql_fetch_array($query)) {


&#63;>
<h2>title: <a href="view.php&#63;id=<&#63;php echo $rs['id']; &#63;>"><&#63;php echo $rs['title']; &#63;></a>
  | <a href="edit.php&#63;id=<&#63;php echo $rs['id']; &#63;>">edit</a> 
  | <a href="del.php&#63;id=<&#63;php echo $rs['id']; &#63;>">delete</a> |
</h2>
<li>date: <&#63;php echo $rs['data']; &#63;></li>
<!--截取内容展示长度-->
<p>contents:<&#63;php echo iconv_substr($rs['contents'],0,30,"gbk"); &#63;>...</p> 
<hr>

<&#63;php

};

&#63;>
로그인 후 복사
첫 번째는 검색 양식입니다. 검색 양식의 내용이 비어 있는지 확인하려면 키워드를 입력하여 기사 제목을 일치시키고 비어 있으면 결과를 표시합니다. 모든 블로그 콘텐츠를 쿼리하고 각각의 기사 제목, 날짜 및 텍스트를 표시합니다. 제목을 클릭하시면 블로그 상세페이지로 연결됩니다. 각 기사는 "편집" 및 "삭제" 기능을 제공합니다.

mysql_query()는 SQL 문을 실행하는 데 사용됩니다. mysql_fetch_arry()는 반환된 데이터로부터 배열을 생성하므로 데이터베이스의 각 데이터 조각이 배열처럼 작동될 수 있습니다.

그런 다음 텍스트가 표시되고 iconv_substr() 함수를 통해 텍스트의 처음 30자를 추출합니다.

블로그 보기 

                                          

./wamp/www/blog/ 디렉토리에 view.php 파일을 생성하세요.


블로그 텍스트 구현은 비교적 간단합니다. get 요청을 통해 블로그 ID를 가져온 다음 SQL 문을 통해 해당 ID에 해당하는 제목, 날짜 및 텍스트를 쿼리하고 표시합니다.
<a href="index.php"><B>index</B></a>
<a href="add.php"><B>add blog</B></a>
<hr>

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

  if (!empty($_GET['id'])) {
    $id = $_GET['id'];
    $sql ="select * from blog where id='$id' ";  
    $query = mysql_query($sql);
    $rs = mysql_fetch_array($query);
    
    $sqlup = "update blog set hits=hits+1 where id='$id'";
    mysql_query($sqlup);
  }



&#63;>
<h2>title: <&#63;php echo $rs['title']; &#63;> </h1>
<h3>date: <&#63;php echo $rs['data']; &#63;> 
click number: <&#63;php echo $rs['hits']; &#63;></h3>
<hr>
<p>contents:<&#63;php echo $rs['contents']; &#63;></p> 

로그인 후 복사
추가적인 작은 기능은 페이지를 새로 고칠 때마다 클릭 수가 1씩 증가하는 간단한 카운터를 표시하는 것입니다.


블로그 수정                                                                    

./wamp/www/blog/ 디렉토리에 edit.php 파일을 생성하세요.


블로그 편집 기능은 비교적 복잡합니다. 작업은 두 단계로 나누어집니다. 첫 번째 단계는 블로그의 제목과 텍스트를 쿼리하여 입력 상자에 표시하는 것입니다. 두 번째 단계는 편집된 내용을 데이터베이스에 업데이트하는 것입니다.
<a href="index.php"><B>index</B></a>
<a href="add.php"><B>add blog</B></a>
<hr>


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

//获取数据库表数据
if (!empty($_GET['id'])) {
  $edit = $_GET['id'];
  $sql = "select * from blog where id='$edit'";
  $query = mysql_query($sql);
  $rs = mysql_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' ";
  mysql_query($sql);
  echo "<script>alert('update success.');location.href='index.php'</script>";

}

&#63;>

<form action="edit.php" method="post">
  <input type="hidden" name="hid" value="<&#63;php echo $rs['id'];&#63;>">
  title  :<br>
  <input type="text" name="title" value="<&#63;php echo $rs['title'];&#63;>">
  <br><br>
  contents:<br>
  <textarea rows="5" cols="50" name="con" ><&#63;php echo $rs['contents'];&#63;></textarea><br><br>
  <input type="submit" name="sub" value="submit">
  
</form>

로그인 후 복사

블로그 삭제

./wamp/www/blog/ 디렉터리에 del.php 파일을 만듭니다.


드디어 블로그 삭제 기능이 구현되고, 해당 블로그가 ID를 통해 조회되어 표시됩니다.

모든 페이지가 프론트엔드 스타일로 미화되지 않아서 보기 흉해서 사진은 올리지 않겠습니다. 기능은 아주 완벽합니다. 여기에 기록된 내용은 PHP 학습의 집합체로 간주됩니다.

============================================= === ========

그리고 모든 언어에는 장단점이 있지만 PHP의 두 가지 단점에 대해서는 여전히 불만을 토로하지 않을 수 없습니다.

1. "$", "->", "=>"와 같은 기호는 쓰기가 어렵습니다. 이러한 기호는 코드 구문을 이해하는 데 어려움을 증가시키지 않습니다. 하지만 역겨운 맛이 납니다. "$" 기호를 입력할 때마다 키보드를 보고 Shift 키를 눌러 4가 어디에 있는지 찾아야 합니다.

2. 내 생각에는 php와 html의 혼합이 그다지 우아하지 않습니다.

위 글의 내용은 모두의 공부에 도움이 되길 바랍니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿