Php部分常見問題總結
1:為什麼我得不到變量
我在一網頁向另一網頁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"]等,這種方法雖然麻煩,但比較安全.
2:調試你的程序
在運行時必須知道某個變量為何值。我是這樣做的,建立一文件debug.php,其內容如下:
PHP代碼:--------------------------------------------------------------------------------
Ob_Start();
Session_Start();
Echo "
";";
Echo "本頁得到的_GET變量有:";
Print_R($_GET);
Echo "本頁得到的_POST變量有:";
Print_R($_POST);
Echo "本頁得到的_COOKIE變量有:";
Print_R($_COOKIE);
Echo "本頁得到的_SESSION變量有:";
Print_R($_SESSION);
Echo "
?>
--------------------------------------------------------------------------------
然後在php.ini中設置:include_path = "c:/php",並將debug.php放在此文件夾,
以後就可以在每個網頁裡包含此文件,查看得到的變量名和值.
3:如何使用session
凡是與session有關的,之前必須調用函數session_start();
為session付值很簡單,如:
PHP代碼:--------------------------------------------------------------------------------
Session_start();
$Name = "這是一個Session例子";
Session_Register("Name");//注意,不要寫成:Session_Register("$Name");
Echo $_SESSION["Name"];
//之後$_SESSION["Name"]為"這是一個Session例子"
?>
--------------------------------------------------------------------------------
在php4.2之後,可以為session直接賦值:
PHP代碼:--------------------------------------------------------------------------------
Session_Start();
$_SESSION["name"]="value";
?>
--------------------------------------------------------------------------------
取消session可以這樣:
PHP代碼:--------------------------------------------------------------------------------
session_start();
session_unset();
session_destroy();
?>
--------------------------------------------------------------------------------
取消某個session變量在php4.2以上還有BUG.
注意:
1:在調用Session_Start()之前不能有任何輸出.例如下面是錯誤的.
==========================================
1行
2行 3行 Session_Start();//之前在第一行已經有輸出
4行 .....
5行 ?>
==========================================
提示1:
凡是出現"........headers already sent..........",就是Session_Start()之前向瀏覽器輸出信息.
去掉輸出就正常,(COOKIE也會出現這種錯誤,錯誤原因一樣)
提示2:
如果你的Session_Start()放在循環語句裡,並且很難確定之前哪裡向瀏覽器輸出信息,可以用下面這種方法:
1行
........這裡是你的程序......
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"
4:為什麼我向另一網頁傳送變量時,只得到前半部分,以空格開頭的則全部丟失
PHP代碼:--------------------------------------------------------------------------------
$Var="hello php";//修改為$Var=" hello php";試試得到什麼結果
$post= "receive.php?Name=".$Var;
header("location:$post");
?>
--------------------------------------------------------------------------------
receive.php的內容:
PHP代碼:--------------------------------------------------------------------------------
Echo "
";";
Echo $_GET["Name"];
Echo "
?>
--------------------------------------------------------------------------------
正確的方法是:
PHP代碼:--------------------------------------------------------------------------------
$Var="hello php";
$post= "receive.php?Name=".urlencode($Var);
header("location:$post");
?>
--------------------------------------------------------------------------------
在接收頁面你不需要使用Urldecode(),變量會自動編碼.
5:如何截取指定長度漢字而不會出現以"?>"結尾,超出部分以"..."代替
一般來說,要截取的變量來自Mysql,首先要保證那個字段長度要足夠長,一般為char(200),可以保持100個漢字,包括標點.
PHP代碼:--------------------------------------------------------------------------------
$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
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,1);
}
}
return $tmpstr;
}
Function showShort($str,$len)
{
$tempstr = csubstr($str,0,$len);
if ($str<>$tempstr)
$tempstr .= "..."; //要以什麼結尾,修改這裡就可以.
return $tempstr;
}
--------------------------------------------------------------------------------
6:規範你的SQL語句
在表格,字段前面加上"`",這樣就不會因為誤用關鍵字而出現錯誤,
當然我並不推薦你使用關鍵字.
例如
$Sql="INSERT INTO `xltxlm` (`author`, `title`, `id`, `content`, `date`) VALUES ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"
"`"怎麼輸入? 在TAB鍵上面.
7:如何使Html/PHP格式的字符串不被解釋,而是照原樣顯示
PHP代碼:--------------------------------------------------------------------------------
$str="
PHP
";Echo "被解釋過的: ".$str."
經過處理的:";
Echo htmlentities(nl2br($str));
?>
--------------------------------------------------------------------------------
8:怎麼在函數里取得函數外的變量值
PHP代碼:--------------------------------------------------------------------------------
$a="PHP";
foo();
Function foo()
{
global $a;//刪除這裡看看是什麼結果
Echo "$a";
}
?>
--------------------------------------------------------------------------------
9:我怎麼知道系統默認支持什麼函數
PHP代碼:--------------------------------------------------------------------------------
$arr = get_defined_functions();
Function php() {
}
echo "
";";
Echo "這裡顯示系統所支持的所有函數,和自定以函數php\n";
print_r($arr);
echo "
?>
--------------------------------------------------------------------------------
10:如何比較兩個日期相差幾天
PHP代碼:--------------------------------------------------------------------------------
$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 天^_^";
?>
--------------------------------------------------------------------------------
11:為什麼我升級PHP後,原來的程序出現滿屏的 Notice: Undefined variable:
這是警告的意思,由於變量未定義引起的.
打開php.ini,找到最下面的error_reporting,修改為error_reporting = E_ALL & ~E_NOTICE
對於Parse error錯誤
error_reporting(0)無法關閉.
如果你想關閉任何錯誤提示,打開php.ini,找到display_errors,設置為display_errors = Off.以後任何錯誤都不會提示.
那什麼是error_reporting?
12:我想在每個文件最前,最後面都加上一文件.但一個一個添加很麻煩
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文件就相當於
PHP代碼:--------------------------------------------------------------------------------
Include "auto_prepend_file.php" ;
.......//這裡是你的程序
Include "auto_append_file.php";
?>
--------------------------------------------------------------------------------
13:如何利用PHP上傳文件
PHP代碼:--------------------------------------------------------------------------------
$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 "存在相同文件名的文件";
exit;
}
//複製文件到指定目錄
if (!move_uploaded_file($upload_file,$store_dir.$upload_file_name)) {
echo "複製文件失敗";
exit;
}
}
Echo "
你上傳了文件:";
echo $_FILES['upload_file']['name'];
echo "
";
//客戶端機器文件的原名稱。
Echo "文件的 MIME 類型為:";
echo $_FILES['upload_file']['type'];
//文件的 MIME 類型,需要瀏覽器提供該信息的支持,例如「image/gif」。
echo "
";
Echo "上傳文件大小:";
echo $_FILES['upload_file']['size'];
//已上傳文件的大小,單位為字節。
echo "
";
Echo "文件上傳後被臨時儲存為:";
echo $_FILES['upload_file']['tmp_name'];
//文件被上傳後在服務端儲存的臨時文件名。
echo "
";
$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;
}
?>
--------------------------------------------------------------------------------
14:如何配置GD庫
下面是我的配置過程
1:用dos命令(也可以手動操作,拷貝dlls文件夾裡所有dll文件到system32目錄下) copy c:\php\dlls\*.dll c:\windows\system322:打開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:運行下面程序進行測試
PHP代碼:--------------------------------------------------------------------------------
Ob_end_flush();
//注意,在此之前不能向瀏覽器輸出任何信息,要注意是否設置了 auto_prepend_file.
header ("Content-type: image/png");
$im = @imagecreate (200, 100)
or die ("無法創建圖像");
$background_color = imagecolorallocate ($im, 0,0, 0);
$text_color = imagecolorallocate ($im, 230, 140, 150);
imagestring ($im, 3, 30, 50, "A Simple Text String", $text_color);
imagepng ($im);
?>
--------------------------------------------------------------------------------
點擊這裡查看結果
15:什麼是UBB代碼
UBB代碼是HTML的一個變種,是Ultimate Bulletin Board (國外一個BBS程序,國內也有不少地方使用這個程序)採用的一種特殊的TAG.
即使禁止使用 HTML,你也可以用 UBBCode? 來實現.也許你更希望使用 UBBCode? 而不是 HTML, 即使論壇允許使用 HTML, 因為使用起來代碼較少也更安全.
Q3boy的UBB裡面付有例子,可以直接運行測試
16:我想修改MySQL的用戶,密碼
首先要聲明一點,大部分情況下,修改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)
VALUES('%','jeffrey',PASSWORD('biscuit'));
mysql> FLUSH PRIVILEGES
方法五
使用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口令加密的同樣方法施行口令加密。
17:我想知道他是通過哪個網站連接到本頁
PHP代碼:--------------------------------------------------------------------------------
//必須通過超級連接進入才有輸出
Echo $_SERVER['HTTP_REFERER'];
?>
--------------------------------------------------------------------------------
18:數據放入數據庫和取出來顯示在頁面需要注意什麼
入庫時
$str=addslashes($str);
$sql="insert into `tab` (`content`) values('$str')";
出庫時
$str=stripslashes($str);
顯示時
$str=htmlspecialchars(nl2br($str)) ;
19:如何讀取當前地址欄信息
PHP代碼:--------------------------------------------------------------------------------
$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";
?>
--------------------------------------------------------------------------------
20:我點擊後退按鈕,為什麼之前填寫的東西不見
這是因為你使用了session.
解決辦法:
PHP代碼:--------------------------------------------------------------------------------
session_cache_limiter('private, must-revalidate');
session_start();
...........
..........
?>
--------------------------------------------------------------------------------
21:怎麼在圖片裡顯示IP地址
PHP代碼:--------------------------------------------------------------------------------
Header("Content-type: image/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);
imagecreatefrompng($img);
ImageDestroy($img);
?>
--------------------------------------------------------------------------------
22:如何取得用戶的真實IP
PHP代碼:--------------------------------------------------------------------------------
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");
}
else {
return "none";
}
}
function iptype3 () {
if (getenv("REMOTE_ADDR")) {
return getenv("REMOTE_ADDR");
}
else {
return "none";
}
}
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;
}
else {
return "none";
}
}
Echo ip();
?>
--------------------------------------------------------------------------------
23:如何從數據庫讀取三天內的所有記錄
首先表格裡要有一個DATETIME字段記錄時間,
格式為'2003-7-15 16:50:00'
SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;
24:如何遠程鏈接Mysql數據庫
在增加用戶的mysql表裡有一個host字段,修改為"%",或者指定允許連接的ip地址,這樣,你就可以遠程調用了。
$link=mysql_connect("192.168.1.80:3306","root","");
25:正則到底怎麼用
點擊這裡
正則表達式中的特殊字符
26:用Apache後,主頁出現亂碼
方法一:
AddDefaultCharset ISO-8859-1 改為 AddDefaultCharset off
方法二:
AddDefaultCharset GB2312
========================================================
tip:
大家貼代碼時GB2312會被解釋成??????
改成這樣就不會
GB2312
-------------------------------------------------------------------------------
********用parse_url 函數*******************
用parse_url 函數。
例子:
$ php -r 'print_r( parse_url("
Array
(
[scheme] => http
[host] => hostname
[user] => username
[pass] => password
[path] => /path
[query] => arg=value
[fragment] => anchor
)
$ php -r 'print_r( parse_url("http://invalid_host..name/"));'
Array
(
[scheme] => http
[host] => invalid_host..name
[path] => /
)
******動態生成HTML方法******************
ob_start(); //打開緩存
echo"
新新內容,也可以用模板來生成";
$aFile=fopen("cache/aa".$startpage.".html",'w'); //文件,$startpage可以用時間來生成,唯一
fwrite($aFile,ob_get_contents()); //寫入
fclose($aFile);
ob_end_clean(); //清空
?>
*****讓瀏覽器不保存脫機內容********
header("Cache-Control: no-store, no-cache,must-revalidate");
**********壓縮文本***********************************
先加載模塊extension=php_zlib.dll
PHP代碼:--------------------------------------------------------------------------------
$x="hello world";
$x=gzcompress($x) ; //壓縮
echo $x ;
echo "
";
echo gzuncompress($x); //解壓
********返回瀏覽器版本*******************
function browse_infor()
{
$browser="";$browserver="";
$Browsers =array("Lynx","MOSAIC","AOL","Opera","JAVA","MacWeb","WebExplorer","OmniWeb");
$Agent = $GLOBALS["HTTP_USER_AGENT"];
for ($i=0; $i<=7; $i++)
{
if (strpos($Agent,$Browsers[$i]))
{
$browser = $Browsers[$i];
$browserver ="";
}
}
if (ereg("Mozilla",$Agent) && !ereg("MSIE",$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[0];
$temp =explode("/", $Part); $browserver=$temp[1];
$temp =explode(" ",$browserver); $browserver=$temp[0];
$browserver =preg_replace("/([\d\.]+)/","\\1",$browserver);
$browserver = " $browserver";
$browser = "Netscape Navigator";
}
if (ereg("Mozilla",$Agent) && ereg("Opera",$Agent))
{
$temp =explode("(", $Agent); $Part=$temp[1];
$temp =explode(")", $Part); $browserver=$temp[1];
$temp =explode(" ",$browserver);$browserver=$temp[2];
$browserver =preg_replace("/([\d\.]+)/","\\1",$browserver);
$browserver = " $browserver";
$browser = "Opera";
}
if (ereg("Mozilla",$Agent) && ereg("MSIE",$Agent))
{
$temp = explode("(", $Agent); $Part=$temp[1];
$temp = explode(";",$Part); $Part=$temp[1];
$temp = explode(" ",$Part);$browserver=$temp[2];
$browserver =preg_replace("/([\d\.]+)/","\\1",$browserver);
$browserver = " $browserver";
$browser = "Internet Explorer";
}
if ($browser!="")
{
$browseinfo = "$browser$browserver";
}
else
{
$browseinfo = "Unknown";
}
return $browseinfo;
}
//調用方法$browser=browse_infor() ;直接返回結果
***********************************************
讓自動增加的id號字段從新從0開始計數啊??
alter table tablename auto_increment=0;
************************************************
get_cfg_var()什麼意思? 動態態讀寫PHP。INI的值
取php.ini 中配置指令的值
比如在php.ini中有如下配置
SMTP = localhost
那麼 get_var_cfg('SMTP'); 將返回 localhost
get_var_cfg() 取的值是配置文件中的值,而不是當前值
而 ini_get 則取的當前值
比如配置文件中 SMTP = localhost
print get_cfg_var('SMTP'); // 返回 localhost
print ini_get('SMTP'); // 返回 localhost
ini_set('SMTP', '192.168.1.24'); // 改變 SMTP 的當前值
print get_cfg_var('SMTP'); // 返回 localhost
print ini_get('SMTP'); // 返回 192.168.1.24
************************************************8
httpd.conf 如果設置邦多個域名?
例:
ServerAdmin
DocumentRoot /home/mysite/public_html/
ServerName game.mysite.com
ErrorLog logs/game.mysite.com-error_log
CustomLog logs/game.mysite.com-access_log common
以上已經正確的邦一個 game.mysite.com ,但如果小弟我想在邦多個怎麼邦??如,www.mysite.com 和mysite.com 都在這個目錄是不是:
ServerName game.mysite.com,www.mysite.com,mysite.com
這樣??
同時,在IIS裡我經常把WEB訪問的日誌去了,這樣就不用記錄日誌了,這個:
ErrorLog logs/game.mysite.com-error_log
CustomLog logs/game.mysite.com-access_log common
是不是把這二句刪除了,WEB訪問就沒有日誌了???
請指教,謝謝了……
第 2 貼 轉的
HTTP 1.1標準在協議中規定了對瀏覽器和服務器通信時,服務器能夠跟蹤瀏
覽器請求的是哪個主機名字。因此可以利用這個新特性,使用更輕鬆的方式設定
虛擬主機。這種方式不需要額外的IP地址,但需要新版本的瀏覽器支持。這種方式已經成為建立虛擬主機的標準方式。
要建立非IP基礎的虛擬主機,多個域名是不可少的配置,因為每個域名就對
應一個要服務的虛擬主機。因此需要更改DNS服務器的配置,為服務器增加多個C NAME選項,如:
linux IN A 192.168.1.64
vhost1 IN CNAME linux
vhost2 IN CNAME linux
基本的設置選項都是為了linux主機設定的,如果要為vhost1和vhost2設定
虛擬主機,就要使用VirtualHost語句定義不同的選項,在語句中可以使用配置文件前面中的大部分選項,而可以重新定義幾乎所有的針對服務器的設置。
NameVirtualHost 192.168.1.64
DocumentRoot /www/data
ServerName linux.example.org.cn
DocumentRoot /vhost1
ServerName vhost1.example.org.cn
DocumentRoot /vhost2
ServerName vhost2.example.org.cn
這裡需要注意的是,VirtualHost的參數地址一定要和NameVirtualHost定義的地址相一致,必須保證所有的值嚴格一致,Apache服務器才承認這些定義是為這個IP地址定義的虛擬主機。
此外,定義過NameVirtualHost之後,那麼對這個IP地址的訪問都被區分不同的虛擬主機進行處理,而對其他IP地址的訪問,例如127.0.0.1,才應用前面定義的缺省選項。
******************************
如何才能讓別人下載abc.php而不是運行這個文件?
修改後綴名是最簡單了方法了~
也可以用程序實現,發一個瀏覽器不認識的 MIME,讓瀏覽器下載
這個文件,而不是在瀏覽器中顯示。
PHP:---------------------------------------------
header("Content-type: application/unknow");
header("Content-Disposition: attachment; filename=test.php");
// 讀取你要下載的文件
readfile('test.php');
?>
*******************************
請教:php中提取FLASH 輸入框中文產生亂碼的問題
多謝
是MX嗎?
在首幀的action首行寫system.usecodepage = true
********************************
求一個日期與今天相差天數
function dktime($oldtime)
{
list($odate)=explode(' ',$oldtime);
list($oy,$om,$od)=explode("-",$odate);
$otime=mktime(0,0,0,$om,$od,$oy);
$y=date("Y");$m=date("m");$d=date("d");
$time=mktime(0,0,0,$m,$d,$y);
$out=round(($time-$otime)/3600/24);
return($out);
}
$old="2003-06-03 12:45:23";
echo dktime($old);
$從數據庫取得的時間="2002-12-20 0:6:6";
list($以前日期)= explode(" ", $從數據庫取得的時間);
list($以前年,$以前月,$以前日)=explode("-", $以前日期);
$以前時間=mktime(0,0,0,$以前月,$以前日,$以前年);
$現在年=date(Y); $現在月=date(m); $現在日=date(d);
$現在時間=mktime("0","0","0",$現在月,$現在日,$現在年);
$相差天數=round(($現在時間-$以前時間)/3600/24) ;
echo $相差天數;
********************************
在apache+php系統上傳大文件
除了upload_max_filesize 在php.ini裡
把這個:post_max_size = 8M 改夠大,
另外程序前加上set_time_limit(0);
基本就可以了
********************************
Apache 中添加兩個可訪問IP表示服務器所擁有IP都可訪問
BindAddress *
********************************
請問如何查出新增記錄自動插入的id號?
mysql裡的user 表id字段是自動插入,
假如我插入一條記錄後要顯示本記錄的id應該如何實現??
$query="select max(id) from table"
說白了﹐就是找目前最大的ID
php 的函數mysql_insert_id()
********************************
Apache服務器的亂碼問題
在Apache 中添加一句設置默認的編碼!!
AddDefaultCharset ??????
如果還不能解決就設成不要默認編碼:
AddDefaultCharset Off
********************************
複選框的值的提交的問題比單選框要複雜一些。在單選框即RADIO中,每一選項的名字是一樣的,但只能有一項被選中,提交時即將此項的VALUE提交。在複選框裡面,用戶有可能選取多個選項,那麼,如何將所有被選中的值都提交到下一個頁面呢?
用數組。思路是這樣的:給複選框中的選項命名時,給他們取名為一個名字都相同的數組,比如SUBMIT[],這樣,用戶提交時,會將所有被選中的選項的值存在此數組中提交至下一個頁面。然後,使用IMPLODE()函數將這個數組的值組合起來後存放在表中即可。
********************************
文件上傳
當php.ini的register_globals=off的時候,文件上傳以後的變量名稱及使用與等於on的時候不一樣了,具體體現在:
on時 off時 變量含義
$userfile $_REQUEST[userfile][tmp_name] 服務器上文 件臨時存放的名稱(包括臨時路徑)
$usefiler_name $_REQUEST[userfile][name] 文件的實際名稱
$userfile_size $_REQUEST[userfile][name] 文件的大小
$userfile_type $_REQUEST[userfile][type] 文件的類型
$_REQUEST[userfile][error] 錯誤次數
*********************************
比較判斷字符串1包含在字符串2中
print substr_count("This is a test", "is"); // prints out 2
strpos('rar,zip,exe,doc,xls,gif,jpg,bmp,swf,txt,ppt','zip1')===false?'不包含':'包含')
*********************************
從數據庫隨機讀出15條記錄?
order by rand() limit 0,5
*********************************
如何才能使瀏覽器的後退鍵等失效啊?
用PHP&MYSQL做了個工資查詢,但在註銷後,按後退鍵卻可以將所查的資料看個清楚,如何辦呢?請指教!THS.
你鑽牛角尖了!!!
為何不從功能強大的PHP上著手考慮?
給你個方法:
1.在登錄頁面用rand()函數生成隨機數並註冊為SESSION,然後把隨機數和用戶名密碼一併提交到登錄程序
2.在登錄程序裡面驗證這個SESSION是否和提交過來的隨機數一樣,不對的話就引導回登錄界面去
記得在註銷的時候要把保存隨機數的session也註銷
剩下的你自己寫代碼啦,自己寫出來印象才深刻
***********************************
查表中一個字段的所有不同值:
select * from tables group by type
***********************************
關於Apache的幾種常見應用舉例
軟件環境:Redhat Linux 5.2
A.如何為每個用戶設置單獨的主頁?
默認設置情況下,你需要在你的用戶主目錄中創建目錄public_html,然後把你的所有網頁文件放在該目錄下即可,打入http://servername/~username訪問,但是請注意以下幾點:
1.登錄為root,修改用戶主目錄權限(#chmod 705 /home/username),讓其他人有權進入該目錄瀏覽。
2.以自己的用戶名登錄,創建public_html目錄,保證該目錄也有正確的權限讓其他人進入。
3. Apache默認的主頁文件是index.html,不是index.htm,你可以改變/etc/mime.types文件中的一行象下面。
text/html html htm
然後Apache會讀你的index.htm文件4.用戶自己在主目錄下創建的目錄最好把權限設為0700,確保其他人不能進入訪問。
B.如何設虛擬主機?
1.假設某台服務器IP為192.168.11.2,要虛擬另一IP address為192.168.11.4,則加下面的行到/etc/rc.d/rc.local
/sbin/ifconfig eth0:0 192.168.11.4 /sbin/route add -host 192.168.11.4 eth0:0
2.加下面的行到/home/httpd/conf/httpd.conf
VirtualHost 192.168.11.4 (此行有<>)
ServerAdmin your_email_address
DocumentRoot /home/httpd/foldername
ServerName virtualservername
ErrorLog /var/log/httpd/foldername/error.log
TransferLog /var/log/httpd/foldername/access_log/VirtualHost (此行有<>)
3.若在你的LAN中有DNS服務器,加上相應的項192.168.11.4--->virtualservername
C.如何用Apache給某個目錄以密碼保護?
默認情況下,可在某個目錄下放一個文件.htaccess,象下面這樣:
AuthName stuff
AuthType Basic
AuthUserFile /etc/.userpasswd
require valid-user
為了給用戶user1進入訪問,用# htpasswd -c /etc/.userpasswd user1為user1分配密碼。
D.如何把某個目錄共享出來用瀏覽器訪問?如/home/ftp/pub/
1.加下面的行到/home/httpd/conf/srm.confAlias /pub /home/ftp/pub/2.更改默認文件類型,改/home/httpd/conf/srm.conf中一行為:
DefaultType application/octet-stream 3.重新啟動Apache. /etc/rc.d/init.d/httpd restart
**********************************************
得到真實IP
getenv
(PHP 3, PHP 4 )
getenv -- Gets the value of an environment variable
Description
string getenv ( string varname)
Returns the value of the environment variable varname, or FALSE on an error.
$ip = getenv ("REMOTE_ADDR"); // get the ip number of the user
So with this script, you always get the right IP:
if (getenv(HTTP_X_FORWARDED_FOR)){
$ip=getenv(HTTP_X_FORWARDED_FOR);
}
else {
$ip=getenv(REMOTE_ADDR);
}
To get REAL ip, u can also use this:
if(getenv("HTTP_CLIENT_IP")) {
$ip = getenv("HTTP_CLIENT_IP");
} elseif(getenv("HTTP_X_FORWARDED_FOR")) {
$ip = getenv("HTTP_X_FORWARDED_FOR");
} else {
$ip = getenv("REMOTE_ADDR");
}
Thus, we should have real user IP in variable $ip.
My "bullet-proof" solution to fetch an IP-address..
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");
}
else {
return "none";
}
}
function iptype3 () {
if (getenv("REMOTE_ADDR")) {
return getenv("REMOTE_ADDR");
}
else {
return "none";
}
}
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;
}
else {
return "none";
}
}
$ip = ip();
?>
I've fetched around 600 unique IP-addresses with this approach.. None of them returned "none" or "unknown".. Only real IP-addresses.
Best regards
Anders Winther
取得代理服務器後面的真實IP
你可能知道$_SERVER['REMOTE_ADDR'] 這個變量裡面保存的是
瀏覽者的IP地址。但是當瀏覽者使用代理服務器訪問的時候怎樣取得他的真實IP呢?
用下面代碼試試看
Code: [Copy to clipboard]
if(getenv("HTTP_CLIENT_IP")) {
$onlineip = getenv("HTTP_CLIENT_IP");
} elseif(getenv("HTTP_X_FORWARDED_FOR")) {
$onlineip = getenv("HTTP_X_FORWARDED_FOR");
} else {
$onlineip = $_SERVER["REMOTE_ADDR"];
}