php3:跨平台的服务器端嵌入式脚本语言
服务器端脚本技术是一种非常有用的东西,将它和客户端脚本技术联合起来应用可以 制作出功能极其强大的页面。好象很久以前有一阵子哪个版(似乎是WWW版)上讨论ASP 到了热火朝天的地步,还有人提议开个ASP版,那就是一种服务器端脚本技术。 通常用的服务器端脚本技术是CGI,NSAPI/ISAPI/FastCGI等等都是对它的改善和扩展。 至于用什么语言来实现CGI技术,没有任何规定,大家一般使用Perl,因为它的字符 功能比较强大。到了需要速度的场合,就用C来实现。
用Perl/C等写的CGI脚本是一种“非嵌入式”的服务器端脚本,因为它是一个单独的程序, 而不是嵌在HTML文档中再通过另一个程序解释替换。
例如,下面的Perl程序:
print "Content-type:text/html\n\n";
print
HeadofHTML
print "
print "";
它中间虽然也有一段似乎是HTML文档,但那是HTML文档嵌入了Perl程序,而不是反过来。 IDC/HTX,ASP等是嵌入式的服务器端脚本,下面的例子是一个mSQL Lite脚本:
echo "Hello!";
>
PHP3.0有几个平台下的编译好的版本,也有源码版本。 PHP3.0内部带了对几种常用数据库的支持,包括:Sybase,Oracle,mSQL,mySQL,PostgresQL, ODBC,dBase等。如果编译它的源码时选择对这些数据库中某几个的支持,那么必须事先 有它们的客户库。
在Unix下编译的方法是:先解压,然后运行"./configure [选项]"(选项见README文件), 再运行"make"和"make install". 选项中比较重要的有:"--enable-msql=msql库路径"等数据库选项和"--enable-apache= apache源程序路径"等。 如果选择了--enable-apache,那么编译出的将是一个库文件,make install将把这个库 安装到apache源程序中,然后再编译apache,可以得到支持php的apache服务器。否则, 生成的将是一个解释程序。
具体请看README文件。 在Windows下,有一个安装程序,界面不太好,而且有几个文件会报告找不到,跳过就是 了。装上后要把php3目录设成网络可执行的。Readme中说要手工修改Registry,但似乎用 不着。 文档不是太好,因为3.0的文档还没写全,而2.0的文档又有些过时了。
安装上之后,系统应该支持对.php3和.phps文件的HTTP读取了。(在Unix下需要修改服务 器的srm.conf文件,具体看README).
如果安装时连进了apache服务器,那么速度应该是最快的。如果作为CGI程序执行,速度 也还将就。如果系统支持FastCGI,那么解释程序也可以作为FastCGI程序运行。Windows下 支持ISAPI的解释程序还没有出来。
现在我们来看看第一个php3脚本,照例是Hello,world.
echo "Hello, world!";
?>
把它放在任何一个能通过HTTP访问到的目录,取名hello.php3,再用浏览器连接 该文件,就可以看见其效果了(不用我写了吧.)
如果把它改名成hello.phps,再用Netscape或Explorer连接,可以看见加了颜色 的源码,因为解释器在遇到.phps文件时会对它进行语法加亮的处理,在里面加上很多颜色 控制符再送出. 并不需要手工指定解释器所在位置,因为如果在Apache服务器下,srm.conf里面可以 指定,在Microsoft IIS 或 PWS下,Registry里面会指定.
从上面的例子应该很容易看出php3文件的写法.用和?>括起来的部分就是php3 程序段,解释器对其余部分不作处理,将这些程序段执行后以其输出代替(echo语句输出一 个无格式字符串,printf语句类似于C的同名函数.) 同样可以看出,php3程序虽然是文本,但客户端只能看见解释后的结果(除非你提供同名的phps文件),因此对客户端是保密的,这也是绝大部分服务器端脚本的特点.
PHP和一般的解释性语言一样,不需要事先定义变量.如果你试着使用一个 没有赋过值的变量,那么返回的值是空字符串.对一个变量赋值则也就同时分配了 这个变量的内存. PHP的变量名前面必须有一个$号,这也是很多脚本语言的惯例了.
例如:
$a=1;
$b=1.0;
$c="Hello!";
都是合法的PHP语句.
PHP中的数组是这样定义的:
$a[1]="a";
$a[2]="b";
它会自动扩展,不必预先设定上限.
其实数组下标也可以是一个字符串,例如:
$a["a"]=1;
$a["b"]="Hello!";
这时它实际上是一个哈希表,就象Tcl中的所谓数组一样.
PHP中有一种类似于指针的用法,例如:
$a = "b";
$$a = "c";
则后一句产生了一个$b变量并给它赋值"c".
PHP变量之间的运算符和C的类似,例如也有:
+,-,*,/,%,^,&,|,&&,||,!,+=,-=,++,--等
PHP3.0定义了一个字符串相加运算符".",和Perl的一样.
PHP的变量类型可以自动转换,如果需要强制转换,做法和C的一样.它有Integer,
Double,String三种简单类型.
要遍历一个哈希表,可以这样:
$i["a"] = 0;
$i["c"] = 1;
reset($i);
for ($j=1;$j $k = key($i);
echo "$k, $i[$k]";
echo "
";
next($i);
}
PHP中的控制流语句与C几乎完全一样,也有if...else,while,for,switch,break,
exit.
PHP3.0中的函数如下例:
function test($a, $b) {
return $a*2+$b;
}
和C差不多.
函数可以递归调用.
PHP3.0的变量作用域规定也类似于C,即缺省认为主程序中的变量是全局 变量,而函数中的变量都是局部变量,即使有同名的全局变量也不使用. 如果在函数中要使用全局变量,则必须在函数头上用global语句声明,
例如:
function ...{
global $a, $b;
...
}
如果函数头上用static语句声明了一些变量,那么这些变量是静态的,其 含义与C语言中的相同. PHP中提供include语句,类似于C的#include. include语句包含的可以是任意文件,它的内容将出现在最后输出的页面 上.如果该文件中有...?>括起的部分,则该部分将被PHP解释器解释执行,否则 该文件的内容原封不动地送出. 它包含的文件名可以是绝对或相对路径,也可以是一个http或ftp的URL, 在后一种情况下,解释器自动取来该URL内容.用这种方法甚至可以触发一个别的 机器上的CGI程序. readfile语句类似于include,但它不执行文件中的PHP程序,只把文件原 封不动地送出.这时被包含的文件中的...?>将被浏览器理解为注释.
PHP3.0中的字符串操作功能是比较多的,重要的有以下这些:
(1)echo,print,printf,sprintf
前两个函数是输出字符串.字符串中如果有变量名则被替换成其值. 后两个函数类似于C的同名函数.
(2)strchr,strlen,strtok,strrchr,strrev,strstr,strtolower,
strtoupper,substr,ucfirst
这些是常用的字符串操作函数,有些和C中的同名函数意义完全一致. strrev是把一个字符串翻转. strtolower和strtoupper的意思应该不用解释了. ucfirst是把字符串的第一个字符变成大写. substr是返回字符串的一个子串,用法是:substr(字符串,头,长度).头位置是从0算起的.如果是负数,则是从尾部向前数的意思.
(3)Chr,Ord
类似于C的同名函数.
(4)explode,implode,join
这些是和数组有关的函数. explode(字符串,分割符)返回一个将字符串在分割符处分开所产生的数组. implode(数组,分割符)返回一个将数组各元素之间插上分割符而成的字符串. join与implode意义相同.
(5)Chop
去掉字符串尾部的空白.
(6)htmlspecialchars
将字符串中的HTML特殊字符换成它们的名字,例如"变成" (7)nl2br
在字符串中的每一个回车前面加上"
".
(8)AddSlashes,StripSlashes
分别给字符串中需要加上"\"才能用于数据库查询的字符加上和去掉"\".
(9)parse_str
将"name1=value1&name2=value2&..."类型的字符串分析成一些变量.
例如:
parse_str("a=1&b=2");
生成$a与$b两个变量,值分别为1,2. 如果有两对名字/值的名字部分相同,则后一个的值覆盖前一个的. 如果这两对的名字尾部都有"[]",例如"a[]=1&a[]=2",则生成数组$a,两个元素分别为1,2.
PHP与其它跨平台语言(也许Java不在其列. :))类似,也有正规表达式功能.PHP3.0的正规表达式功能当然远远比不上Perl,但还是足够用的,主要函数有这么些:
(1)ereg,eregi
这是正规表达式匹配函数,前者是大小写有关匹配,后者则是无关的.
用法:
ereg(正规表达式,字符串,[匹配部分数组名]);PHP3.0中的正规表达式大体类似于grep中用的.
(2)ereg_replace,eregi_replace
这些是替换函数.
用法:
ereg_replace(正规表达式,替换串,原字符串); 字符串处理函数中有一个strtr,是"翻译"函数,类似于Perl中的tr/.../.../,
用法:
strtr(字符串,"从","到");
例如:
strtr("aaabb","ab","cd")返回"cccdd".
(3)split
与explode函数有些类似,但这次可以在匹配某正规表达式的地方分割字符串.
用法:
split(正规表达式,字符串,[取出前多少项]);
标 题: php3:跨平台的服务器端嵌入式脚本语言(8)
PHP3.0中的文件操作函数大体和C的类似,但有一些扩充,

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

