天天看點

[分享]Php部分常見問題總結

[分享]Php部分常見問題總結

目錄:

1:為什麼我得不到變量

2:調試你的程式

3:如何使用session

4:為什麼我向另一網頁傳送變量時,隻得到前半部分,以空格開頭的則全部丢失

5:如何截取指定長度漢字而不會出現以"?>"結尾,超出部分以"..."代替

6:規範你的SQL語句

7:如何使Html/PHP格式的字元串不被解釋,而是照原樣顯示

8:怎麼在函數裡取得函數外的變量值

9:我怎麼知道系統預設支援什麼函數

10:如何比較兩個日期相差幾天

11:為什麼我更新PHP後,原來的程式出現滿屏的 Notice: Undefined variable:

12:我想在每個檔案最前,最後面都加上一檔案.但一個一個添加很麻煩

13:如何利用PHP上傳檔案

14:如何配置GD庫

15:什麼是UBB代碼

16:我想修改MySQL的使用者,密碼

17:我想知道他是通過哪個網站連接配接到本頁

18:資料放入資料庫和取出來顯示在頁面需要注意什麼

19:如何讀取目前位址欄資訊

20:我點選後退按鈕,為什麼之前填寫的東西不見

21:怎麼在圖檔裡顯示IP位址

22:如何取得使用者的真實IP

23:如何從資料庫讀取三天内的所有記錄

24:如何遠端連結Mysql資料庫

25:正則到底怎麼用

26:用Apache後,首頁出現亂碼

