最简单php连接数据库代码如下
代码如下 | 复制代码 |
<? $hostname_conn = "localhost"; ?> |
包含到页面里面的时候用require_once,不用include了。
代码如下 | 复制代码 |
<?php require_once('Connections/conn.php'); ?> |
如果连接时出现错误提示:Call to undefined function mysql_connect() 说明你的配置未成功
解决办法
1.将libmysql.dll和php5ts.dll拷贝至windows目录下的system32下!
2.修改php.ini extension_dir = "d:phpext"
2.修改windows安装目录下的php.ini 去掉;extension=php_mysql.dll前面的分号;
php4.2.0的版本是没有用过,php官网提到:php最具争议的变化是php4.2.0版本配置中register_globals的On改为了Off,对此项依赖的是如此普遍以至于很多人不知道他的存在而以为php本来就是这么工作的,下面解释这个指令如何写出不安全的代码,但是要知道这个指令没有什么不安全的地方,只有不安全的代码。
当register_globals打开以后,很多代码都可以被注入比如html表单提交的内容,再加上php在使用变量的时候无需初始化,这就使得更容易出现不安全的代码。比如我将php.ini中register_globals设置为On开始状态:
代码如下 | 复制代码 |
// 由于并没有事先把 $flag初始化为 false, |
以上代码在register_globals = On的时候,由于$flag没有初始化,在后面判断的时候通过get方式的flag = 1也可以执行include。
1.&(与) 将数值转化为二进制后 都为1则为1否则为0
$a = 10; //1010
$b = 12; //1100
echo $a & $b; //得到的是8 => 1000 2.| (或) 将数值转化为二进制后 只要有一个是1则为1 否则为0
$a = 10; //1010
$b = 12; //1100
echo $a | $b; //得到的是14 => 1110 3.^ (异或)将数值转化为二进制后 相同的为0 不同的为1
$a = 10; //1010
$b = 12; //1100
echo $a ^ $b; //得到的是6 => 0110 4.~ (取非) 将数值转化为二进制后 1转为0 0转为1
$a = 10; //1010
echo ~$a; //结果是-11 => 1111111111111111111111111111111111111111111111111111111111110101 5.<< (左移) 左移几个位置就乘以几个2
$a = 10;
echo $a << 3; //结果是80 6. >> (右移) 右移几个位置除以几个2
$a = 80;
echo $a >> 3; //结果是10
(1)文件的创建与打开;
(2)文件的操作;
(3)文件的关闭;
在PHP中,通过一系列的函数来完成文件的操作,常用的函数及其简要说明罗列如下:
//文件打开,完成文件打开(在文件不存在时可创建文件),依赖于文件中模式的不同而具有不同的操作
resource fopen ( string $filename , string $mode [, bool $use_include_path = false [, resource $context ]] )
//$filename 打开或者要创建文件的路径及文件名,为了便于移植,使用反斜杠/为佳
//$mode 是文件打开的模式,有很多模式,比较常用的r,w,a,同样为了便于移植,建议mode中增加b(二进制)
//通常读文件为 rb ,写文件为 ab,分别表示以二进制读文件及以二进制向文件追加内容
//在文件打开操作过程中出现错误请首先检查文件所在的路径的权限设置
代码如下 | 复制代码 |
//文件操作函数 //写操作相关函数 //把$string的内容写到文件指针$handle int fwrite ( resource $handle , string $string [, int $length ] ) //函数是fwrite的别名函数 fputs() //也能完成写操作,不同的是集成了fopen(),fwrite(),fclose(),使用该函数不用再打开关闭文件 int file_put_contents ( string $filename , mixed $data [, int $flags = 0 [, resource $context ]] ) //读操作相关函数 //逐行读取 string fgets ( resource $handle [, int $length ] ) //逐行读,能够过滤标记 string fgetss ( resource $handle [, int $length [, string $allowable_tags ]] ) //逐行读,能够根据定界符输出到数组 array fgetcsv ( resource $handle [, int $length = 0 [, string $delimiter = ',' [, string $enclosure = '"' [, string $escape = '\' ]]]] ) //一次性读取一个文件并将文件内容发送到标准输出,包含了文件打开与文件关闭操作 int readfile ( string $filename [, bool $use_include_path = false [, resource $context ]] ) //先要打开文件,然后将文件指针所指向的文件内容发送到标准输出 int fpassthru ( resource $handle ) //把结果发送到一个数组中 array file ( string $filename [, int $flags = 0 [, resource $context ]] ) //一次读取一个字符 string fgetc ( resource $handle ) //读取任意长度字节的内容 string fread ( resource $handle , int $length ) //文件关闭 bool fclose ( resource $handle ) //文件操作中常用的函数 //检查文件或目录是否存在 bool file_exists ( string $filename ) //获取文件大小,返回文件大小的字节数 int filesize ( string $filename ) //删除文件 bool unlink ( string $filename [, resource $context ] ) //复位文件指针位置 bool rewind ( resource $handle ) //在文件指针中定位 int fseek ( resource $handle , int $offset [, int $whence = SEEK_SET ] ) |
函数的具体详细的说明在php.net上可以查到,下面练习一下文件的操作,练习名称为『简易日记』,需求如下:
(1)每日记录的内容以年-月-日.txt保存在数据目录下;
(2)首页写日记,并显示以往的记录;
(3)显示单页记录内容;
具体代码如下
首页(index.php)
代码如下 | 复制代码 |
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>简易日记--php文件操作练习</title> <style> h1 { font-size:24px; border-bottom:1px solid #000; line-height:40px; } .active { line-height:22px; font-size:14px; background:#2cf; padding:8px; text-decoration:none; } .btn { width:100px; height:40px; } </style> </head> <body> <h1>我的日记本</h1> <p><span class="active">写日记</span></p> <form name="writediary" method="POST" action="diaryprocessed.php"> <p>日记主题</p> <input type="text" name="diarytopic" size="60" maxlength="100" /> <p>日记内容</p> <textarea name="diarycontents" rows="10" cols="53"></textarea> <p><input class="btn" type="submit" name="save" value="保存" /></p> </form> <hr> <p><span class="active">日记列表</span> </p> <hr> <?php $handler = opendir($_SERVER['DOCUMENT_ROOT'] . '/phpcodes/diarydatas/'); while (($diaryname = readdir($handler)) !== false) { if($diaryname != "." && $diaryname != ".." ) { $files[] = $diaryname; } } closedir($handler); foreach($files as $value) { echo "<a href=viewdiary.php?id=" . substr($value,0,(strlen($value)-4)) . ">$value</a>" . " | "; } ?> </body> </html> |
保存处理页(diaryprocessed.php)
代码如下 | 复制代码 |
<?php header('Content-Type:text/html; charset=utf-8'); $date = gmdate('Y-m-d', time() + 3600 * 8); $diarytopic = $_POST['diarytopic']; $diarycontents = $_POST['diarycontents']; $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $output = $diarytopic . "n" . $diarycontents . "n"; $fp = fopen($DOCUMENT_ROOT . '/phpcodes/diarydatas/' . $date . '.txt', 'ab'); flock($fp,LOCK_EX); if(!$fp) { echo "<p><strong>当前不能处理您提交的日志,请稍后再试!</strong></p>"; echo "<a href="index.htm">返回</a>"; } fwrite($fp,$output); flock($fp,LOCK_UN); fclose($fp); echo '日记提交成功!'; echo "<a href="index.htm">返回</a>"; |
查看内容页(viewdiary.php)
代码如下 | 复制代码 |
<?php |
Global,全局变量
PHP Global变量在实际应用中会发现许多问题需要我们不断的去完善处理。我们在这篇文章中就针对PHP Global变量出现的问题给出了一些具体的解决办法。
PHP hack的使用技巧详解
代码实现PHP GTK写文本查看器
网站开发中PHP语言优缺点
如何正确实现PHP function函数扩展
PHP error_log()函数处理错误日志
1:PHP Global变量的作用是定义全局变量,但是这个全局变量不是应用于整个网站,而是应用于当前页面,包括include或require的所有文件
代码如下 | 复制代码 |
$a=123; 总结: |
在函数体内定义的PHP Global变量,函数体外可以使用,在函数体外定义的global变量不能在函数体内使用,
代码如下 | 复制代码 |
$glpbal $a; $a=123; function f() { echo $a; //错误, } |
再看看下面一例
代码如下 | 复制代码 |
|
//正确,可以使用
2:PHP Global变量问题解析:
question:我在config.inc.php中定义了一些变量($a),在别的文件中函数外部 include("config.inc.php"),函数内部需要使用这些变量$a,如果没有声明的话,echo $a是打印不出来任何东西的。因此声明global $a,但是有很多函数和很多变量,总不能不断重复的这样声明吧?有什么好的解决办法,请指点。
answer1:先在config.inc.php里定义常量:define(常量名,常量值),再在其他需要用到的地方require 'config.inc.php',然后就能在这个文件里直接使用这个常量了。
answer2:我也有个办法,就是定义数组,如$x[a],$x,那样就只要声明global $x一个了。
answer3:我试了你的这个方法,不行啊。
answer4:改你的php.ini文件。
设置PHP Global变量 为 on
,下面我们看看复杂点的:
代码如下 | 复制代码 |
//A.php 文件 <?php $a = 0 ; //B.php 文件 <?php |
为什么输出的却是0?!!
在用户自定义函数中,一个局部函数范围将被引入。任何用于函数内部的变量按缺省情况将被限制在局部函数范围内(包括include 和 require 导入的文件内的变量)!
解释:A.php文件的内Test_Global是定义好的第三方函数,该函数用include导入了B.php文件内的$a的global全局变量,所以$a被限制在Test_Global局部函数范围内,所以B.php文件内的$a的作用范围都在Test_Global内,而不是作用了整个A.php内….
解决方案:
1. 冲出局部函数
代码如下 | 复制代码 |
//A.php 文件 <?php //B.php 文件 <?php |
global和$GLOBALS的区别
php中global和$GLOBALS不仅仅是写法不一样以为,2者的区别还是很大的,在实际应用中需要注意!
先看下面的例子:
PHP代码
代码如下 | 复制代码 |
<?php // 例子1 function test_global() { global $var1, $var2; $var2 =& $var1; } function test_globals() { $GLOBALS['var3'] =& $GLOBALS['var1']; } $var1 = 5; $var2 = $var3 = 0; test_global(); print $var2 .”n”; test_globals(); print $var3 .”n”; ?> |
执行结果为:
0
5
怎么会这样呢?不应该是2个5吗?怎么会出现1个0和1个5呢?
恩,我们保留以上问题,深入分析$GLOBALS和global的原理!
我们都知道变量其实是相应物理内存在代码中的”代号”而已
引用php手册的$GLOBALS的解释:
Global 变量:$GLOBALS,注意: $GLOBALS 在 PHP 3.0.0 及以后版本中适用。
由所有已定义全局变量组成的数组。变量名就是该数组的索引。这是一个“superglobal”,或者可以描述为自动全局变量。
也就是说上面代码中的$var1和$GLOBALS['var1']是指的同一变量,而不是2个不同的变量!
下面来分析global到底做了什么?
引用php手册的global的解释:
如果在一个函数内部给一个声明为 global 的变量赋于一个引用,该引用只在函数内部可见。可以通过使用 $GLOBALS 数组避免这一点。
我们都知道php中的函数所产生的变量都是函数的私有变量,那么global关键字产生的变量也肯定逃不出这个规则,为什么这么说呢,看下面的代码:
PHP代码
代码如下 | 复制代码 |
<?php // 例子2 function test() { global $a; unset($a); } $a = 1; test(); print $a; ?> |
执行结果为:
1
为什么会输出1呢?不是已经把$a给unset了吗?unset失灵了?php的bug?
都不是,其实unset起作用了,是把test函数中的$a给unset掉了,可以在函数test()中加入
print $a;
来测试!
接着回到上面的例子1,看test_global中的这一代码“$var2 =& $var1;”,上面是一个引用赋值运算,也就是$var2将指向var1所指向的物理内存地址,所以例子1执行过test_global函数以后,变量的变化只在函数的局部产生效应,在函数外部$var2的指向物理内存地址并没有变化,还是它自己.
此时,就能理解为什么例子1执行完以后,$var2是0,而$var3是5了!
所以我们得出一个结论,在函数中global和$GLOBALS[]的区别在于:
global在函数产生一个指向函数外部变量的别名变量,而不是真正的函数外部变量,一但改变了别名变量的指向地址,就会发生一些意料不到情况,例如例子 1.
$GLOBALS[]确确实实调用是外部的变量,函数内外会始终保持一致
可以对照 下面两个列子再加深下印象:
global:
代码如下 | 复制代码 |
<?php function myfunction(){ global $bar; unset($bar); } $bar=”someting”; myfunction(); echo $bar; ?> 输出:someting $GLOBALS[]: <?php function foo() { unset($GLOBALS['bar']); } $bar = “something”; foo(); echo $bar; ?> |
输出:空
当按照上面的思路理解后,碰到下面的情况是不是又有些晕呢?
代码如下 | 复制代码 |
<?php $a = 1; $b = 2; function Sum() { global $a, $b; $b = $a + $b; } Sum(); echo $b; ?> |
输出将是 “3″。在函数中申明 了全局变量 $a 和 $b,任何变量的所有引用变量都会指向到全局变量。
怎么不是2呢,在函数外部不是不影响吗,请注意$b在函数中并没有通过引用修改,而是修改的$b指向物理内存的值,因此外部输入为3。
php中global和$GLOBALS不仅仅是写法不一样以为,2者的区别还是很大的,在实际应用中需要注意!
先看下面的例子:
PHP代码
代码如下 | 复制代码 |
<?php // 例子1 function test_global() { global $var1, $var2; $var2 =& $var1; } function test_globals() { $GLOBALS['var3'] =& $GLOBALS['var1']; } $var1 = 5; $var2 = $var3 = 0; test_global(); print $var2 .”n”; test_globals(); print $var3 .”n”; ?>
|
执行结果为:
0
5
怎么会这样呢?不应该是2个5吗?怎么会出现1个0和1个5呢?
恩,我们保留以上问题,深入分析$GLOBALS和global的原理!
我们都知道变量其实是相应物理内存在代码中的“代号“而已
引用php手册的$GLOBALS的解释:
Global 变量:$GLOBALS,注意: $GLOBALS 在 PHP 3.0.0 及以后版本中适用。
由所有已定义全局变量组成的数组。变量名就是该数组的索引。这是一个“superglobal”,或者可以描述为自动全局变量。
也就是说上面代码中的$var1和$GLOBALS['var1']是指的同一变量,而不是2个不同的变量!
下面来分析global到底做了什么?
引用php手册的global的解释:
如果在一个函数内部给一个声明为 global 的变量赋于一个引用,该引用只在函数内部可见。可以通过使用 $GLOBALS 数组避免这一点。
我们都知道php中的函数所产生的变量都是函数的私有变量,那么global关键字产生的变量也肯定逃不出这个规则,为什么这么说呢,看下面的代码:
PHP代码
代码如下 | 复制代码 |
<?php // 例子2 function test() { global $a; unset($a); }
$a = 1; test(); print $a; ?>
|
执行结果为:
1
为什么会输出1呢?不是已经把$a给unset了吗?unset失灵了?php的bug?
都不是,其实unset起作用了,是把test函数中的$a给unset掉了,可以在函数test()中加入
print $a;
来测试!
接着回到上面的例子1,看test_global中的这一代码“$var2 =& $var1;”,上面是一个引用赋值运算,也就是$var2将指向var1所指向的物理内存地址,所以例子1执行过test_global函数以后,变量的变化只在函数的局部产生效应,在函数外部$var2的指向物理内存地址并没有变化,还是它自己.
此时,就能理解为什么例子1执行完以后,$var2是0,而$var3是5了!
所以我们得出一个结论,在函数中global和$GLOBALS[]的区别在于:
global在函数产生一个指向函数外部变量的别名变量,而不是真正的函数外部变量,一但改变了别名变量的指向地址,就会发生一些意料不到情况,例如例子 1.
$GLOBALS[]确确实实调用是外部的变量,函数内外会始终保持一致
可以对照 下面两个列子再加深下印象:
global:
代码如下 | 复制代码 |
<?php function myfunction(){ global $bar; unset($bar); } $bar=”someting”; myfunction(); echo $bar; ?> |
输出:someting
代码如下 | 复制代码 |
$GLOBALS[]: <?php function foo() { unset($GLOBALS['bar']); } $bar = “something”; foo(); echo $bar; ?> |
输出:空
当按照上面的思路理解后,碰到下面的情况是不是又有些晕呢?
代码如下 | 复制代码 |
<?php $a = 1; $b = 2; function Sum() { global $a, $b; $b = $a + $b; } Sum(); echo $b; ?> |
输出将是 “3″。在函数中申明 了全局变量 $a 和 $b,任何变量的所有引用变量都会指向到全局变量。
怎么不是2呢,在函数外部不是不影响吗,请注意$b在函数中并没有通过引用修改,而是修改的$b指向物理内存的值,因此外部输入为3。