MySQL 数据库中,用户和数据库的关系通过权限和表定义。用户拥有用户名和密码,用于访问数据库。权限通过 GRANT 命令授予,而表由 CREATE TABLE 命令创建。要建立用户和数据库之间的关系,需创建数据库、创建用户,然后授予权限。

数据集成简化:AmazonRDSMySQL与Redshift的零ETL集成高效的数据集成是数据驱动型组织的核心。传统的ETL(提取、转换、加载)流程复杂且耗时,尤其是在将数据库(例如AmazonRDSMySQL)与数据仓库(例如Redshift)集成时。然而,AWS提供的零ETL集成方案彻底改变了这一现状,为从RDSMySQL到Redshift的数据迁移提供了简化、近乎实时的解决方案。本文将深入探讨RDSMySQL零ETL与Redshift集成,阐述其工作原理以及为数据工程师和开发者带来的优势。

MySQL数据库性能优化指南在资源密集型应用中,MySQL数据库扮演着至关重要的角色,负责管理海量事务。然而,随着应用规模的扩大,数据库性能瓶颈往往成为制约因素。本文将探讨一系列行之有效的MySQL性能优化策略,确保您的应用在高负载下依然保持高效响应。我们将结合实际案例,深入讲解索引、查询优化、数据库设计以及缓存等关键技术。1.数据库架构设计优化合理的数据库架构是MySQL性能优化的基石。以下是一些核心原则:选择合适的数据类型选择最小的、符合需求的数据类型,既能节省存储空间,又能提升数据处理速度

