基于ThinkPHP框架的博客系统_第1页
基于ThinkPHP框架的博客系统_第2页
基于ThinkPHP框架的博客系统_第3页
基于ThinkPHP框架的博客系统_第4页
基于ThinkPHP框架的博客系统_第5页
已阅读5页,还剩19页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

基于ThinkPHP框架的博客系统摘要:随着计算机和因特网的飞速发展,互联网信息资源日益丰富。博客,就是网络上发布和记录的流水日志,也被称为“网络日志”,它以简易迅速便捷的方式发布自己的心得,及时有效轻松地与他人进行交流,再集丰富多彩的个性化展示于一体的综合性平台,打破传统报刊、杂志撰写文章的方式,是代表着新的生活方式和新的工作方式,更代表着新的学习方式。系统采用PHP动态网站开发技术,MYSQL数据库,APACHE服务器,利用ThinkPHP开源框架技术, HTML+CSS+javascript等脚本语言,实现基于B/S模式的个人日志发表和交流的平台个人博客系统。关键词:博客系统PHPThinkPHP 动态网页Abstract: With the rapid development of computers and the Internet, the Internet increasingly rich information resources. Blog, publish on the web and record log of water, also known as web log, it is simple and quickly and easily publish their own experience, timely and effective and easily communicate with each other, and then set a variety of personalized show integrated platform, breaking the traditional newspaper, magazine to write articles on behalf of new lifestyles and new ways of working, but also represent new ways of learning.The system uses PHP dynamic website development, MYSQL database, APACHE server, the ThinkPHP open-source framework, HTML + CSS + the javascript and other scripting language, personal log of B / S mode, and a platform for exchange - personal blog system.Key words: The blog system PHP ThinkPHP dynamic webpage目录第一章 需求分析与功能简介2一、开发的需求分析2二、开发的技术概要21、网站程序开发技术21.1、PHP技术21.2 、AJAX技术22、网站前端设计技术21.1 、javascript脚本语言21.2、 DIV+CSS布局方式2三、开发的环境配置21、系统运行平台22、开发工具选用2四、开发的设计思想21、OOP(面向对象的编程思想)22、MVC 模型视图控制器思想23、ORM 对象关联映射思想24、单一入口访问思想2五、开发的目录结构2六、系统功能简介2第二章 数据库结构设计2一、数据库表结构设计2二、数据库关联模型映射21、用户权限的关联模型22、文章分类标签的关联模型2第三章 网站后台功能实现2一、RBAC基于角色的多用户访问控制功能21.1 RBAC的全局配置参数21.2 RBAC 操作初始化配置21.2 RBAC 用户的登陆检测2二、AJAX无刷新提交功能2三、无限级分类功能2四、文章管理2五、角色授权管理功能2六、文件管理器功能2七、数据库备份功能2第四章 网站前台功能及实现2一、3D标签云功能2二、日志归档功能2第五章 网站的用户体验2一、留言的字数统计2二、拖动型弹层2三、窗口化页面2第六章 总结2第七章 致谢2第八章 参考文献2第一章 需求分析与功能简介一、开发的需求分析越来越多的网络用户希望能够在网络平台上展现自己的个性,更方便地与人互动交流,无论是论坛、社区还是个人网站,都试图在这些方面进行努力,随着WEB2.0时代的到来,一个新的概念出现了博客。随着计算机网络的飞速发展,博客已经成为写网络日志必不可少的一种工具,也是一种简单有效的提供网络用户之间进行在线交流的网络平台,通过其可以结交更多的朋友,表达更多的想法,它随时可以发表日志,方便快捷。访客可以直接在个人Blog上留言,如提出问题或意见等。个人博客的发展,也已经成为广告商业务扩展的重要领域。总之, Blog是继Email、BBS、ICQ之后的第四种网络交互方式。Blog是未来信息化教育和个人知识管理的强大而易用的工具。二、开发的技术概要1、网站程序开发技术1.1、PHP技术PHP(Hypertext Preprocessor超文本预处理器)是一种 HTML 内嵌式的编程语言。PHP的语法大部分兼容了C、JAVA、Perl,并增加了PHP特有的语法结构,可以比CGI或Perl更快速的执行动态网页,只需要很少的编程知识就能建立一个交互的WEB站点。它可以管理动态内容,支持数据库,处理会话和跟踪,甚至构建整个电子商务站点。PHP是完全免费的开源产品,程序开发快,运行快,兼容UNIX、LINUX、WINDOWS等操作系统,可以在IIS、Apache、Nginx等WEB服务器端执行代码解析,能支持MySQL、MSSQL、Oracle、SyBase等主流数据库,构建LAMP(Linux+Apache+Mysql+Php)可以非常快速地搭建一套动态网站系统。 ThinkPHP是一个免费开源的,快速、简单的面向对象的轻量级PHP开发框架,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。使用ThinkPHP,你可以更方便和快捷的开发和部署应用。1.2 、AJAX技术AJAX 指异步 JavaScript 及 XML(Asynchronous JavaScript And XML),用于创建更好更快以及交互性更强的 Web 应用程序的技术。Ajax不是一门编程语言,它的核心是JavaScript对象XmlHttpRequest,通过XmlHttpRequest,用户可以在不重载页面的情况下直接与服务器进行通信,形成与Web服务器间交互数据。这一特性不仅优化了网站界面和用户的体验,也提高了系统的性能,大大增强了网站的“动态化”。2、网站前端设计技术1.1 、javascript脚本语言JavaScript是一种能让你的网页更加生动活泼的程式语言,是一种动态、弱类型、基于原型的语言,通过浏览器可以直接执行。利用JavaScript能轻易的展现各类的网页特效,增加的网络用户的观赏性。它的代码结构比较松散,记录在HTML文件中,可以直接查看源码获得。Jquery是Javascrpt的一个框架,轻量级的js库,兼容各种浏览器 (IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+)。jQuery使用户能更方便地处理HTML documents、events、实现动画效果,并且方便地为网站提供AJAX交互。1.2、 DIV+CSS布局方式DIV+CSS是WEB标准中常用术语之一它是网页布局的一种方式,这种方式区别于传统的HTML网页设计语言中的表格(Table)定位,采用DIV+CSS的布局方式,可实现网页页面内容与表现相分离,优化了HTML代码结构,能很好的被浏览器解析,同时也有利于搜索引擎的收录。 DIV+CSS适应未来网络应用更多的需求。三、开发的环境配置1、系统运行平台操作系统 :WINNT运行环境 :Apache/2.2.17 (Win32)PHP程序版本 :5.3.5MYSQL程序版本 :5.5.8浏览器:Firefox、IE9、Chrome2、开发工具选用程序开发软件:Zend Studio 8.0 、Dreamwever CS5、EditPlus3 数据库软件:phpMyAdmin图像处理软件:Photoshop CS5测试软件:IETester、Firebug、WebDeveloper、IE调试工具四、开发的设计思想1、OOP(面向对象的编程思想)面向对象编程(Object Oriented Programming,OOP,面向对象程序设计)是一种计算机编程架构。OOP的一条基本原则是计算机程序是由单个能够起到子程序作用的单元或对象组合而成。OOP达到了软件工程的三个主要目标:重用性、灵活性和扩展性。为了实现整体运算,每个对象都能够接收信息、处理数据和向其它对象发送信息。OOP主要有以下的概念和组件: 组件 数据和功能一起在运行着的计算机程序中形成的单元,组件在 OOP 计算机程序中是模块和结构化的基础。 抽象性 程序有能力忽略正在处理中信息的某些方面,即对信息主要方面关注的能力。 封装 也叫做信息封装:确保组件不会以不可预期的方式改变其它组件的内部状态;只有在那些提供了内部状态改变方法的组件中,才可以访问其内部状态。每类组件都提供了一个与其它组件联系的接口,并规定了其它组件进行调用的方法。 多态性 组件的引用和类集会涉及到其它许多不同类型的组件,而且引用组件所产生的结果得依据实际调用的类型。 继承性 允许在现存的组件基础上创建子类组件,这统一并增强了多态性和封装性。典型地来说就是用类来对组件进行分组,而且还可以定义新类为现存的类的扩展,这样就可以将类组织成树形或网状结构,这体现了动作的通用性。 2、MVC 模型视图控制器思想MVC是一个设计模式,它强制性的使应用程序的输入、处理和输出分开。使用MVC应用程序被分成三个核心部件:模型(M)、视图(V)、控制器(C),它们各自处理自己的任务。 视图 :视图是用户看到并与之交互的界面。视图就是由HTML元素和web应用程序组成的界面,它作为一种输出数据并允许用户操纵的方式。模型 :模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有最多的处理任务。被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据。由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。 控制器 :控制器接受用户的输入并调用模型和视图去完成用户的需求。所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后确定用哪个视图来显示模型处理返回的数据。 3、ORM 对象关联映射思想对象-关系映射(Object/Relation Mapping,简称ORM),是随着面向对象的软件开发方法发展而产生的。面向对象的开发方法是当今企业级应用开发环境中的主流开发方法,关系数据库是企业级应用环境中永久存放数据的主流数据存储系统。对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系,而在数据库中,关系数据无法直接表达多对多关联和继承关系。因此,对象-关系映射(ORM)系统一般以中间件的形式存在,主要实现程序对象到关系数据库数据的映射。4、单一入口访问思想单一入口通常是指一个项目或者应用具有一个统一的入口文件,既项目的所有功能操作都是通过这个入口文件进行的,它使得项目整体比较规范,不同操作之间具有相同的规则,同带来的好处是控制较为灵活。五、开发的目录结构Public : 存放站点公共目录,存放图片(Images)、样式(Css)、脚本(Js),以及用户上传的资源UploadsThinkPHP :存放ThinkPHP框架引擎WebApp : 存放博客系统的目录,包含全局参数,模型,类库,模板,公共函数及缓存等文件。index.php :站点入口文件六、系统功能简介博客系统是基于ThinkPHP框架技术开发,具有一般博客系统发布、修改、删除文章,日志的评论和归档等功能,同时也增设了标签、无限分类、权限管理、文件管理功能,支持站点的数据库结构查看及其备份。利用MiniUi控件,增强的后台管理界面和用户体验,同时结合AJAX技术对数据的异步交互,大大增强对用户操作的便携性和透明性。博客系统后台管理首页文章页日志归档,标签云,分类列表内容显示,点击数,访问评论系统管理文章管理文件管理权限管理角色管理用户管理文件管理器节点管理数据备份站点配置上传文件文章列表分类标签发表文章前台界面站点名称、站点描述、分页页数等配置数据库表信息、数据表结构、数据库备份文章的发表、标签的插入文章的编辑、删除,分类显示和标签显示分类的显示、创建、编辑、删除,标签的显示和删除多文件上传,文件的删除和预览目录遍历,文件和文件夹的删除、命名,文件的编辑节点的创建、编辑、删除,节点的启用和禁用角色的创建、编辑、删除,角色的授权角色的创建、编辑、删除,用户分配角色第二章 数据库结构设计一、数据库表结构设计b_blog 文章表b_category 分类表b_comment 评论表idID号idID号idID号categoryId分类ID号title分类名recordId文章ID号title文章名remark备注author昵称content内容pid父分类email邮箱cTime创建时间path分类路径url个人站点status状态ip评论者IPreadCount点击数b_access 角色访问表content内容commentCount评论数idID号cTime创建时间tags标签role_id角色ID号agent操作系统node_id节点ID号status状态b_options 站点配置表idID号b_role 角色表b_node节点表option_name配置名idID号idID号option_value配置值name角色名name节点名status状态pid父分类title显示名status状态status状态b_user节点表remark备注remark备注idID号pid父节点username用户名b_role_user角色用户关系level等级nickname昵称role_id角色ID号password密码user_id用户ID号tagged 标签关联表reg_date注册时间idID号status状态tag 标签表tagId标签ID号remark备注idID号recordId文章ID号email邮箱name标签名tagTime标签应用时间count使用数b_upload 上传表b_link 友情链接表idID号link_idID号filename文件名link_url链接地址url上传路径link_name链接名filesize文件大小link_target跳转模式filetype文件类型link_decoration链接描述uptime上传时间link_order链接排序status状态二、数据库关联模型映射1、用户权限的关联模型b_user 用户表b_role_user角色用户关系b_node节点表idID号user _id用户ID号idID号username用户名role _id角色ID号name节点名nickname昵称title显示名password密码b_role 角色表pid父节点reg_date注册时间idID号level等级status状态name角色名remark备注pid父分类b_access 角色访问表email邮箱status状态node_id节点ID号idID号remark备注role_id角色ID号用户权限的关联模型,角色是一组用户的集合,通过一对多的关系,一组角色可以关联多个用户,用户的权限管理取决于角色的权限管理。角色的访问形成了角色与节点之间多对多的关系,每一组角色都有一条或多条节点关系,多组角色形成了多对多的关系模型,这样,用户的权限将取决于节点的等级,节点表具有管理用户操作的功能。 2、文章分类标签的关联模型b_blog 文章表b_category 分类表b_tag标签表idID号idID号idID号categoryId分类ID号title标题name标签名title标题pid分类父IDcount标签使用次数content内容cTime创建时间tagged 标签关联表status状态idID号tags标签recordId文章IDtagId标签ID文章分类标签的关联模型,文章与分类形成一对一的关系,分类的父ID在分类表中实现“内联”关系,形成分类的无限子分类。文章编写标签集通过分割插入到标签表中,标签表中是一组无冗余的表,只记录新创建的标签,如果标签重复出现,标签关联表能记录下不同文章关联相同的标签。文章表和标签表实现了多对多的关系映射。 第三章 网站后台功能实现一、RBAC基于角色的多用户访问控制功能1.1 RBAC的全局配置参数true,USER_AUTH_ON=true,USER_AUTH_TYPE=1,/ 默认认证类型 1 登录认证 2 实时认证USER_AUTH_KEY =authId,/ 用户认证SESSION标记ADMIN_AUTH_KEY =administrator,/ 记录管理员的SESSION,USER_AUTH_MODEL =User,/ 默认验证数据表模型,即用户账户管理表AUTH_PWD_ENCODER =md5,/ 用户认证密码加密方式USER_AUTH_GATEWAY =/Admin/Public/login, / 默认认证网关NOT_AUTH_MODULE =Public, / 默认无需认证模块REQUIRE_AUTH_MODULE =, / 默认需要认证模块NOT_AUTH_ACTION =, / 默认无需认证操作REQUIRE_AUTH_ACTION =, / 默认需要认证操作GUEST_AUTH_ON =false, / 是否开启游客授权访问GUEST_AUTH_ID =0, / 游客的用户IDRBAC_ROLE_TABLE =b_role, / 角色分组表RBAC_USER_TABLE =b_role_user, / 用户角色关联表RBAC_ACCESS_TABLE =b_access, / 系统访问权限表RBAC_NODE_TABLE =b_node, / 系统节点表);?(图1)如图1所示,配置认证的SESSION标记为authId,用与记录用户登陆的ID号,$_SESSIONUSER_AUTH_KEY相当与$_SESSIONauthId配置用户的登陆网关为USER_AUTH_GATEWAY =/Admin/Public/login,也就是用户登陆后台的第一道门,若已经登陆,就会跳转到后台主页面,相反的没有设置$_SESSIONauthId的值或该值已过期,就会显示登陆界面。1.2 RBAC 操作初始化配置class CommonAction extends Action function _initialize() / 用户权限检查,判断是否开启的用户权限认证,且排除掉无需认证的模块 if (C(USER_AUTH_ON) & !in_array(MODULE_NAME, explode(, C(NOT_AUTH_MODULE) import(ORG.Util.RBAC); /引入RBAC类库 /检测用户是否权限,有权限放回true跳转到后台管理,无权限执行一下代码 if (!RBAC:AccessDecision(GROUP_NAME) /检查用户的SESSION ID,不存在则跳到默认网关if (!$_SESSION C(USER_AUTH_KEY) redirect(PHP_FILE . C(USER_AUTH_GATEWAY); /正常登陆没有权限,跳转到RBAC_ERROR_PAGE 提示的权限页,如果没有该配置,直接给出没有权限访问该页面 if (C(RBAC_ERROR_PAGE) redirect(C(RBAC_ERROR_PAGE);/ 没有权限 抛出错误 else if (C(GUEST_AUTH_ON) $this-assign(jumpUrl, PHP_FILE . C(USER_AUTH_GATEWAY); $this-error(L(_VALID_ACCESS_);/ 提示错误信息 (图2)如图2所示,配置了USER_AUTH_ON为true,即我们开启了RBAC的验证,这里的NOT_AUTH_MODULE 默认配置了PUBLIC模块,则表示其他模块只要继承了CommonAction类,则需要进行RBAC验证;调用RBAC:AccessDecision(GROUP_NAME),检查该分组的权限,有权限则返回ture,跳转到管理界面;无权限则返回false,抛出错误信息。1.2 RBAC 用户的登陆检测class PublicAction extends Action public function checkLogin() $data=json_decode($_REQUESTsubmitData,true); / 接收异步提交过来的json数据进行解码if(empty($datausername) / 检查用户提交的用户名、密码、验证码都不为空$this-ajaxReturn(username,账户必须!,0);elseif (empty($datapassword)$this-ajaxReturn(password,密码必须!,0);elseif (empty($dataverify)$this-ajaxReturn(verify,验证码必须!,0); $map = array(); /生成认证条件$mapusername = $datausername;$mapstatus = array(gt,0); if($_SESSIONverify != md5($dataverify) $this-ajaxReturn(verify,验证码错误!,0); import ( ORG.Util.RBAC ); $authInfo = RBAC:authenticate($map); /使用用户名、密码和状态的方式进行认证 if(false = $authInfo) $this-error(帐号不存在或已禁用!); else if($authInfopassword != md5($datapassword) $this-ajaxReturn(password,密码错误!,0); $_SESSIONC(USER_AUTH_KEY) =$authInfoid; /登陆成功,记录用户SESSION if($authInfousername=admin) /检测是否为管理员帐号,是则开放最大权限 $_SESSIONadministrator=true; RBAC:saveAccessList(); / 缓存访问权限列表$this-success(登录成功!);?(图3)如图3所示,系统异步获取用户提交的数据,进行json的解码操作,分别判断接收的用户名,密码,验证码都不为空,验证成立生成认证条件。调用RBAC:authenticate()方法,传入$map数组,通过authenticate方法来检测后台账户表中是否有该用户,并帐号状态是否正常;C(USER_AUTH_MODEL)就是图1配置User,对应后台账户表就是b_user表,该方法会返回该账户的相关信息,赋值到$authInfo中,如果该用户存在,通过密码比对就完成了一个登陆认证。登陆后的用户ID记录在$_SESSIONauthId中,如果用户名是管理员”admin”,则$_SESSIONadministrator会设置为true,在RBAC类中对于该用户拥有最高的权限。最后通过调用RBAC:saveAccessList()方法将该用户拥有的各个角色的节点访问权限保存在SESSION中,可以通过$_SESSION_ACCESS_LIST查看系统访问权限列表。二、AJAX无刷新提交功能(图4)站点配置AJAX无刷新提交如图4,表单按钮 保存 触发javascript自定义onSave函数,代码如下所示:function onSave(e) ThinkAjax.sendForm(form1,_URL_/update,function (data,status,info)if (status=1)alert(操作成功);,result);当用户触发onSave函数后,ThinkAjax.sendForm将表单的内容提交到指定的url地址,ThinkAjax是ThinkPHP框架集中提供的一种ajax提交方式,方便用户对数据的异步请求和处理。其中_URL_表示当前模型的URL地址,全路径为index.php/Admin/Option/update,对应的服务端程序为$v)$voption_value=addslashes($voption_value);$Option-save($v);$this-ajaxReturn(,保存成功,1);else$this-error($Option-getError();?服务器段通过$_POST预定义变量接收表单请求,通过实例化一个Options模型对象来建立数据库句柄$Option,通过一个循环将数据更新到数据库中,最后通过ajaxRturn的方法将结果放回到客户端,其中ajaxRturn包含三个参数,1表示返回的数据,2表示返回的信息,3表示返回的状态,客户端的js通过一个函数接收ajaxRturnde的内容,如果状态为1表示表单成功被修改。下面的图5和图6通过Firebug开发工具来说明了表单进行异步请求和响应的全过程。(图5)Firebug抓取客户端操作进行的异步请求(图6)Firebug抓取服务端对数据的异步响应三、无限级分类功能(图7)创建无限级分类用户通过点击增加分类来创建新的分类,创建分类时通过点击所属分类来形成子父分类关系,多级子分类通过分类路径来达到总体的关联效果,如图7所示。实现该效果的服务端代码如下所示。class CategoryAction extends CommonAction public function index() $Cate=M(Category);$list=$Cate-field(id, title, pid, concat( path, -, id ) AS bpath)-order(bpath,id)-select();foreach($list as $key=$value)$list$keycount=count(explode(-,$valuebpath);$this-assign(list,$list);$this-display();?服务端查找数据库b_category表,通过Mysql内置的concat函数将它的路径关系和自己id连合起来,形成整段分类路径,再通过foreach遍历数据集,分割数据集中的分类路径,查看层次关系,得到该分类的层叠数。将该数组通过thinkphp模板引擎 volist页输出,运用CSS对输出的层叠数进行样式的格式化,就形成了无限集分类的效果。然而分类与父类集之间的路径关系是如何的实现的?下面的代码将解释这个路径关系的实现原理。where(id=$pid)-find();$bpath=$listpath.-.$listid;return $bpath;?创建一个自定义模型类,当用户添加分类的时候会实例化这个模型类,该类继承了ThinkPHP框架的Model 类,$_auto是该类库中定义的一个属性,完成数据自动处理功能,用来处理默认值、数据过滤以及其他系统写入字段。$_auto属性是由多个填充因子组成的数组,填充因子格式为array(填充字段,填充内容,填充条件,附加规则),这里将path内容填充的是cpath函数返回的值,它通过用户提交过来的父ID号查找数据库,得到父级的关系信息,让父级的路径关系与父ID连合就是当前分类的路径关系。四、文章管理文章管理模块是整个博客系统最主要的环节,它包括了日志的发表、编辑、删除、预览、评论、点击、自定义标签、所属分类、分页等多项功能。文章的发表引入了kindEditor的富文本编辑器,支持用户在网站上创建可见可得的编辑效果。下面将展示文章管理的相关页面。(图8)分页模式下的文章列表(图9)发表文章(图10)访客的评论(图11)标签的管理五、角色授权管理功能(图12)节点管理(图13)角色权限管理(图14)分配用户所属组基于角色的访问控制模型(RBAC Model,Role-based Access Model):RBAC模型的基本思想是将访问许可权分配给一定的角色,用户通过饰演不同的角色获得角色所拥有的访问许可权。如图12所示创建节点,节点管理用户操作该模型的权限,一个节点包含查看、添加、插入、编辑、更新、删除、启用、禁用等操作权限,图13显示的是管理员对该角色进行授权,图14指派到角色组中,从而来控制用户权限的管理。六、文件管理器功能(图15)文件管理器(图16)文件内容编辑器(图17)文件重命名(图18)文件上传如图15 所示,文件管理列表通过传递当前的工作路径,以FileManage类的getFileList方法遍历整个工作路径,获得当前工作路径下的文件夹和文件。path = $path;$this-doroot=$_SERVERDOCUMENT_ROOT;function getPath() return $this-path; function setPath($v) $this-path=$v;function getFileList($dirname=.) $dirname=str_replace(/,/,$dirname); $thispath=$this-doroot.$dirname;$d = dir($thispath);while(false!=$file=$d-read()$filepath=$dirname.$file;if ($file=. | $file=. & $dirname=C(ROOT_NAME)continue;$filesize=is_dir($thispath.$file)?:round(filesize($thispath.$file)/1024,2).kb;$filetime=is_dir($thispath.$file)?:date(Y-m-d H:i:s,filemtime($thispath.$file);$this-fileList = array(filename=iconv(gb2312,UTF-8,$file),filepath=$dirname.iconv(gb2312,UTF-8,$file),filesize=$filesize,filemtime=$filetime,filetype=filetype($thispath.$file),);foreach ($this-fileList as $k = $v) $filetype$k = $vfiletype;$filename$k = $vfilename;array_multisort($filetype, SORT_ASC,$filename, SORT_ASC, $this-fileList);$d-close();return $this-fileList;?七、数据库备份功能(图19)查看数据表(图20)数据表结构 如图19所示,通过Sql语句 show table status from 数据库名 可以查看所有表的信息,图20通过用户提交表名,执行Sql语句 show columns from 表名 获得表结构,用户通过点击“数据库备份”,将执行以下两段函数来生成整个表的SQL语句,通过文件写入函数file_put_contents将内

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论