thinkphp创建应用的一般流程

2019-08-13 10:35:11 浏览数 (1)

MVC模式

MVC是一个设计模式,它强制性的使应用程序的输入、处理和输出分开。使用MVC应用程序被分成三个核心部件:模型(M)、视图(V)、控制器(C),它们各自处理自己的任务。

视图:视图是用户看到并与之交互的界面。对老式的Web应用程序来说,视图就是由HTML元素组成的界面,在新式的Web应用程序中,HTML依旧在视图中扮演着重要的角色,但一些新的技术已层出不穷,它们包括Adobe Flash和象XHTML,XML/XSL,WML等一些标识语言和Web services。如何处理应用程序的界面变得越来越有挑战性。MVC一个大的好处是它能为你的应用程序处理很多不同的视图。在视图中其实没有真正的处理发生,不管这些数据是联机存储的还是一个雇员列表,作为视图来讲,它只是作为一种输出数据并允许用户操纵的方式。

模型:模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有最多的处理任务。例如它可能用象EJBs和ColdFusion Components这样的构件对象来处理数据库。被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据。由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。

控制器:控制器接受用户的输入并调用模型和视图去完成用户的需求。所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后确定用哪个视图来显示模型处理返回的数据。

我们总结MVC的处理过程,首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户

单入口

单一入口通常是指一个项目或者应用具有一个统一(但并不一定是唯一)的入口文件,也就是说项目的所有功能操作都是通过这个入口文件进行的,并且往往入口文件是第一步被执行的。

入口的好处是项目整体比较规范,因为同一个入口,往往其不同操作之间具有相同的规则。另外一个方面就是单一入口带来的好处是控制较为灵活,因为拦截方便了,类似如一些权限控制、用户登录方面的判断和操作可以统一处理了。

二、ThinkPHP的创建应用的一般开发流程

1、下载ThinkPHP

下载完成后,解压,将文件里的ThinkPHP文件夹复制,我们在XAMPP/htdocs目录(服务器或者本地web目录)下新建一个文件bookstore文件夹,再将ThinkPHP文件夹拷贝到bookstore文件夹路径下

2、建立单入口文件

这里我们在bookstore路径下建立index.php文件作为前台项目的单入口文件

那么单入口文件里我们写什么内容呢?

默认情况下,我们只需要在该文件中添加一行代码即可:

代码语言:javascript复制
<?php
    //引入框架核心文件
    require "ThinkPHP/ThinkPHP.php";
?>

我们在bookstore下再建一个Index文件夹,用来存放生成的项目目录结构

那么我们还必须在单入口文件index.php文件中增加项目名称和项目路径,顺便开启调试模式:

代码语言:javascript复制
<?php
    //开启调试模式:部分做缓存
    define("APP_DEBUG",true);
    //定义项目名=称
    define("APP_NAME","Index");
    //定义项目路径
    define("APP_PATH","Index/");
    //引入框架核心文件
    require "ThinkPHP/ThinkPHP.php";
?>

开启调试模式有什么作用呢,请看 http://doc.thinkphp.cn/manual/debug_mode.html

然后,我们打开浏览器,输入地址并运行

http://localhost/bookstore/

就会看到欢迎页面

图片.png

注:如果没有出现这个欢迎页面,可将bookstore文件夹的权限修改为可读可写,应用到所有项目中. 出现欢迎页面表示ThinkPHP已经成功执行,这个时候系统已经在bookstore目录下生成了相关目录,并写入了初始Action

图片.png

生成的项目目录结构和系统目录类似,包括:

目录

说明

Common

项目公共文件目录,一般放置公共的js、css、图片等

Conf

项目配置目录,项目所有的配置文件都放在这里

Lang

项目语言包目录(可选,如果不需要多语言支持可删除)

Lib

项目类库目录,放置项目具体代码,包括Action( 行为、控制 C层)、Behavior、Model(模型 M层)、Widget(小插件)

Tpl

(V层)项目模板目录,支持模板主题

Runtime

项目运行时目录,包括Cache(模板缓存)、Temp(数据缓存)、Data(数据目录)和Logs(日志文件)子目录,如果存在分组的话,则首先是分组目录。

三、项目前台内容

html代码在bookstore/Index/Tpl文件夹里面写,那么在Tpl下:

首先新建Index目录,用来存放各页面的html文件 再新建Public目录,用来存放各个页面公共的html部分,比如头部和尾部css、js、images文件夹建在Index/Common下

图片.png

四 C层(控制层)配置

可以利用Lib/Action下系统自动生成的IndexAction.class.php文件,这个文件里面有一个IndexAction类,类里面的方法与我们建的html文件名一一对应,这里我们有5个页面,就要定义5个方法

代码语言:javascript复制
<?php
// 本类由系统自动生成,仅供测试用途
class IndexAction extends Action {
//主页
    public function index(){
    //--------------------------------- 定义变量 -------------------------------------
    //------------------------------ 将变量输出到模板 ----------------------------------
    //----------------------------------- 加载模板 ----------------------------------------
            $this->display();
    }
//登录页
    public function login(){
        $this->display();
    }
//添加图书页 
    public function addbook(){
        $this->display();
    }
//购物车页  
    public function shopcar(){
        $this->display();
    }
//商品详情
    public function bookinfo(){
        $this->display();
    }
}

五 运行(在本地服务器上)

根据路由原则:

http://localhost/bookstore/单入口文件/类名/方法名

首页 http://localhost/bookstore/index.php/Index/index

登录页 http://localhost/bookstore/index.php/Index/login

六 搭建数据库

这里我们在本地数据库localhost/phpmyadmin简单的搭建一个数据库,两个表,一个用来保存用户信息,一个用来保存商品信息

图片.png

图片.png

图片.png

图片.png

七、连接数据库

在Index/Conf/config.php文件中配置

代码语言:javascript复制
<?php
//项目配置文件
return array(
    //数据库配置信息
    //'配置项'=>'配置值'
    'DB_TYPE'   => 'mysql', // 数据库类型
    'DB_HOST'   => 'localhost', // 服务器地址
    'DB_NAME'   => 'bookstore', // 数据库名
    'DB_USER'   => 'root', // 用户名
    'DB_PWD'    => '', // 密码
    'DB_PORT'   => 3306, // phpmyadmin端口
    'DB_PREFIX' => '', // 数据库表前缀 
);
?>

八、商品列表页(index)数据展示

找到Index/Lib/Action/IndexAction.class.php文件的Index类的index方法(因为我们该页面的路由是http://localhost/bookstore/index.php/Index/index)

图片.png

然后html文件里面:

图片.png

结果:

图片.png

九、登录注册页

(一)注册

前台将用户信息发送给后台,后台判断数据库是否有重名,若重名则注册失败

那么这里会用到ThinkPHP的ajax传送数据,前台ajax可以用我们学过的方法都行

0 人点赞