Web程序工作原理详解


Posted in PHP onDecember 25, 2014

1.Web程序工作原理

(1)Web一词的含义

Network:【计算机】电脑网络,网

Web:【计算机】万维网(WorldWideWeb),互联网(Internet)

Web程序,顾名思义,即工作在Web上的程序。

(2)单机程序工作原理

单机,即不连接到其他计算机的计算机,不在网络中。例如:两单机A、B,只在A上安装有程序X,若要在B上得到X的运行结果,则必须在B上安装一遍X,然后运行。若B类的计算机比较多,则需要逐一安装运行。它们之间不能直接进行通信和协作。如图1所示。

Web程序工作原理详解

(3)客户机/服务器程序工作原理

将单机连成网络,如将A与B连成网络,则可以使它们之间提供服务,如A向B提供服务。常见的服务是文件共享,FTP文件下载等。我们把提供(响应)服务的计算机称作服务器(Server),接受(请求)服务的计算机称作客户机(Client),也叫工作站(Workstations)。客户机/服务器程序的工作原理如图2所示。

Web程序工作原理详解

服务器和客户机的角色可以转换。一台计算机,可以对自己提供服务,这时它既是服务器,也是客户机。如,计算机A把自己的文件夹a共享,然后在网络上找到A,则可以下载a,即自己对自己提供了服务,自己请求并响应了服务。

客户机/服务器的这种计算机间的协作方式,称为C/S方式,或C/S架构。

C/S程序分为两部分:服务器端和客户机端,分别称为服务器端程序(或服务程序)和客户端程序(或客户程序)。对于客户端程序,对每一个客户机,也都要分别安装,这一点与单机程序的分发相同,也很麻烦。但是,安装好了客户端程序后,就可以通过通信线路与服务器交互,或通过服务器,与其他客户机通信。典型的例子是大家常用的聊天程序QQ,如图3所示。

Web程序工作原理详解

(4)浏览器/服务器程序工作原理

若通过客户机中的浏览器(Browser),向服务器发出请求,接收其响应的结果,那么,这时,我们称这样的协作方式为B/S方式,或B/S架构,其工作原理如图4所示:

Web程序工作原理详解

这时,客户端程序就是浏览器,而浏览器的安装是随着操作系统的安装完成的,不需要用户额外安装。对他们而言,使用B/S程序(如上网看新闻,收发电子邮件),可不需要安装专门的客户端程序,直接在浏览器中操作即可。这使得B/S程序的维护十分方便,因为不用管客户端程序,只要维护好服务器端程序即可。

(5)C/S、B/S服务器的组成

服务器,是担负服务任务的机器。这些服务任务由一般专门的软件来完成。一般地,把具有某种服务功能的服务器软件及其所在的机器,都统称为XX服务器(XX表示某种具体服务)。这些软件可以集中于一台机器中(如图5),这样的机器可以称为集中式服务器;也可以单独存在于某台机器中(如图6),这样的机器可以称为独立式服务器,多个独立式服务器可组成服务器群或矩阵。

Web程序工作原理详解

Web程序工作原理详解

按照服务任务,常见的几种服务器软件如表 1 所示。

Web程序工作原理详解

服务器端脚本:用服务器端编程语言编写的程序。

服务器端编程语言:只运行在服务器端,被服务器所解释和执行的编程语言,如PHP语言。

(6)B/S程序工作的具体过程(如图7)

Web程序工作原理详解

(7)PHP程序工作的具体过程

具体过程是Apache、PHP、浏览器之间的协作过程:

