前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >thinkphp创建应用的一般流程

thinkphp创建应用的一般流程

作者头像
PM吃瓜
发布2019-08-13 10:35:11
1.5K0
发布2019-08-13 10:35:11
举报
文章被收录于专栏:PM吃瓜(公众号)
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可以用我们学过的方法都行

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-05-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Tech爬虫 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二、ThinkPHP的创建应用的一般开发流程
    • 1、下载ThinkPHP
      • 2、建立单入口文件
      • 三、项目前台内容
      • 四 C层(控制层)配置
      • 五 运行(在本地服务器上)
      • 六 搭建数据库
      • 七、连接数据库
      • 八、商品列表页(index)数据展示
      • 九、登录注册页
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档