27:為什麼單引号,雙引号在接受頁面變成(\'\")

28:怎麼讓程式一直運作下去,而不是超過30秒就停止

29:計算目前線上人數

30:什麼是模闆,怎麼用

31:怎麼用php解釋字元

我在一網頁向另一網頁POST資料name,為什麼輸出$name時卻得不到任何值?

在PHP4.2以後的版本中register_global預設為off

若想取得從另一頁面送出的變量:

方法一:在PHP.ini中找到register_global,并把它設定為on.

方法二:在接收網頁最前面放上這個extract($_POST);extract($_GET);(注意extract($_SESSION)前必須要有Session_Start()).

方法三:一個一個讀取變量$a=$_GET[\"a\"];$b=$_POST[\"b\"]等,這種方法雖然麻煩,但比較安全.

在運作時必須知道某個變量為何值。我是這樣做的,建立一檔案debug.php,其内容如下:

PHP代碼:--------------------------------------------------------------------------------

<?PHP

Ob_Start();

Session_Start();

Echo \"<pre>\";

Echo \"本頁得到的_GET變量有:\";

Print_R($_GET);

Echo \"本頁得到的_POST變量有:\";

Print_R($_POST);

Echo \"本頁得到的_COOKIE變量有:\";

Print_R($_COOKIE);

Echo \"本頁得到的_SESSION變量有:\";

Print_R($_SESSION);

Echo \"</pre>\";

?>

--------------------------------------------------------------------------------

然後在php.ini中設定:include_path = \"c:/php\",并将debug.php放在此檔案夾,

以後就可以在每個網頁裡包含此檔案,檢視得到的變量名和值.

凡是與session有關的,之前必須調用函數session_start();

為session付值很簡單,如:

<?php

Session_start();

$Name = \"這是一個Session例子\";

Session_Register(\"Name\");//注意,不要寫成:Session_Register(\"$Name\");

Echo $_SESSION[\"Name\"];

//之後$_SESSION[\"Name\"]為\"這是一個Session例子\"

在php4.2之後,可以為session直接付值:

$_SESSION[\"name\"]=\"value\";

取消session可以這樣:

session_start();

session_unset();

session_destroy();

取消某個session變量在php4.2以上還有BUG.

注意:

1:在調用Session_Start()之前不能有任何輸出.例如下面是錯誤的.

==========================================

1行

2行 <?PHP

3行 Session_Start();//之前在第一行已經有輸出

4行 .....

5行 ?>

提示1:

凡是出現\"........headers already sent..........\",就是Session_Start()之前向浏覽器輸出資訊.

去掉輸出就正常,(COOKIE也會出現這種錯誤,錯誤原因一樣)

提示2:

如果你的Session_Start()放在循環語句裡,并且很難确定之前哪裡向浏覽器輸出資訊,可以用下面這種方法:

1行 <?PHP Ob_Start(); ?>

........這裡是你的程式......

2:這是什麼錯誤

Warning: session_start(): open(/tmp\\sess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) failed:....

因為你沒有指定session檔案的存放路徑.

解決方法:

(1)在c盤建立檔案夾tmp

(2)打開php.ini,找到session.save_path,修改為session.save_path= \"c:/tmp\"

$Var=\"hello php\";//修改為$Var=\"   hello php\";試試得到什麼結果

$post= \"receive.php?Name=\".$Var;

header(\"location:$post\");

receive.php的内容:

Echo   $_GET[\"Name\"];

正确的方法是:

$Var=\"hello php\";

$post= \"receive.php?Name=\".urlencode($Var);

在接收頁面你不需要使用Urldecode(),變量會自動編碼.

5:如何截取指定長度漢字而不會出現以\"?>\"結尾,超出部分以\"...\"代替

一般來說,要截取的變量來自Mysql,首先要保證那個字段長度要足夠長,一般為char(200),可以保持100個漢字,包括标點.

$str=\"這個字元好長呀,^_^\";

$Short_Str=showShort($str,4);//截取前面4個漢字,結果為:這個字元...

Echo   \"$Short_Str\";

Function csubstr($str,$start,$len)

{

$strlen=strlen($str);

$clen=0;

for($i=0;$i<$strlen;$i++,$clen++)

if ($clen>=$start+$len)

break;

if(ord(substr($str,$i,1))>0xa0)

if ($clen>=$start)

$tmpstr.=substr($str,$i,2);

$i++;

}

else

$tmpstr.=substr($str,$i,1);

return $tmpstr;

Function showShort($str,$len)

$tempstr = csubstr($str,0,$len);

if ($str<>$tempstr)

$tempstr .= \"...\"; //要以什麼結尾,修改這裡就可以.

return $tempstr;

}

在表格,字段前面加上\"`\",這樣就不會因為誤用關鍵字而出現錯誤,

當然我并不推薦你使用關鍵字.

例如

$Sql=\"INSERT INTO `xltxlm` (`author`, `title`, `id`, `content`,

`date`) VALUES (\'xltxlm\', \'use`\', 1, \'criterion your sql string

\', &#392003;-07-11 00:00:00\')\"

\"`\"怎麼輸入? 在TAB鍵上面.

$str=\"<h1>PHP</h1>\";

Echo \"被解釋過的: \".$str.\"<br>經過處理的:\";

Echo   htmlentities(nl2br($str));

$a=\"PHP\";

foo();

Function foo()

{

global $a;//删除這裡看看是什麼結果

Echo \"$a\";

<?php

$arr = get_defined_functions();

Function php() {

echo   \"<pre>\";

Echo   \"這裡顯示系統所支援的所有函數,和自定以函數php\\n\";

print_r($arr);

echo   \"</pre>\";

?>

$Date_1=\"2003-7-15\";//也可以是:$Date_1=\"2003-6-25 23:29:14\";

$Date_2=\"1982-10-1\";

$Date_List_1=explode(\"-\",$Date_1);

$Date_List_2=explode(\"-\",$Date_2);

$d1=mktime(0,0,0,$Date_List_1[1],$Date_List_1[2],$Date_List_1[0]);

$d2=mktime(0,0,0,$Date_List_2[1],$Date_List_2[2],$Date_List_2[0]);

$Days=round(($d1-$d2)/3600/24);

Echo   \"偶已經奮鬥了 $Days 天^_^\";

這是警告的意思,由于變量未定義引起的.

打開php.ini,找到最下面的error_reporting,修改為error_reporting = E_ALL & ~E_NOTICE

對于Parse error錯誤

error_reporting(0)無法關閉.

如果你想關閉任何錯誤提示,打開php.ini,找到display_errors,設定為display_errors = Off.以後任何錯誤都不會提示.

那什麼是error_reporting?

1:打開php.ini檔案

設定 include_path= \"c:\"

2:寫兩個檔案

auto_prepend_file.php 和 auto_append_file.php 儲存在c盤,他們将自動依附在每個php檔案的頭部和尾部.

3:在php.ini中找到:

Automatically add files before or after any PHP document.

auto_prepend_file = auto_prepend_file.php;依附在頭部

auto_append_file = auto_append_file.php;依附在尾部

以後你每個php檔案就相當于

Include \"auto_prepend_file.php\" ;

.......//這裡是你的程式

Include \"auto_append_file.php\";

<html><head>

<title>上載檔案表單</title></head>

<body>

<form enctype=\"multipart/form-data\" action=\"\" method=\"post\">

請選擇檔案: <br>

<input name=\"upload_file\" type=\"file\"><br>

<input type=\"submit\" value=\"上傳檔案\">

</form>

</body>

</html>

<?

$upload_file=$_FILES[\'upload_file\'][\'tmp_name\'];

$upload_file_name=$_FILES[\'upload_file\'][\'name\'];

if($upload_file){

$file_size_max = 1000*1000;// 1M限制檔案上傳最大容量(bytes)

$store_dir = \"d:/\";// 上傳檔案的儲存位置

$accept_overwrite = 1;//是否允許覆寫相同檔案

// 檢查檔案大小

if ($upload_file_size > $file_size_max) {

echo \"對不起,你的檔案容量大于規定\";

exit;

// 檢查讀寫檔案

if (file_exists($store_dir . $upload_file_name) && !$accept_overwrite) {

Echo   \"存在相同檔案名的檔案\";

//複制檔案到指定目錄

if (!move_uploaded_file($upload_file,$store_dir.$upload_file_name)) {

echo \"複制檔案失敗\";

Echo   \"<p>你上傳了檔案:\";

echo $_FILES[\'upload_file\'][\'name\'];

echo \"<br>\";

//用戶端機器檔案的原名稱。

Echo   \"檔案的 MIME 類型為:\";

echo $_FILES[\'upload_file\'][\'type\'];

//檔案的 MIME 類型,需要浏覽器提供該資訊的支援,例如“p_w_picpath/gif”。

Echo   \"上傳檔案大小:\";

echo $_FILES[\'upload_file\'][\'size\'];

//已上傳檔案的大小,機關為位元組。

Echo   \"檔案上傳後被臨時儲存為:\";

echo $_FILES[\'upload_file\'][\'tmp_name\'];

//檔案被上傳後在服務端儲存的臨時檔案名。

$Erroe=$_FILES[\'upload_file\'][\'error\'];

switch($Erroe){

  case 0:

    Echo   \"上傳成功\"; break;

  case 1:

    Echo   \"上傳的檔案超過了 php.ini 中 upload_max_filesize 選項限制的值.\"; break;

  case 2:

    Echo   \"上傳檔案的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值。\";   break;

  case 3:

    Echo   \"檔案隻有部分被上傳\";break;

  case 4:

    Echo   \"沒有檔案被上傳\";break;

下面是我的配置過程

1:用dos指令(也可以手動操作,拷貝dlls檔案夾裡所有dll檔案到system32目錄下) copy c:\\php\\dlls\\*.dll c:\\windows\\system32\\

2:打開php.ini

設定extension_dir = \"c:/php/extensions/\";

3:

extension=php_gd2.dll;把extension前面的逗号去掉,如果沒有php_gd2.dll,php_gd.dll也一樣,保證确實存在這一檔案c:/php/extensions/php_gd2.dll

4:運作下面程式進行測試

Ob_end_flush();

//注意,在此之前不能向浏覽器輸出任何資訊,要注意是否設定了 auto_prepend_file.

header (\"Content-type: p_w_picpath/png\");

$im = @p_w_picpathcreate (200, 100)

or die (\"無法建立圖像\");

$background_color = p_w_picpathcolorallocate ($im, 0,0, 0);

$text_color = p_w_picpathcolorallocate ($im, 230, 140, 150);

p_w_picpathstring ($im, 3, 30, 50, \"A Simple Text String\", $text_color);

p_w_picpathpng ($im);

點選這裡檢視結果

UBB代碼是HTML的一個變種,是Ultimate Bulletin Board (國外一個BBS程式,國内也有不少地方使用這個程式)采用的一種特殊的TAG.

即使禁止使用 HTML,你也可以用 UBBCode? 來實作.也許你更希望使用 UBBCode? 而不是 HTML, 即使論壇允許使用 HTML, 因為使用起來代碼較少也更安全.

Q3boy的UBB裡面付有例子,可以直接運作測試

首先要聲明一點,大部分情況下,修改MySQL是需要有mysql裡的root權限的,

是以一般使用者無法更改密碼,除非請求管理者.

方法一

  使用phpmyadmin,這是最簡單的了,修改mysql庫的user表,

  不過别忘了使用PASSWORD函數。

方法二

  使用mysqladmin,這是前面聲明的一個特例。

  mysqladmin -u root -p password mypasswd

  輸入這個指令後,需要輸入root的原密碼,然後root的密碼将改為mypasswd。

  把指令裡的root改為你的使用者名,你就可以改你自己的密碼了。

  當然如果你的mysqladmin連接配接不上mysql server,或者你沒有辦法執行mysqladmin,

  那麼這種方法就是無效的。

  而且mysqladmin無法把密碼清空。

下面的方法都在mysql提示符下使用,且必須有mysql的root權限:

  方法三

  mysql> INSERT INTO mysql.user (Host,User,Password)

  VALUES(\'%\',\'jeffrey\',PASSWORD(\'biscuit\'));

  mysql> FLUSH PRIVILEGES

  确切地說這是在增加一個使用者,使用者名為jeffrey,密碼為biscuit。

  在《mysql中文參考手冊》裡有這個例子,是以我也就寫出來了。

  注意要使用PASSWORD函數,然後還要使用FLUSH PRIVILEGES。

方法四

  和方法三一樣,隻是使用了REPLACE語句

  mysql> REPLACE INTO mysql.user (Host,User,Password)

方法五

  使用SET PASSWORD語句,

  mysql> SET PASSWORD FOR jeffrey@\"%\" = PASSWORD(\'biscuit\');

  你也必須使用PASSWORD()函數,

  但是不需要使用FLUSH PRIVILEGES。

方法六

  使用GRANT ... IDENTIFIED BY語句

  mysql> GRANT USAGE ON *.* TO jeffrey@\"%\" IDENTIFIED BY \'biscuit\'

  這裡PASSWORD()函數是不必要的,也不需要使用FLUSH PRIVILEGES。

注意: PASSWORD() [不是]以在Unix密碼加密的同樣方法施行密碼加密。

//必須通過超級連接配接進入才有輸出

Echo $_SERVER[\'HTTP_REFERER\'];

入庫時

$str=addslashes($str);

$sql=\"insert into `tab` (`content`) values(\'$str\')\";

出庫時

$str=stripslashes($str);

顯示時

$str=htmlspecialchars(nl2br($str)) ;

$s=\"http://{$_SERVER[\'HTTP_HOST\']}:{$_SERVER[\"SERVER_PORT\"]}{$_SERVER[\'SCRIPT_NAME\']}\";

$se=\'\'

foreach ($_GET as $key => $value) {   

$se.=$key.\"=\".$value.\"&\";   

}   

$se=Preg_Replace(\"/(.*)&$/\",\"$1\",$se);

$se?$se=\"?\".$se:\"\";

echo   $s.\"?$se\";

這是因為你使用了session.

解決辦法:

session_cache_limiter(\'禁用詞語, must-revalidate\');

session_start();

...........

..........

Header(\"Content-type: p_w_picpath/png\");

$img = ImageCreate(180,50);

$ip = $_SERVER[\'REMOTE_ADDR\'];

ImageColorTransparent($img,$bgcolor);

$bgColor = ImageColorAllocate($img, 0x2c,0x6D,0xAF); // 背景顔色

$shadow = ImageColorAllocate($img, 250,0,0);   // 陰影顔色

$textColor = ImageColorAllocate($img, oxff,oxff,oxff);   // 字型顔色

ImageTTFText($img,10,0,78,30,$shadow,\"d:/windows/fonts/Tahoma.ttf\",$ip); //顯示背景

ImageTTFText($img,10,0,25,28,$textColor,\"d:/windows/fonts/Tahoma.ttf\",\"your ip is\".$ip); // 顯示IP

ImagePng($img);

p_w_picpathcreatefrompng($img);

ImageDestroy($img);

<?

function iptype1 () {

if (getenv(\"HTTP_CLIENT_IP\")) {

return getenv(\"HTTP_CLIENT_IP\");

else {

return \"none\";

function iptype2 () {

if (getenv(\"HTTP_X_FORWARDED_FOR\")) {

return getenv(\"HTTP_X_FORWARDED_FOR\");

function iptype3 () {

if (getenv(\"REMOTE_ADDR\")) {

return getenv(\"REMOTE_ADDR\");

function ip() {

$ip1 = iptype1();

$ip2 = iptype2();

$ip3 = iptype3();

if (isset($ip1) && $ip1 != \"none\" && $ip1 != \"unknown\") {

return $ip1;

elseif (isset($ip2) && $ip2 != \"none\" && $ip2 != \"unknown\") {

return $ip2;

elseif (isset($ip3) && $ip3 != \"none\" && $ip3 != \"unknown\") {

return $ip3;

Echo ip();

首先表格裡要有一個DATETIME字段記錄時間,

格式為&#392003;-7-15 16:50:00\'

SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;

在增加使用者的mysql表裡有一個host字段,修改為\"%\",或者指定允許連接配接的ip位址,這樣,你就可以遠端調用了。

$link=mysql_connect(\"192.168.1.80:3306\",\"root\",\"\");

點選這裡

正規表達式中的特殊字元

方法一:

AddDefaultCharset ISO-8859-1 改為 AddDefaultCharset off

方法二:

AddDefaultCharset GB2312

========================================================

tip:

大家貼代碼時GB2312會被解釋成??????

改成這樣就不會

GB2312

27:為什麼單引号,雙引号在接受頁面變成(\\\'\\\")

方法一:在php.ini中設定:magic_quotes_gpc = Off

方法二: $str=stripcslashes($str)

set_time_limit(60)//最長運作時間一分鐘

set_time_limit(0)//運作到程式自己結束,或手動停止

例子一:用文本實作

//首先你要有讀寫檔案的權限

//本程式可以直接運作,第一次報錯,以後就可以

$online_log = \"count.dat\"; //儲存人數的檔案,

$timeout = 30;//30秒内沒動作者,認為掉線

$entries = file($online_log);

$temp = array();

for ($i=0;$i<count($entries);$i++) {

$entry = explode(\",\",trim($entries[$i]));

if (($entry[0] != getenv(\'REMOTE_ADDR\')) && ($entry[1] > time())) {

array_push($temp,$entry[0].\",\".$entry[1].\"\\n\"); //取出其他浏覽者的資訊,并去掉逾時者,儲存進$temp

array_push($temp,getenv(\'REMOTE_ADDR\').\",\".(time() + ($timeout)).\"\\n\"); //更新浏覽者的時間

$users_online = count($temp); //計算線上人數

$entries = implode(\"\",$temp);

//寫入檔案

$fp = fopen($online_log,\"w\");

flock($fp,LOCK_EX); //flock() 不能在NFS以及其他的一些網絡檔案系統中正常工作

fputs($fp,$entries);

flock($fp,LOCK_UN);

fclose($fp);

echo \"目前有\".$users_online.\"人線上\";

例子二:

用資料庫實作線上使用者

這裡有幾篇關于模闆的文章

我用的是phplib模闆

下面是其中幾個函數的使用

$T->Set_File(\"随便定義\",\"模闆檔案.tpl\");

$T->Set_Block(\"在set_file中定義的\",\"<!-- 來自模闆 -->\",\"随便定義\");

$T->Parse(\"在Set_Block中定義的\",\"<!-- 來自模闆 -->\",true);

$T->Parse(\"随便輸出結果\",\"在Set_File中定義的\");

設定循環格式為:

<!--(多于一個空格) BEGIN $handle(多于一個空格)-->

如何将模闆生成靜态網頁

//這裡使用phplib模闆

............

$tpl->parse(\"output\",\"html\");

$output = $tpl->get(\"output\");// $output 為整個網頁内容

function wfile($file,$content,$mode=\'w\') {

$oldmask = umask(0);

$fp = fopen($file, $mode);

if (!$fp) return false;

fwrite($fp,$content);

fclose($fp);

umask($oldmask);

return true;

// 寫到檔案裡

Wfile($FILE,$output);

header(\"location:$FILE\");//重定向到生成的網頁

phplib下載下傳位址 smarty下載下傳位址

比如:輸入2+2*(1+2),自動輸出8

可以用eval函數

<form method=post action=\"\">

<input type=\"text\" name=\"str\"><input type=\"submit\">

</form>

$str=$_POST[\'str\'];

eval(\"\\$o=$str;\");

Echo   \"$o\";