用户通过浏览器向服务器请求PHP文件(如在地址栏输入:http://localhost/index.php),Apache在服务器上用户文档发布目录下查找浏览器所请求的PHP文件,若找不到,则向浏览器返回错误信息,否则,将其提交给PHP解释器解释执行,PHP解释器对该PHP文件进行语法分析,若发现语法错误,则经Apache返回错误信息(以浏览器能识别的代码表示)到浏览器,否则执行该PHP程序(可能包含对数据库MySQL的操作),将PHP程序执行结果(以浏览器能识别的代码表示)经Apache返回到浏览器,浏览器对返回结果进行解释、执行,执行的结果显示在浏览器窗口中。

如果浏览器所请求的文件不是PHP文件,而是HTML文件或JavaScript文件。该过程将简化:Apache在服务器上用户文档发布目录下查找浏览器所请求的HTML文件或JavaScript文件,若找不到,则向浏览器返回错误信息,否则,将其返回给浏览器,浏览器对返回的结果进行解释、执行,执行的结果显示在浏览器窗口中。

2.浏览器工作过程

(1)Web客户端工作过程

任何应用系统都必须有一个提供用户操作的界面,即用户界面。浏览器的工作,从整个B/S程序来看,是用户与B/S程序打交道的一个界面(接口)。它的任务是:

A.收集用户输入的数据

B.将用户数据发送到服务器

C.接收服务器返回的响应

D.解释,执行这些代码

可见,浏览器扮演的是服务器在用户那里的一个代理(Agent)的角色。这个代理,具有收集消息,请求响应和解释服务器发回的指示的作用。

(2)Web客户端代码

无论是组织用于收集用户数据的界面,还是解释来自服务器的指示形成结果界面,都是用Web客户端代码实现的。常用的Web客户端代码有HTML语言、JavaScript语言、CSS、XML等语言。

3.HTML工作原理

(1)HTML简介

HTML:HyperTextMarkupLanguage,超文本标记语言。

20世纪80年代末,在欧洲粒子物理实验室(CERN:theEuropeanLabloratoryforParticlePhysics)工作的TimBerners-Lee(WWW之父)通过研究发现:人们视觉处理是以页为基础的。于是他得出一个结论:电子资料应以页的方式呈现。以此为出发点,他使用超文本为中心的管理方式来组织网络上的资料,并提出了建立存取与浏览网页的方法:建立了超文本标记语言;设计了超文本传输协议(HTTP:HypertextTransportProtocol),用于获取超链接文件;使用统一资源定位器(URL:UniformResourceLocator)来定位网络文件、站点或服务器。

(2)HTML工作原理

HTML本质上不是程序语言,而是一种标记语言。所谓标记,在有的书上也叫标签,从面向对象的角度而言,就是对浏览器对象的标识的意思。它用来控制文字、图片等浏览器的子对象在浏览器中的表现,以及如何建立文件之间链接的标记。这些标记均放在文本格式的文件中。而程序与之最大的不同,就是可用来控制操作系统或应用程序执行并完成某项作业。超文本标记语言的文档应该尽量做到,从形式上看,无论在任何操作系统的任何浏览器上打开都具有相同的效果。

(3)HTML的基本结构

A.版本声明,即序(Prologue)

B.头部(Head)

C.主体(Body)

PHP 相关文章推荐
PHP一些有意思的小区别
Dec 06 PHP
PHP之数组学习
May 29 PHP
执行、获取远程代码返回:file_get_contents 超时处理的问题详解
Jun 25 PHP
php后台如何避免用户直接进入方法实例
Oct 15 PHP
php+MySQL判断update语句是否执行成功的方法
Aug 28 PHP
PHP @ at 记号的作用示例介绍
Oct 10 PHP
php使用PDO操作MySQL数据库实例
Dec 30 PHP
在WordPress中使用PHP脚本来判断访客来自什么国家
Dec 10 PHP
yum命令安装php7和相关扩展
Jul 04 PHP
PHP实现批量检测网站是否能够正常打开的方法
Aug 23 PHP
Laravel源码解析之路由的使用和示例详解
Sep 27 PHP
php微信公众号开发之校园图书馆
Oct 20 PHP
php更新mysql后获取改变行数的方法
Dec 25 #PHP
php常见的魔术方法详解
Dec 25 #PHP
php利用scws实现mysql全文搜索功能的方法
Dec 25 #PHP
php中heredoc与nowdoc介绍
Dec 25 #PHP
php中实现xml与mysql数据相互转换的方法
Dec 25 #PHP
推荐5款跨平台的PHP编辑器
Dec 25 #PHP
主流PHP框架的优缺点对比分析
Dec 25 #PHP
You might like
php源码加密 仿微盾PHP加密专家(PHPCodeLock)
2010/05/06 PHP
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装(win+linux)
2012/05/05 PHP
Thinkphp模板标签if和eq的区别和比较实例分析
2015/07/01 PHP
PHP设计模式之策略模式原理与用法实例分析
2019/04/04 PHP
jquery 选择器部分整理
2009/10/28 Javascript
JS维吉尼亚密码算法实现代码
2010/11/09 Javascript
JS 修改URL参数(实现代码)
2013/07/08 Javascript
JS获取各种浏览器窗口大小的方法
2014/01/14 Javascript
jquery修改网页背景颜色通过css方法实现
2014/06/06 Javascript
JavaScript中的索引数组、关联数组和静态数组、动态数组讲解
2014/11/08 Javascript
用Vue-cli搭建的项目中引入css报错的原因分析
2017/07/20 Javascript
详解AngularJS之$window窗口对象
2018/01/17 Javascript
Bootstrap 中data-[*] 属性的整理
2018/03/13 Javascript
Jquery获取radio选中值实例总结
2019/01/17 jQuery
微信小程序去除左上角返回键的实现方法
2020/03/06 Javascript
js通过canvas生成图片缩略图
2020/10/02 Javascript
解决Vue项目中tff报错的问题
2020/10/21 Javascript
js实现简易ATM功能
2020/10/27 Javascript
python字符串连接的N种方式总结
2014/09/17 Python
Python获取单个程序CPU使用情况趋势图
2015/03/10 Python
Python Django框架实现应用添加logging日志操作示例
2019/05/17 Python
解决webdriver.Chrome()报错:Message:'chromedriver' executable needs to be in Path
2019/06/12 Python
django一对多模型以及如何在前端实现详解
2019/07/24 Python
HTML5自定义data-* data(obj)属性和jquery的data()方法的使用
2012/12/13 HTML / CSS
蔻驰法国官网:COACH法国
2018/11/14 全球购物
英国设计师珠宝网站:Joshua James Jewellery
2020/03/01 全球购物
经理秘书岗位职责
2013/11/14 职场文书
初中生期末考试的自我评价
2013/12/17 职场文书
《都江堰》教学反思
2014/02/07 职场文书
检查接待方案
2014/02/27 职场文书
绍兴鲁迅故居导游词
2015/02/09 职场文书
解决redis sentinel 频繁主备切换的问题
2021/04/12 Redis
Python爬取英雄联盟MSI直播间弹幕并生成词云图
2021/06/01 Python
Vscode中SSH插件如何远程连接Linux
2022/05/02 Servers
Java多线程并发FutureTask使用详解
2022/06/28 Java/Android
Win10本地连接不见了怎么恢复? win10系统电脑本地连接不见了解决方法
2023/01/09 数码科技