php機試
A. 做好php網站怎麼調試
PHP首先要安裝IIS或者Apache 再安裝php5通過IIS配置它!資料庫一般用Mysql
B. 如何把在本機調試成功的php程序,放在網上並能正常運行
確認你的空間是否支持FSO組件
---------------------------------
無組件上傳(Up.asp)
---------------------------------
<%
dim Data_Upload
Class file_Upload
dim objForm,objFile
Public function Form(strForm)
strForm=lcase(strForm)
if not objForm.exists(strForm) then
Form=""
else
Form=objForm(strForm)
end if
End function
Public function File(strFile)
strFile=lcase(strFile)
if not objFile.exists(strFile) then
set File=new FileInfo
else
set File=objFile(strFile)
end if
End function
Private Sub Class_Initialize
dim RequestData,sStart,vbCrlf,sInfo,iInfoStart,iInfoEnd,tStream,iStart,theFile
dim iFileSize,sFilePath,sFileType,sFormValue,sFileName
dim iFindStart,iFindEnd
dim iFormStart,iFormEnd,sFormName
set objForm=Server.CreateObject("Scripting.Dictionary")
set objFile=Server.CreateObject("Scripting.Dictionary")
if Request.TotalBytes<1 then Exit Sub
set tStream = Server.CreateObject("adodb.stream")
set Data_Upload = Server.CreateObject("adodb.stream")
Data_Upload.Type = 1
Data_Upload.Mode =3
Data_Upload.Open
Data_Upload.Write Request.BinaryRead(Request.TotalBytes)
Data_Upload.Position=0
RequestData =Data_Upload.Read
iFormStart = 1
iFormEnd = LenB(RequestData)
vbCrlf = chrB(13) & chrB(10)
sStart = MidB(RequestData,1, InStrB(iFormStart,RequestData,vbCrlf)-1)
iStart = LenB (sStart)
iFormStart=iFormStart+iStart+1
while (iFormStart + 10) < iFormEnd
iInfoEnd = InStrB(iFormStart,RequestData,vbCrlf & vbCrlf)+3
tStream.Type = 1
tStream.Mode =3
tStream.Open
Data_Upload.Position = iFormStart
Data_Upload.CopyTo tStream,iInfoEnd-iFormStart
tStream.Position = 0
tStream.Type = 2
tStream.Charset ="gb2312"
sInfo = tStream.ReadText
tStream.Close
'取得表單項目名稱
iFormStart = InStrB(iInfoEnd,RequestData,sStart)
iFindStart = InStr(22,sInfo,"name=""",1)+6
iFindEnd = InStr(iFindStart,sInfo,"""",1)
sFormName = lcase(Mid (sinfo,iFindStart,iFindEnd-iFindStart))
'如果是文件
if InStr (45,sInfo,"filename=""",1) > 0 then
set theFile=new FileInfo
'取得文件名
iFindStart = InStr(iFindEnd,sInfo,"filename=""",1)+10
iFindEnd = InStr(iFindStart,sInfo,"""",1)
sFileName = Mid (sinfo,iFindStart,iFindEnd-iFindStart)
theFile.FileName=getFileName(sFileName)
theFile.FilePath=getFilePath(sFileName)
'取得文件類型
iFindStart = InStr(iFindEnd,sInfo,"Content-Type: ",1)+14
iFindEnd = InStr(iFindStart,sInfo,vbCr)
theFile.FileType =Mid (sinfo,iFindStart,iFindEnd-iFindStart)
theFile.FileStart =iInfoEnd
theFile.FileSize = iFormStart -iInfoEnd -3
theFile.FormName=sFormName
if not objFile.Exists(sFormName) then
objFile.add sFormName,theFile
end if
else
'如果是表單項目
tStream.Type =1
tStream.Mode =3
tStream.Open
Data_Upload.Position = iInfoEnd
Data_Upload.CopyTo tStream,iFormStart-iInfoEnd-3
tStream.Position = 0
tStream.Type = 2
tStream.Charset ="gb2312"
sFormValue = tStream.ReadText
tStream.Close
if objForm.Exists(sFormName) then
objForm(sFormName)=objForm(sFormName)&", "&sFormValue
else
objForm.Add sFormName,sFormValue
end if
end if
iFormStart=iFormStart+iStart+1
wend
RequestData=""
set tStream =nothing
End Sub
Private Sub Class_Terminate
if Request.TotalBytes>0 then
objForm.RemoveAll
objFile.RemoveAll
set objForm=nothing
set objFile=nothing
Data_Upload.Close
set Data_Upload =nothing
end if
End Sub
Private function GetFilePath(FullPath)
If FullPath <> "" Then
GetFilePath = left(FullPath,InStrRev(FullPath, "\"))
Else
GetFilePath = ""
End If
End function
Private function GetFileName(FullPath)
If FullPath <> "" Then
GetFileName = mid(FullPath,InStrRev(FullPath, "\")+1)
Else
GetFileName = ""
End If
End function
End Class
Class FileInfo
dim FormName,FileName,FilePath,FileSize,FileType,FileStart
Private Sub Class_Initialize
FileName = ""
FilePath = ""
FileSize = 0
FileStart= 0
FormName = ""
FileType = ""
End Sub
Public function UploadFileName()
Dim lngTime,strDate
strDate=replace(cstr(Date()),"-","")
lngTime=clng(timer()*1000)
lngTime=lngTime+1
UploadFileName=strDate&lngTime
FileName=Mid(FileName,instr(FileName,"."))
UploadFileName=UploadFileName&FileName
End function
Public function SaveAs(FullPath)
dim dr,ErrorChar,i,SaveFileName
SaveAs=true
if trim(fullpath)="" or FileStart=0 or FileName="" then exit function
set dr=CreateObject("Adodb.Stream")
dr.Mode=3
dr.Type=1
dr.Open
Data_Upload.position=FileStart
Data_Upload.to dr,FileSize
dr.SaveToFile Server.MapPath(FullPath),2
dr.Close
set dr=nothing
SaveAs=false
End function
End Class
%>
--------------------------
上傳文件處理頁面
--------------------------
<!--#include file="Up.asp"-->
<%
...
myPath="" '設置你要上傳到的文件夾位置
set file=upLoad.file("filePath")
if file.FileSize>0 then
file.SaveAs myPath & file.UploadFileName
....
%>
如果對您有幫助,請記得採納為滿意答案,謝謝!祝您生活愉快!
vaela
C. 如何在實現本地調試php源碼,具體的操作
首先確定你已經在本機安裝了PHP與MYSQL,可以使用WAMP整合安裝。安裝完成後C:\wamp\www默認就是站點文件夾(在安裝時會提示,建議不要修改)。雙擊C:\wamp中的wamp.exe就可以啟動wamp了(可以修改成中文),如果不能啟動檢查是不是埠被佔用,一切正常後就Dreamweaver進行PHP的編寫與調式了。打開Dreamweaver後首先要建立站點。站點新建的主要過程如下:
管理站點->新建站點->高級標簽->本地信息中輸入站點名,選擇本地根文件夾(就是C:\wamp\www),選擇圖像文件夾在www中新一個images文件夾並指定就可以了,http地址改為http://localhost ->遠程信息中,訪問:本地/網路,無端文件夾選擇c:\wamp\www ->測試伺服器中,伺服器模型選擇PHP MySql,訪問選擇本地/網路 ->確定。
這樣就可以了,如果還是不行的話就將http://localhost改成http://127.0.0.1。
D. php 源碼怎麼本地調試
PHP本地測試,解決你的問題主要有2種思路:
1、Windows系統下實現。
(1)去網上搜索wamp集成環境包,下載後安裝在電腦里。這個集成軟體包括了php5, apache伺服器,mysql資料庫,是windows系統下使用的。
(2)如果你不想用,也可以下載以上3個軟體,然後進行自行安裝。這種情況下,可以使用windows的IIS伺服器,或apache伺服器,教程網上有,你可以自己找下。
2、Linux系統下進行測試。
那麼你需要自已在電腦原有windows系統下安裝Linux系統,Linux可以與windows並存,也可以在虛擬機里安裝。然後,在Linux下安裝php5,apache伺服器,ok後就可以進行本地開發和測試了。
記得給分!!!
E. php面試題一般是筆寫還是電腦上回答卷子
某大公司的PHP面試題
管理提醒: 本帖被 haowu 執行取消置頂操作(2009-07-30)
1. 如何用php的環境變數得到一個網頁地址的內容?ip地址又要怎樣得到?
[php]
echo $_SERVER ['PHP_SELF'];
echo $_SERVER ['SERVER_ADDR'];
[/php]
2. 求兩個日期的差數,例如2007-2-5 ~ 2007-3-6 的日期差數
[php]
$begin=strtotime('2007-2-5');
$end=strtotime('2007-3-6');
echo ($end-$begin)/(24*3600);
[/php]
3. 請寫一個函數,實現以下功能:
字元串「open_door」 轉換成 「OpenDoor」、」make_by_id」 轉換成 」MakeById」。
[php]
function changeStyle(& $str) {
/*$str = str_replace ( "_", " ", $str );
$str = ucwords ( $str );
$str = str_replace ( " ", "", $str );
return $str;*/
$arrStr=explode('_',$str);
foreach($arrStr as $key=>$value){
$arrStr[$key]=strtoupper(substr($value,0,1)).substr($value,1);
}
return implode('',$arrStr);
}
$s = "open_door";
echo changeStyle ( $s );
[/php]
4. 要求寫一段程序,實現以下數組$arr1轉換成數組$arr2:
[php]$arr1 = array (
'0' => array ('fid' => 1, 'tid' => 1, 'name' =>'Name1' ),
'1' => array ('fid' => 1, 'tid' => 2 , 'name' =>'Name2' ),
'2' => array ('fid' => 1, 'tid' => 5 , 'name' =>'Name3' ),
'3' => array ('fid' => 1, 'tid' => 7 , 'name' =>'Name4' ),
'4' => array ('fid' => 3, 'tid' => 9, 'name' =>'Name5' )
);
$arr2 = array (
'0' => array (
'0' => array ( 'tid' => 1, 'name' => 'Name1'),
'1' => array ( 'tid' => 2, 'name' => 'Name2'),
'2' => array ( 'tid' => 5, 'name' => 'Name3'),
'3' => array ( 'tid' => 7, 'name' => 'Name4')
),
'1' => array (
'0' => array ( 'tid' => 9, 'name' => 'Name5' )
)
);
<?php
$arr1 = array (
'0' => array ('fid' => 1, 'tid' => 1, 'name' =>'Name1' ),
'1' => array ('fid' => 1, 'tid' => 2 , 'name' =>'Name2' ),
'2' => array ('fid' => 1, 'tid' => 5 , 'name' =>'Name3' ),
'3' => array ('fid' => 1, 'tid' => 7 , 'name' =>'Name4' ),
'4' => array ('fid' => 3, 'tid' => 9, 'name' =>'Name5' )
);
function changeArrayStyle($arr){
foreach($arr as $key=>$value){
$result[$value['fid']][]=$value;
}
return array_values($result);
}
$arr2=changeArrayStyle($arr1);
echo "<pre>";
var_mp($arr2);
[/php]
5. 請簡述資料庫設計的範式及應用。
一般第3範式就足以,用於表結構的優化,這樣做既可以避免應用程序過於復雜同時也避免了SQL語句過於龐大所造成系統效率低下。
ANSWER:
第一範式:若關系模式R的每一個屬性是不可再分解的,再屬於第一範式。
第二範式:若R屬於第一範式,且所有的非碼屬性都完全函數依賴於碼屬性,則為第二範式。
第三範式:若R屬於第二範式,且所有的非碼屬性沒有一個是傳遞函數依賴於候選碼,則屬於第三範式。
6.一個表中的Id有多個記錄,把所有這個id的記錄查出來,並顯示共有多少條記錄數,用SQL語句及視圖、存儲過程分別實現。
存儲過程:
[php]
DELIMITER //
create procere proc_countNum(in columnId int,out rowsNo int)
begin
select count(*) into rowsNo from member where member_id=columnId;
end
call proc_countNum(1,@no);
select @no;
[/php]
視圖:
create view v_countNum as select member_id,count(*) as countNum from member group by member_id
select countNum from v_countNum where member_id=1
7 表中有A B C三列,用SQL語句實現:當A列大於B列時選擇A列否則選擇B列,當B列大於C列時選擇B列否則選擇C列。
[php]select
case
when first_name>middle_name then
case when first_name>last_name then first_name
else last_name end
else
case when middle_name>last_name then middle_name else last_name
end
end as name
from member
[/php]
8請簡述項目中優化sql語句執行效率的方法,從哪些方面,sql語句性能如何分析?
ANSWER: sql優化有鳥用,不如直接加索引。
9 如果模板是用smarty模板。怎樣用section語句來顯示一個名為$data的數組。比如:
[php]$data = array(
[0] => array( [id]=8 [name]=』name1′)
[1] => array( [id]=10 [name]=』name2′)
[2] => array( [id]=15 [name]=』name3′)
……
)[/php]
寫出在模板頁的代碼? 若用foreach語句又要怎樣顯示呢?
占無答案.
10 寫一個函數,能夠遍歷一個文件夾下的所有文件和子文件夾。(目錄操作)
[php] <?php
$d = dir(dirname(__file__));
//echo "Handle: " . $d->handle . "\n";
//echo "Path: " . $d->path . "\n";
while ( false !== ($entry = $d->read ()) ) {
echo $entry . "<br />";
}
$d->close ();
[/php]
11 兩張表 city表和province表。分別為城市與省份的關系表。
city:
id City Provinceid
1 廣州 1
2 深圳 1
3 惠州 1
4 長沙 2
5 武漢 3
………. 廣州
province:
id Province
1 廣東
2 湖南
3 湖北
……….
(1) 寫一條sql語句關系兩個表,實現:顯示城市的基本信息。?
(2) 顯示欄位:城市id ,城市名, 所屬省份 。
如:
Id(城市id) Cityname(城市名) Privence(所屬省份)
。。。。。。。。。
。。。。。。。。。
(2)如果要統計每個省份有多少個城市,請用group by 查詢出來。?
顯示欄位:省份id ,省份名,包含多少個城市。
ANSWER:
1.select A.id,A.Cityname,B.Province from city A,province B where A.provinceid=B.id
2.select B.id,B.Province,count(*) as num from city A,province B where A.provinceid=B.id group by B.id
12. 按照你的經驗請簡述軟體工程進行軟體開發的步驟。以下工具Rational Rose、PowerDesigner、Project、VSS或CVS、TestDirector使用過那種,有缺點是什麼?
公司用dbdesigner及cvs,測試管理工具用的是Mantis
13. 請簡述操作系統的線程與進程的區別。列舉LINUX下面你使用過的軟體?
14. 請使用偽語言結合數據結構冒泡排序法對以下一組數據進行排序 10 2 36 14 10 25 23 85 99 45。
[php]function bubble_sort(& $arr){
$number=count($arr);
for($i=0;$i<$number-1;$i++){
for($j=0;$j<$number-1-$i;$j++){
if($arr[$j]>$arr[$j+1]){
$tmp=$arr[$j];
$arr[$j]=$arr[$j+1];
$arr[$j+1]=$tmp;
}
}
}
}
$str="10 2 36 14 10 25 23 85 99 45";
$arr=explode(" ",$str);
bubble_sort($arr);
echo "<pre>";
var_mp($arr);
[/php]
F. 如果在本機測試PHP網站源碼
估計IIS你是會用了,因為ASP的調試都能正常使用,建議你安裝「PHP Setup for IIS PHP集成環境」,這樣asp和php就會同時在IIS中可用
這里有我寫的「PHP Setup for IIS PHP集成環境」詳細的安裝教程:
http://news.2ky.cn/50/PHP_Setup_for_IIS.htm