Home > php教程 > PHP源码 > body text

基于CakePHP实现的简单博客系统实例_php实例

PHP中文网
Release: 2016-05-25 17:09:22
Original
1104 people have browsed it

这篇文章主要介绍了基于CakePHP实现的简单博客系统,以一个完整实例分析了使用CakePHP实现博客系统的完整流程,需要的朋友可以参考下

本文实例讲述了基于CakePHP实现的简单博客系统。分享给大家供大家参考。具体实现方法如下:

PostsController.php文件:

<?php
class PostsController extends AppController {
 public $helpers = array(&#39;Html&#39;, &#39;Form&#39;, &#39;Session&#39;);
 public $components = array(&#39;Session&#39;);
 public function index() 
 {
   $this->set(&#39;posts&#39;, $this->Post->find(&#39;all&#39;));
 }
 public function view($id=null)
 {
   $this->Post->id=$id;
   $this->set(&#39;post&#39;,$this->Post->read());
 }
 public function add()
 {
   if($this->request->is("post"))
   {
    $this->Post->create();
    if($this->Post->save($this->request->data))
    {
      $this->Session->setFlash("your post added!");
      $this->redirect(array(&#39;action&#39;=>&#39;index&#39;));
    }
    else
    {
      $this->Session->setFlash("unable to create post!");
    }
   }
 }
 public function edit($id=null)
 {
   $this->Post->id=$id;
   if($this->request->is(&#39;get&#39;))
   {
     $this->request->data = $this->Post->read();
   }
   else
   {
     if($this->Post->save($this->request->data)) 
     {
       $this->Session->setFlash(&#39;Your post has been updated.&#39;);
       $this->redirect(array(&#39;action&#39; => &#39;index&#39;));
     }
     else
     {
       $this->Session->setFlash(&#39;Unable to update your post.&#39;);
     }
   }
 }
 public function delete($id) {
    if ($this->request->is(&#39;get&#39;)) {
        throw new MethodNotAllowedException();
    }
    if ($this->Post->delete($id)) {
      $this->Session->setFlash(&#39;The post with id: &#39; . $id . &#39; has been deleted.&#39;);
      $this->redirect(array(&#39;action&#39; => &#39;index&#39;));
    }
 }
}
?>
Copy after login

Post.php文件:

<?php
class Post extends AppModel {
public $validate = array(
 &#39;title&#39; => array(
 &#39;rule&#39; => &#39;notEmpty&#39;
),
 &#39;body&#39; => array(
 &#39;rule&#39; => &#39;notEmpty&#39;
)
);
}
?>
Copy after login

routes.php文件:

<?php
/**
 * Routes configuration
 *
 * In this file, you set up routes to your controllers and their actions.
 * Routes are very important mechanism that allows you to freely connect
 * different urls to chosen controllers and their actions (functions).
 *
 * PHP 5
 *
 * CakePHP(tm) : Rapid Development Framework (http://www.php.cn/)
 * Copyright 2005-2012, Cake Software Foundation, Inc. (http://www.php.cn/)
 *
 * Licensed under The MIT License
 * Redistributions of files must retain the above copyright notice.
 *
 * @copyright   Copyright 2005-2012, Cake Software Foundation, Inc. (http://www.php.cn/)
 * @link     http://www.php.cn/ CakePHP(tm) Project
 * @package    app.Config
 * @since     CakePHP(tm) v 0.2.9
 * @license    MIT License (http://www.php.cn/)
 */
/**
 * Here, we are connecting &#39;/&#39; (base path) to controller called &#39;Pages&#39;,
 * its action called &#39;display&#39;, and we pass a param to select the view file
 * to use (in this case, /app/View/Pages/home.ctp)...
 */
  //Router::connect(&#39;/&#39;, array(&#39;controller&#39; => &#39;pages&#39;, &#39;action&#39; => &#39;display&#39;, &#39;home&#39;));
  Router::connect(&#39;/&#39;, array(&#39;controller&#39; => &#39;posts&#39;, &#39;action&#39; => &#39;index&#39;));
/**
 * ...and connect the rest of &#39;Pages&#39; controller&#39;s urls.
 */
  Router::connect(&#39;/pages/*&#39;, array(&#39;controller&#39; => &#39;pages&#39;, &#39;action&#39; => &#39;display&#39;));
/**
 * Load all plugin routes. See the CakePlugin documentation on 
 * how to customize the loading of plugin routes.
 */
  CakePlugin::routes();
/**
 * Load the CakePHP default routes. Only remove this if you do not want to use
 * the built-in default routes.
 */
  require CAKE . &#39;Config&#39; . DS . &#39;routes.php&#39;;
Copy after login

blog.sql文件如下:

-- MySQL dump 10.13 Distrib 5.5.19, for Win64 (x86)
--
-- Host: localhost  Database: facebook
-- ------------------------------------------------------
-- Server version  5.5.19
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE=&#39;+00:00&#39; */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE=&#39;NO_AUTO_VALUE_ON_ZERO&#39; */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
 
--
-- Table structure for table `posts`
--
DROP TABLE IF EXISTS `posts`;
/*!40101 SET @saved_cs_client   = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `posts` (
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
 `title` varchar(50) COLLATE utf8_unicode_ci DEFAULT NULL,
 `body` text COLLATE utf8_unicode_ci,
 `created` datetime DEFAULT NULL,
 `modified` datetime DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Dumping data for table `posts`
--
LOCK TABLES `posts` WRITE;
/*!40000 ALTER TABLE `posts` DISABLE KEYS */;
INSERT INTO `posts` VALUES (1,&#39;The title&#39;,&#39;This is the post body.&#39;,&#39;2012-11-01 15:43:41&#39;,NULL),(2,&#39;A title once again&#39;,&#39;And the post body follows.&#39;,&#39;2012-11-01 15:43:41&#39;,NULL),(3,&#39;Title strikes back&#39;,&#39;This is really exciting! Not.&#39;,&#39;2012-11-01 15:43:41&#39;,NULL),(4,&#39;ggjjkhkhhk&#39;,&#39;7777777777777777777777777\r\n777777777777777777777777&#39;,&#39;2012-11-01 20:16:28&#39;,&#39;2012-11-01 20:16:28&#39;);
/*!40000 ALTER TABLE `posts` ENABLE KEYS */;
UNLOCK TABLES;
--
-- Table structure for table `schema_migrations`
--
DROP TABLE IF EXISTS `schema_migrations`;
/*!40101 SET @saved_cs_client   = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `schema_migrations` (
 `version` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
 UNIQUE KEY `unique_schema_migrations` (`version`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Dumping data for table `schema_migrations`
--
LOCK TABLES `schema_migrations` WRITE;
/*!40000 ALTER TABLE `schema_migrations` DISABLE KEYS */;
INSERT INTO `schema_migrations` VALUES (&#39;20121013024711&#39;),(&#39;20121013030850&#39;);
/*!40000 ALTER TABLE `schema_migrations` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;
/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;
-- Dump completed on 2012-11-01 16:41:46
Copy after login

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template