《2022年2022年零基础学习PHP-从零开始学习PHP-PHP基础教程-PHP简明教程 .pdf》由会员分享,可在线阅读,更多相关《2022年2022年零基础学习PHP-从零开始学习PHP-PHP基础教程-PHP简明教程 .pdf(39页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、欢迎来到PHP 的世界!PHP 起步PHP 语言是最受欢迎的Web 开发语言之一。它以学习简单、开发快速、性能稳定而倍受 Web 开发人员的青睐。PHP 不仅使用人员众多、数以万计的Web 站点用它构建,而且有强大的社区支持,使得无论是用PHP 开发Web 应用,还是学习PHP 语言,都会快速有效、事半功倍。在各种Web 开发语言、框架、概念纷扰的今天,PHP 仍以其独特魅力吸引更多的 Web 开发人员学习和使用。选择 PHP ,没错的!1.1 初识 PHP PHP 是一种服务器端的、嵌入HTML 的脚本语言。它的语法结构和C 语言极为相似。为了能够快速地编写动态Web 页面, PHP 还加入
2、了自己的某些语言特征,这些特征都非常容易理解和使用。先来看一个嵌入有PHP 代码的HTML 文档。 Welcome 1.2 LAMP 锋利四剑客: Linux、Apache、MySQL 和 PHP 要想学习PHP ,就有必要了解和PHP 关系密切的其他3 种技术: Linux 操作系统、 Apache 网络服务器和MySQL 数据库。LAMP 这个名词最早由Michael Kunze 创造,用来代表Linux 操作系统、 Apache 网络服务器、 MySQL 数据库和PHP(如果可以, Perl 和 Python 也是不错的选择),LAMP 正是这4 种技术的首字母。PHP 作为强有力的We
3、b 开发语言,和Linux、Apache、MySQL 的支持是密不可分的。它们都是开源软件,并且有强有力的社区支持,它们的完美组合构成了当今Web 开发世界中不可忽视的一极重要力量。而且,这支力量近年一直在不断地变得更加强大。虽然,这4 种技术并不是专门被设计成在一起工作的,但多年来,这些软件之间的兼容性不断完善,不仅完改善了个组件之间的协作,扩展出更多的功能,而且在目前几乎所有的Linux 版本中都默认包含了这些产品,使得这些产品共同组成了一个强大的Web 应用平台。1.3 PHP Web 编程的体系结构和基本内容概括地说,任何Web 编程体系,无外乎服务器端和客户端的程序开发。基于PHP
4、的Web 应用开发也不例外,其中客户端的开发包括使用HTML 设计 Web 页面,使用样式表控制 Web 页面的显示效果,还需要客户端的脚本语言来控制浏览器的特效、验证HTML 表单数据等,这些脚本语言包括JavaScript、VBScript 等。服务器端的开发就需要掌握PHP 语言和 MySQL 数据库的有关内容。本节的各小节将对这些内容做简要说明,之后的各节将较为详细地介绍HTML、样式表和 JavaScript,它们都是Web 开发的基础内容,对这些内容不了解的PHP 初学者有必要掌握。1.3.1 了解 PHP、HTML、层叠样式表( CSS )和 JavaScript 及其关系作为服
5、务器端的脚本语言,PHP 多数情况下都是和HTML 相互搭配来使用的。PHP 用来名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 39 页 - - - - - - - - - 完成和逻辑有关的动态内容。PHP 程序执行的输出结果,通过HTML 文档表现给用户。一般情况下,在HTML 页面中需要输出数据的地方内嵌入PHP 代码,这个页面也就成为了PHP 程序。在创建HTML 页面时,都要考虑页面设计。如页面布局、页面颜色、字体、边距空白等。这些设置可以单独在页面中进行,但那
6、样会使HTML 页面变得臃肿,也不便于将来的维护。层叠样式表解决了这些问题,它允许页面设计人员在层叠样式表(即CSS )文件里设定页面表现效果,如字体大小、边距控制等。CSS 使得HTML 页面的表现更加丰富、美观,也更加容易维护。1.3.2 HTML 文档HTML 文档就是使用HTML 标记语言创建的文档。通过浏览器浏览的网页,几乎都是HTML 文档,或者是由服务器端程序生成的HTML 文档。下面就是一个HTML 文档的代码。 HTML 文档示例 HTML 语言 First Web Page 1.3.3 使用样式表实现页面效果按照 HTML 的设计初衷,文档的内容、结构与格式是分离开来的。如
7、果过多地在HTML 文档中控制页面的显示效果,会使HTML 文档的维护越来越难以维护,也违背了HTML 的设计初衷。为了解决这个问题,引入了样式表的概念。一个简单的样式表如下所示。说明:样式表负责控制页面的格式和显示效果,HTML 文档负责控制结构和显示内容。p font-size:10pt; 这个样式表定义的含义是,HTML 文档中所有用 标签定义的内容,都将使用10pt 大小的字体显示。关于样式表语法和如何使用样式表,将在后面做讲述。1.3.4 客户端的响应Web 页面作为客户端,有时需要直接对用户的请求作出响应。这主要是通过客户端脚本来实现,这些脚本语言包括JavaScript 等。可以
8、在HTML 页面中加入JavaScript 脚本,这些脚本可以直接在浏览器里执行。这样,就可以达到在客户端响应用户请求的需求。一般这样的响应主要是验证表单数据、用户操作提示等。本书将在1.6 节介绍JavaScript。1.3.5 嵌入式脚本页面PHP 代码一般都是嵌入在HTML 文档当中,通过服务器解释这些PHP 代码,并用代码执行产生的结果替换PHP 代码内容,最后返回给用户的是内嵌代码执行后的HTML 文档。例如内嵌生成 “ Hello World” 的 HTML 页面代码如下: HTML-PHP 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - -
9、- - - - - - 名师精心整理 - - - - - - - 第 2 页,共 39 页 - - - - - - - - - 1.4 Web 编程的基础知识之一:HTML HTML 是创建Web 应用的最基本内容,无论是动态还是静态页面,最终都要产生HTML 文档。所有的Web 开发都要涉及到用HTML 设计Web 页面。本节将介绍HTML 语言及如何使用 HTML 创建Web 页面。1.4.1 HTTP 协议简介网络上的计算机之间要进行通信,就必须遵守一定的规则,这种通信规则就是网络协议。协议保证网络上各种不同的计算机之间能够理解彼此传递的消息,好比操不同语言的人们之间,通过翻译来理解对方
10、所说话的含义一样。现在应用最广的Internet 使用的是TCP/IP 协议,而浏览WWW 使用的是HTTP 协议,即超文本传输协议(HyperText Transfer Protocol),此协议建立在TCP/IP 协议之上。浏览网页的过程,其实就是一系列请求/ 响应的过程。 HTTP 协议定义了这个请求/ 响应过程中请求和响应的格式,及维护HTTP 链接的内容。1.4.2 HTML 基本知识:标签HTML 的全称是HyperText Markup Language,即超文本标记语言。它是一种简单、通用的标记语言。之所以叫标记语言,是因为,HTML 通过不同的标签,来标记文档的不同部分。读者
11、看到的每个Web 页面,都是由HTML 通过一系列定义好的标签生成的。从简单的文本编辑器,如Windows 的记事本,到专业化的编辑工具,如Dreamveaver,都可以用来编辑HTML 文档,编辑好的HTML 文档必须按后缀 .html 或.htm 来保存,最后,通过浏览器打开HTML 文档,来查看页面效果。在 HTML 文档中,标签是包含在“ ” 之间的部分,如就是一个标签。标签一般是成对使用的,如和同时使用,其中 是开始标签, 是结束标签。 HTML 的标签不区分大小写,因此和表示的含义相同。1.4.3 HTML 基本知识:元素HTML 元素由标签定义,标签所定义的内容就叫“ 元素” ,
12、元素包含在开始标签和结束标签之间。每一种HTML 元素,一般都会有一个或数个属性,属性用来设置或表示元素的一些特性、名称或显示效果等。属性放在元素标签中,紧跟标签名称之后,它和标签名称之间有一个或数个空格。元素的每个属性都有一个值,属性的值的设定使用“ 属性 =” 值”的格式,可以为属性的,值 ? 加上引号或不加引号。下面的HTML 代码为标签 设置了name 属性,其值为login,表示这个表单的名称为login。 1.4.4 HTML 基本知识: HTML 的基本元素元素是组成HTML 文档的关键,本节介绍HTML 常用的几种基本元素。1标头元素 :HTML 使用标签 定义一个标头,结束标
13、签是。2标题元素 :这里的标题,是指HTML 文档中,内容的标题。标题元素由标签到 定义。3段落元素 :HTML 中使用标签 和定义一个段落。4字形元素 :使用标签 和定义一个粗体字形元素5链接 :HTML 文档中指向其他Web 资源,如另一个HTML 页面、图片等的链接被称为“ 锚” 。在 HTML 中使用标签 和定义一个锚元素,即链接元素,也就是说在和 之间的内容,会成为一个超链接。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 39 页 - - - - - - -
14、- - 6图像元素 :使用标签 定义一个图片元素,在标签中使用属性src 来指向一个图片资源,象这样 ,其中url 是指向资源所在位置。这个位置可以是一个URL ,也可以是一个相对地址,7表格元素 :使用标签 和定义一个表格元素。一个表格由“ 行” 构成,每一行由数据单元构成。表格的“ 行” 用标签 和 定义,数据单元用标签和 定义。8列表元素 :说明: HTML 的列表分为无序列表和有序列表。9表单元素 :HTML 表单是一个包含表单元素的区域,表单元素一般会作为数据,提交给后台服务器做处理。表单域用标签和 定义。表单元素是那些定义在表单域里,可以输入信息的元素,如文本框、单选按钮、下拉列表
15、等。1.4.5 创建 HTML 文档使用任何一款文本编辑器,都可以编辑HTML 文档。编辑好的HTML 文档,按后缀名 .html 或 htm 保存,最后通过浏览器访问HTML 文档。打开一个文本编辑器,键入如下HTML 代码(代码1-15),1.4.6 创建 HTML 列表HTML 最基本的列表有两种:无序列表和有序列表,列表可以嵌套使用,亦可同时使用。创建无序列表,通过设置标签的type 属性,可以更改列表项的标志。type 属性的取值可以是disc,square 或 circle 中的任意一个。创建有序列表,通过设置标签的type 属性,可以为有序列表的列表项设置不同的顺序标志。对于无序
16、列表来说,1.4.7 创建页面表格标签和用来创建一个表格。标签主要的常用属性有width 、align 和 border。width 属性:设置表格的宽度,如下所示。这里定义一个宽度为600px(600 点像素)的表格。 align 属性,设置表格相对于浏览器区域的对其方式,可以选取的值有:left(居左)、 center (居中)或right(居右)。border,设置表格的边框宽度,单位为像素。1.4.8 建立页面表单使用标签 和 创建一个表单。 的主要属性是action 和 method 。action 属性:用来指定表单数据被提交后,处理这些数据的程序的地址。如下HTML 代码,表示当
17、表单提交后,表单的数据将被传到文件login.php,由 login.php 来处理传入的数据。 method 属性:指定用何种HTTP 方式传递数据。有两种传递数据的方式:POST 方式和GET 方式。 POST 方式将表单数据放在HTTP 数据的正文部分传递。GET 方式将表单数据加到action 所指的地址之后传递。1.5 Web 编程的基础知识之二:层叠样式表(CSS )简介层叠样式表的英文全称是Cascading Style Sheet (简称CSS )。 HTML 最初设计时,只是用来定义文档的内容。比如标签就是用来定义一个HTML 文档的表格。页面的布局由浏览器显示,并不由HTM
18、L 标签控制。随着一个站点HTML 文件的越来越多,如果用仍HTML 标签排版和控制页面显示效果,它的局限性和困难性的问题会日益突出。甚至,在标签无法满足页面显示效果时,有的设计名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 39 页 - - - - - - - - - 人员又加入JavaScript 来控制页面效果。可以想象,这样HTML 文档会变得越发臃肿,并且越来越难以维护。层叠样式表( CSS )的出现解决了这个问题,即使用CSS 决定网页内容如何显示,用CSS
19、控制页面显示效果。1.5.1 样式表的基本语法一个样式 (Style)的语法由3 部分构成: Selector(选择器),属性(Property),属性值 (Value)。格式如下:selector property: value 例如下面的例子,p 就是 selector,color 就是属性, blue 就是属性值。p color:blue 其中 p 就是指p 标签 ,这个样式( Style)的含义表示凡是用标签标记的文档内容,其文本颜色显示为蓝色。HTML 中所有的标签都可以作为selector。如果想为Style 添加多个属性,可以在两个属性之间用分号分隔。下面的Style 就包含两个
20、属性,一个是对齐方式,其值为居中,一个字体颜色,其值为红色,它们之间用分号分隔开。p text-align:center;color:red 1.5.2 设置页面字体格式使用 CSS 可以设置字体的名称、大小、显示风格等样式。1字体名称属性:font-family (用这个属性设定字体的名称,如Arial, Tahoma, Courier 等。)2字体大小属性:font-size(font-size 属性用来设定字体的大小,字体大小的单位有多种,常见的是pt 和 px。)3字体风格属性:font-style (这个属性有3 个值可选: normal(正常显示)、italic(斜体显示)、 ob
21、lique (斜体显示)。 normal 是缺省值。)1.5.3 设置页面颜色和背景使用 CSS 背景颜色属性和背景图片属性,可以很方便地设置Web 页面的颜色和背景。1背景颜色属性:background-color(此属性为HTML 元素设定背景颜色,示例代码如下。)body background-color:#99FF00;(上面的代码表示body 这个 HTML 元素的背景颜色值是#99FF00 。)2背景图片属性:background-image(此属性为HTML 元素设定背景图片)名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - -
22、 - - 名师精心整理 - - - - - - - 第 5 页,共 39 页 - - - - - - - - - 1.5.4 处理页面的边距和填充边距属性是用来设置页面中一个元素所占空间的边缘到相邻元素之间的距离。左边距属性: margin-left :这个属性用来设定左边距的宽度。示例代码如下。.d1margin-left:1cm 右边距属性:margin-right :这个属性用来设定右边距的宽度。示例代码如下。.d1 margin-right:1cm 上边距属性: margin-top :这个属性用来设定上边距的宽度。示例代码如下。.d1 margin-top:1cm 下边距属性: ma
23、rgin-bottom :这个属性用来设定左边距的宽度。示例代码如下。.d1margin-bottom:1cm 边距属性: margin:这个属性是设定边距宽度的一个快捷的综合写法,用这个属性可以同时设定上下左右边距属性。还可以为上下左右边距设置相同的宽度。示例代码如下。.d1 margin:1cm 1.5.5 理解 HTML 层的概念HTML 中,使用标签和 来定义一个层,通过CSS 指定不同的属性值,可以定位层,从而实现页面的布局。利用层可以非常灵活地放置内容,例如可以将层前后放置、隐藏某些层而显示其他层、在屏幕上移动层等。可以在一个层中放置背景图像,然后在该层的前面放置第二个层,从而包含
24、带有透明背景的文本。通常,可以把层看成一个容器,在层里可以放置其他更多的HTML 元素。1.5.6 按 Web 标准建立网页传统 HMTL 布局,一般都是使用表格。表格定位比较简单快捷,但容易出现表格嵌套表格的现象,这样对页面的后期维护很不方便,而且表格越多,越会影响到浏览器解析HTML 文档的速度,使页面打开的速度变慢。如今,页面设计人员更多地使用HTML 层和 CSS ,用于 Web 页面的布局。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 39 页 - - - -
25、 - - - - - 所谓的Web 标准,其实并没有统一的标准。不过,它似乎朝着使用和 CSS 进行页面布局的方向行进。DIV+CSS 只是具体的实现技术手段,并不能涵盖web 标准。 web 标准不仅仅是布局的问题,更重要的是信息结构清晰、内容与表现相分离,而DIV+CSS 技术能较好的实现这种思想。因此,当前看到的多数符合标准的页面都是采用DIV+CSS 制作。1.5.7 在网页中引入样式表最常用的样式表引入方式有:内嵌样式(Inline Style)、内部样式表(Internal Style Sheet)和外部样式表( External Style Sheet)。内嵌样式:内嵌样式是写在
26、标签里面的。内嵌样式只对所在的标签有效。如下代码所示。 用 Style 定义字体 这里在 标签内增加样式:style=font-size:20pt; color:red ,这个样式只对当前标签有效。内部样式:内部样式表是写在HTML 的里面的。内部样式表只对所在的网页有效。外部样式:外部样式是指,将样式(Styles)写在一个以 .css 为后缀的CSS 文件里,然后在每个需要用到这些样式(Styles)的网页里引用这个CSS 文件。1.6 Web 编程的基础知识之三:JavaScript 基础JavaScript 是一种基于对象和事件驱动并具有安全性能的脚本语言,它是Web 页面设计的重要组
27、成部分,它被嵌入在HTML 文档中,由浏览器解释执行。可以使用JavaScript 设计出更有效果的Web 页面、验证Web 页面表单数据、创建cookie 等。1.6.1 网页中的JavaScript JavaScript 可 以 出 现 在HTML 文 档 的 任 何 地 方 , 但 必 须 包 含 在“ ” 和“ ” 之间。一般情况下,使用“ ”和“ ” 包含的JavaScript 代码。1.6.2 JavaScript 的变量JavaScript 变量是用来存储数据的地方。这样在需要用这个值的地方就可以用变量来代表,一个变量可以是一个数字、文本等。JavaScript 变量的命名区分大
28、小写,例如,名为computer 的变量和名为Computer 的是不一样的。而且,变量名必须以字母或下划线开头。JavaScript 是一种对变量的数据类型要求不太严格的语言,所以不必声明每一个变量的类型,但在使用变量之前先进行声明是一种好习惯。在JavaScript 中用 var 语句声明一个变量,象下面这样:var name = value 1.6.3 JavaScript 的基本语句这一小节仅介绍JavaScript 的几种常用的基本语句,它们是:ifelse 条件语句。switch 选择语句。for 循环语句。while 循环语句。1.6.4 使用简单的对话框通常会使用JavaScr
29、ipt 在网页上产生弹出对话框的效果。用JavaScript 可以创建的对话框主要有以下所示的两种。警告对话框。确认对话框。下面将通过实例代码,来了解如何使用JavaScript 创建这些对话框。使用函数alert()创建警告对话框,它的语法格式如下所示。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 39 页 - - - - - - - - - alert(“ message” ) 1.6.5 JavaScript 的基本事件所谓事件,是指用户与Web 页面交互时产生的
30、各种操作,例如单击Web 页面上的超链接或按钮时,就产生一个单击(click)事件( event)。浏览器为了响应某个事件而进行的处理过程,叫做事件处理。注意:浏览器在程序运行的大部分时间都等待事件的发生,事件能够被Web 页面中的JavaScript 捕捉到,并在事件发生时,自动调用JavaScript 的事件处理函数,完成事件处理。除此之外,浏览器自己的一些动作也可以产生事件,例如,当浏览器载入一个Web 页面时,就会发生载入(load)事件,卸载一个页面时,就会发生卸载(unload)事件。本小节将介绍几种常见的JavaScript 事件,它们是以下所示的3 种。鼠标单击事件( onCl
31、ick):当用户单击Web 页面上的超链接或者按钮时,就会触发onClick 事件。页面载入和卸载事件(onload 和 onUnload): onload 事件发生在Web 页面完全下载完成后。 onUnload 事件发生在用户离开(即关闭)当前Web 页面时。 onload 事件通常用来检测浏览器的一些信息,如浏览器类型、版本等。它们也可以用来处理用户cookie。提交事件( onSubmit):该事件发生在页面表单的“ 提交” 按钮按下并放开之后。通常使用该事件的处理过程验证表单数据的有效性。1.6.6 JavaScript 的函数函数是一个可以完成特定功能可执行的代码块,它由一条或多条
32、JavaScript 语句组成。通常将那些会反复使用,或者用来完成某种功能的代码写成函数,以便利于代码的重用。JavaScript 中函数的语法如下所示。function name(var_1,var_2,.,var_n) statement 1.6.7 JavaScript 的对象JavaScript 是一种面向对象的编程语言。一段文字、一个图片、一个表单都可以看作是一个对象,每个对象都有自己的属性、方法和事件。属性表示了该对象的某些特征,如字符串的长度、文本框里的文字等。方法可以理解成该对象可以处理的一些事情。JavaScipt 提供了很多对象,这些对象可以直接在JavaScript 里使
33、用。本小节介绍JavaScript 的一些常用的基本对象。1String 对象String 对象代表一个字符串,定义该对象的最简单办法就是直接赋值。如下代码所示。此时,变量str 就是一个String 对象,它的值是 “ Hello JavaScript ” 。var str = “ Hello JavaScript”2日期对象 Date 顾名思义,日期对象就是用来处理时间的JavaScript 对象。要定义一个日期对象,需要使用 new 运算符,如下代码所示。var some_date = new Date() 3数组对象 Array 数组对象用来存放一组数据(或者说是对象),这些数据可以是
34、不同类型的。数组中的每个对象都有一个“ 下标 ” ,用来表示它在数组中的位置。数组的下标从0 开始算起,所以,第一个对象的位置是0,第二个对象的位置是1,以此类推。 JavaScript 中定义一个数组的方法如下代码所示。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 8 页,共 39 页 - - - - - - - - - var my_arr = new Array() 4window 对象该 对 象 表 示 的 是 一 个 浏 览 器 窗 口 。 引 用 该 对 象 的 方 法
35、 或 属 性 时 , 不需 要 使 用“ window.xxx ” 这种形式,而是直接使用该对象的方法或属性。该对象常见的属性如下所示。name:当前窗口的名称。states:表示浏览器窗口下方状态栏所显示的内容。通过对改属性发赋值,可以改变浏览器状态栏显示的内容。self:指浏览器窗口本身。history :浏览器历史访问对象。location:浏览器地址对象。document :文档对象。window 对象常见的方法如下所示。open():打开一个窗口。close():关闭一个已打开的窗口。alert():弹出一个包含 “ 确定” 和“ 取消” 按钮的对话框。该方法已经在前面介绍过。5do
36、cument 对象document 对象代表浏览器窗口内的文档。该对象包含了整个HTML 文档,并且可以访问当前页面中的所有元素。该对象最常用的方法就是write ,它向当前HTML 文档写入数据。前面的内容已多次使用过该方法,这里不再重复举例。document 有一个重要属性:cookie。接下来的一小节,就向读者介绍JavaScript 中的 cookie。1.6.8 JavaScript 中的 cookie cookie 是指当用户访问某一个Web 站点时,由服务器存储在客户端计算机中的一些变量。它通常用来区别不同的访问用户。当同一台计算机请求访问某个页面时,浏览器也会将cookie 发
37、送给服务器。cookie 一般是这样的形式:cookie 名称=cookie 值。cookie 的名字一般使用字母和数字命名, cookie 的值要求是可以用URL 编码的字符。所有的cookie 都有一个失效期,过了失效期,计算机就会将这个cookie 删除。 JavaScript 中通常使用document 的 cookie 属性存储cookie。它的用法如下所示。document.cookie=cookieName=+escape(cookieValue)+;expires= expirationDateObj.toGMTString(); 1.7 开始 PHP 之旅:搭建PHP 开发环
38、境+ 从这节开始,正式进入和PHP 有关的内容。本节将介绍Apache、MySQL 和 PHP 的下载、安装及配置,分别讲述在WindowsXP 和 Linux/UNIX 下开发环境的搭建。为了便于初学者理解和掌握,本书将按Windows 操作系统下的开发环境讲述PHP 语言及其编程。1.7.1 下载 Apache、MySQL 和 PHP Apache、MySQL 和 PHP 都是开源产品,均可从其官方网站下载,并且可以免费使用。1Apache 的下载Apache 服务器的官方网站是http:/httpd.apache.org 当前,可以通过镜像地址http:/ 下载 Windows 的 Ap
39、ache 安装程序,这个镜像地址列有各个版本的Apache 安装程序,2MySQL 的下载MySQL 的官方网站是http:/ 可以通过http:/ 下载最新版本的MySQL,3PHP 的下载PHP 的官方网站是http:/ 可以通过http:/ 下载最新的PHP 版本。对于Windows 系统,可以下载安装版本或者PHP 压缩包文件,名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 9 页,共 39 页 - - - - - - - - - 1.7.2 在 Windows 下配置开发环
40、境下载完需要的软件后,本节介绍如何实现这些软件的安装和配置。1Apache 的安装2PHP 的安装3配置开发环境1.7.3 在 Linux/UNIX 下配置开发环境因为在Linux/UNIX 下配置PHP 的开发环境,对读者的技术要求稍微高一些,而且涉及到一些Linux/UNIX 方面的基础知识,如命令的使用、程序编译等,考虑到便于初学者学习和掌握,本节讲述比较简略。另外,本书主要以Windows 为平台讲述PHP 语言及其开发,因此初学者也可以跳过本节的学习。1MySQL 的安装2安装Apache 3PHP 的安装1.7.4 善其事利其器 PHP 编辑器的选择毋容置疑,开发人员需要一个功能强
41、大的IDE(Itegrated Development Enviroment,集成开发环境),就好似一个好的猎人,需要一支好的猎枪一样。使用PHP 做 Web 应用的开发,无论是从开发人员的需求上考虑,还是项目的开发效率上考虑,都需要有一个功能强大而且易用的编辑器做支持。如今有许多编辑器可供PHP 开发人员选择,它们各有优点,开发人员可以根据自己的需求、使用习惯等方面选择这些编辑器,将它们作为编写代码、开发程序的高效工具。本节将简单介绍三款常用也是比较受开发人员欢迎的PHP 编辑器,希望对初学者有所帮助。这三款编辑器是:UltraEdit、Eclipse 和 Zend Stdio。1.8 立竿
42、见影经过上几节的讲述,配置好了PHP 的开发环境。从现在开始,通过一些小例子体验一下 PHP,看看PHP 是怎样一种计算机程序语言,简单了解一下用PHP 能做哪些事。从向PHP 问好开始,向它说声“ Hello,PHP !” !1.8.1 编写第一个PHP 程序“ Hello,PHP!”打开最上手的编辑器,来编写第一个PHP 程序。这个PHP 程序非常简单,在编辑器键入以上代码后,按文件名hello.php 保存在Apache 安装目录的htdocs 目录下。然后打开浏览器,键入地址:http:/localhost/hello.php,如果一切正确无误的话,将会看到浏览器显示出“ Hello,
43、PHP!” 字样,1.8.2 使用 PHP 处理 HTML 表单这一小节介绍如何使用PHP 处理 HTML 表单数据。在这小节,将编写一个PHP 程序,试着用它处理HTML 文档提交的数据。1.9 深入了解Apache、PHP 和 MySQL 在正式学习PHP 语言之前,还需要对Apache、PHP 配置和MySQL 的有关方面做一些比较深入的说明,这样即有助于读者对前几节知识加深认识,也有助于读者学习和理解后续内容。以下几小节的内容,主要将以Windows 平台下的配置做讲解,Linux/UNIX 平台下的情形类似。1.9.1 Apache 服务器目录Apache 安装完成后,有一些目录需要
44、读者进一步了解,如:conf 目录、 htdocs 目录、 logs 目录和modules 目录。conf 目录: conf 目录下存放着一些Apache 配置文件,其中最常用到的就是httpd.conf ,这是 Apache 的核心配置文件,Apache 服务器的很多重要配置及功能实现都要在这个文件里名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 10 页,共 39 页 - - - - - - - - - 完成。这个文件也是PHP 开发人员需要经常改动的文件,本书将在下一小结讲述h
45、ttpd.conf ,设置一些重要的配置项。htdocs 目录:这个目录被Apache 默认为服务器的根目录。这就是说,在默认情况下,开发人员编写的HTML 文档和PHP 程序,只有放到这个目录下,才可以被访问或被执行。logs 目录:这个目录下存放着服务器级别的日志文件。如access.log 记录用户访问的文件及其访问日期时间、方式等。这个目录下的有些文件,有时可以用来做PHP 程序调试之用,因为服务器记录了些错误在这些日志里,开发人员可以通过这些错误,来调试PHP 程序。modules 目录:这个目录下放有Apache 执行的核心模块,当Apache 启动时,它会根据配置从这个目录里载入
46、需要的模块。一般情况下,PHP 开发人员不需要对这个目录了解更多。1.9.2 进行基本的Apache 配置Apache 服务器的很多功能、任务等重要配置,都是通过修改httpd.conf 来完成的。如设置服务器根目录、服务器超时时间、监听端口、Apache 运行模块的载入、服务器语言字符设置等。下面这段文字就是从httpd.conf 摘出的一部分。# # Timeout: The number of seconds before receives and sends time out. # Timeout 300 1.9.3 Apache 的启动与停止对于 Windows 用户来说,可以通过W
47、indows“ 服务 ” 来启动和关闭Apache 服务器。进入 Windows 控制面板里的管理工具,打开服务,找到Apache 一项,通过 “ 操作 ” 菜单项或图标按钮即可完成Apache 的启动与停止。1.9.4 PHP 的核心配置 php.ini 与 Apache 相似, PHP 也有自己的核心配置文件php.ini,PHP 分析器启动是会读取这个文件。与httpd.conf 不同, php.ini 以英文分号 “ ;” 做为注释符本小节主要讲述以下PHP 基本的配置项,这些配置项均在php.ini 中设置。doc_root:该项用来指定PHP 页面在服务器的根目录,以本书安装情况为
48、例,该项配置如下所示。doc_root = d:Apache2htdocs 注意: httpd.conf 配置项与其值之间用空格分割,而php.ini 使用“ =” 。extension_dir:该项用来指定PHP 在哪个目录下查找扩展动态库。以本书安装情况为例,该项配置如下所示。表示从PHP 安装目录下的ext 目录里查找扩展动态库。extension_dir = d:phpext 1.9.5 PHP 文件上传功能的配置关于 PHP 文件上传功能的配置,主要有以下所示的两项。upload_tmp_dir :当进行文件上传时,临时文件存放的目录,对于Linux/UNIX 用户来说,要特别注意,
49、当前PHP 用户必须拥有这个目录的写权限。upload_max_filesize:这个配置项指定了允许上传文件大小的最大值,php.ini 默认值是2M。1.9.6 PHP 中 session 的配置在 php.ini 中,有关session 的基本配置有以下所示的几项。session.save_handler:这项配置用来设置session 的存储方式,一般使用默认值files 即可,代表用文件储存。session.save_path:这项用来设置session 的保存路径,以本书为例,将session 保存在名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - -
50、- - - - - - - - 名师精心整理 - - - - - - - 第 11 页,共 39 页 - - - - - - - - - PHP 安装目录的session 目录下,如下所示。session.save_path = d:phpsession session.use_cookies:sessionid 的传递方式,默认是cookie,推荐使用。1.9.7 PHP 中和电子邮件有关的配置在这里PHP 的邮件配置目前只需了解一个sendmail_path 项即可,其他的配置项将在以后有更多讲述。sendmail_path 这项仅针对Linux/UNIX 用户来说,它用来指定sendma