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 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL 및 Phpmyadmin은 강력한 데이터베이스 관리 도구입니다. 1) MySQL은 데이터베이스 및 테이블을 작성하고 DML 및 SQL 쿼리를 실행하는 데 사용됩니다. 2) PHPMYADMIN은 데이터베이스 관리, 테이블 구조 관리, 데이터 운영 및 사용자 권한 관리에 직관적 인 인터페이스를 제공합니다.

IIS 및 PHP는 호환 가능하며 FastCGI를 통해 구현됩니다. 1. IIS 구성 파일을 통해 .php 파일 요청을 FastCGI 모듈로 전달합니다. 2. FASTCGI 모듈은 PHP 프로세스를 시작하여 요청을 처리하여 성능과 안정성을 향상시킵니다. 3. 실제 응용 프로그램에서는 구성 세부 사항, 오류 디버깅 및 성능 최적화에주의를 기울여야합니다.

MySQL에서 외국 키의 기능은 테이블 간의 관계를 설정하고 데이터의 일관성과 무결성을 보장하는 것입니다. 외국 키는 참조 무결성 검사 및 계단식 작업을 통해 데이터의 효과를 유지합니다. 성능 최적화에주의를 기울이고 사용할 때 일반적인 오류를 피하십시오.

SQL은 관계형 데이터베이스를 관리하는 표준 언어이며 MySQL은 SQL을 사용하는 데이터베이스 관리 시스템입니다. SQL은 CRUD 작업을 포함한 데이터베이스와 상호 작용하는 방법을 정의하는 반면 MySQL은 SQL 표준을 구현하고 저장 프로 시저 및 트리거와 같은 추가 기능을 제공합니다.

MySQL과 Mariadb의 주요 차이점은 성능, 기능 및 라이센스입니다. 1. MySQL은 Oracle에 의해 개발되었으며 Mariadb는 포크입니다. 2. MariaDB는 높은 하중 환경에서 더 나은 성능을 발휘할 수 있습니다. 3. Mariadb는 더 많은 스토리지 엔진과 기능을 제공합니다. 4.MySQL은 듀얼 라이센스를 채택하고 MariaDB는 완전히 오픈 소스입니다. 선택할 때 기존 인프라, 성능 요구 사항, 기능 요구 사항 및 라이센스 비용을 고려해야합니다.

프론트 엔드 개발에서 JSON의 기능과 정규 표현식을 안전하게 처리하면 JavaScript가 종종 필요합니다 ...

Session_Start ()로 여러 통화를하면 경고 메시지와 가능한 데이터 덮어 쓰기가 발생합니다. 1) PHP는 세션이 시작되었다는 경고를 발행합니다. 2) 세션 데이터의 예상치 못한 덮어 쓰기를 유발할 수 있습니다. 3) Session_status ()를 사용하여 반복 통화를 피하기 위해 세션 상태를 확인하십시오.

MySQL은 빠른 개발 및 중소형 응용 프로그램에 적합한 반면 Oracle은 대기업 및 고 가용성 요구에 적합합니다. 1) MySQL은 오픈 소스이며 사용하기 쉬우 며 웹 응용 프로그램 및 중소 기업에 적합합니다. 2) Oracle은 강력하고 대기업 및 정부 기관에 적합합니다. 3) MySQL은 다양한 스토리지 엔진을 지원하며 Oracle은 풍부한 엔터프라이즈 수준의 기능을 제공합니다.