1.使用正确的索引索引通过减少扫描的数据量来加速数据检索select*fromemployeeswherelast_name='smith';如果多次查询表的某一列,则为该列创建索引如果您或您的应用根据条件需要来自多个列的数据,则创建复合索引2.避免选择*仅选择那些需要的列,如果您选择所有不需要的列,这只会消耗更多的服务器内存并导致服务器在高负载或频率时间下变慢例如,您的表包含诸如created_at和updated_at以及时间戳之类的列,然后避免选择*,因为它们在正常情况下不需要低效查询se

通过以下命令查看 MySQL 数据库:连接到服务器:mysql -u 用户名 -p 密码运行 SHOW DATABASES; 命令获取所有现有数据库选择数据库:USE 数据库名;查看表:SHOW TABLES;查看表结构:DESCRIBE 表名;查看数据:SELECT * FROM 表名;

数据库ACID属性详解ACID属性是确保数据库事务可靠性和一致性的一组规则。它们规定了数据库系统处理事务的方式,即使在系统崩溃、电源中断或多用户并发访问的情况下,也能保证数据的完整性和准确性。ACID属性概述原子性(Atomicity):事务被视为一个不可分割的单元。任何部分失败,整个事务回滚,数据库不保留任何更改。例如,银行转账,如果从一个账户扣款但未向另一个账户加款,则整个操作撤销。begintransaction;updateaccountssetbalance=balance-100wh

要填写 MySQL 用户名和密码,请:1. 确定用户名和密码;2. 连接到数据库;3. 使用用户名和密码执行查询和命令。

MySQL 中的复制粘贴包含以下步骤:选择数据,使用 Ctrl C(Windows)或 Cmd C(Mac)复制;在目标位置右键单击,选择“粘贴”或使用 Ctrl V(Windows)或 Cmd V(Mac);复制的数据将插入到目标位置,或替换现有数据(取决于目标位置是否已存在数据)。
