PHP+MySQL+Dreamweaver整合教學(PHPMaker運用設計網站教學):快速設計網站與網頁
總教頭特別企畫【專業整合課程】比傳統的學習的還要快速與實用!


感謝您造訪 PHP程式設計+MySQL資料庫+Dreamweaver整合教學(PHPMaker運用設計網站教學)密訓基地。 你可進入教學詳細內容介紹頁面,詳細瞭解PHP程式設計+MySQL資料庫(PHPMaker運用設計網站教學)及相關技術維護影片教學(完整配套措施),馬上可以設計架站程式與PHP網頁,快速建立MySQL資料庫、自動生成PHP網頁。可對資料庫進行瀏覽、修改、查詢、加入和刪除(整合成我們需要的網站)。

要在網路上經營網站賺大錢,不能只會下載現有的程式來架站(自己設計才能完全符合專業的特殊需求),你不用死背PHP語法,更可以完全不用花錢用購買資料庫(PHPMySQL完全免費!)你可以透過技術學習,讓PHP程式網頁+網路資料庫+Dreamweaver整合教學→讓你快速成為:【動態網站程式設計專家→你能因此賺大錢】!

 PHP程式設計+MySQL資料庫+Dreamweaver整合教學(PHPMaker運用設計網站教學):

http://por.tw/php/new-E_learning/index.php


PHP程式設計+MySQL資料庫+Dreamweaver整合教學(PHPMaker運用教學)密訓基地  總教頭  敬上



  • 1 
瀏覽模式: 普通 | 列表

您還在自己(死背PHP與MySQL語法)嗎?別傻了!最快速的生成軟體來了!
有些人,在學校學的是:資訊科系(您要花3-4年才能畢業),畢業後...上班第一天就被:革職了!
為何社會如此嚴苛?老闆為何不給您年輕人機會?
不是老闆嚴苛,而是學校誤人子弟!
目前大專院校(死背PHP與MySQL語法),學了3-4年才能畢業(就然學一些過時的技術)
傳統設計pHP程式網站(人工輸入PHP與MySQL語法),一個專案要搞好幾個星期(有時還搞不定)?
相同的PHP網站專案,別人用『PHPMake』一天搞定!
請問:老闆要一個專案要搞好幾個星期(有時還搞不定)的員工嗎?
請認清事實:不是社會無情!一切都要講求成本與效率!
公司不是慈善機構,花薪水聘任員工,當然要聘用:最好.最強.最有效率的員工!

PHPMaker是一個強大的自動化工具,可以從MySQL,PostgreSQL,Microsoft Access和Microsoft SQL Server資料庫快速生成一整套PHP。
使用PHPMaker,您可以立即建立網站,容許使用者在網路上檢視,編輯,搜尋,加入和刪除記錄。


 

PHPMaker設計用於高彈性,眾多選項使您能夠生成最適合您需求的PHP應用程式。生成的代碼是乾淨,易於理解和易於定制的。

PHP腳本可以在Windows伺服器(MySQL / PostgreSQL / Access / MSSQL)或Linux / Unix伺服器(MySQL / PostgreSQL)上運行。
PHPMaker可以節省大量的時間,適合初學者和經驗豐富的開發人員。

這裡有『總教頭』的中文教學課程:

http://por.tw/php/new-E_learning/index.php

以下是“PHPMaker”的一些主要功能:
- 所有腳本都正確連結
- 可選清單,為每個表/檢視加入/複製,檢視,編輯,刪除,多重更新和搜尋頁面。 (見表格設定)可訂做的表格顯示順序。
- 清單頁面中可選的網格加入,網格編輯,內聯加入,內聯複製,內聯刪除,內聯編輯
- 插入或更新記錄之前的可選確認頁面
- 清單/檢視頁面中的尋呼機
- 每個欄位的完全可定制的檢視和編輯格式。 (請參閱現場設定)可定制的欄位顯示順序。
- 伺服器端驗證和/或用戶端JavaScript驗證
- 可選搜尋功能(快速,延伸快速和進階)與搜尋結果突出顯示
- 可選的使用者ID和使用者層級進階安全性,以保護資料免遭未經授權的訪問。 (請參閱安全設定)支援動態使用者層級和分級父級使用者ID。
- 完成使用者註冊系統,可選使用者啟動
- 可選的HTML設定。字集,字型,CSS,可訂做的主題與預覽。 (見HTML設定)
- 選單編輯器
- 多個主/詳細頁面
- 各種PHP選項。字集,區功能變數設定,預設日期格式等。 (見PHP設定)
- 從項目檔案中儲存和恢復項目
- 將項目設定與資料庫中的變更同步。
- 自動在IIS中建立虛擬目錄
- CSS樣式表整合
- 欄位聚合(總和,平均和計數)
- 內建視覺查詢構建器的訂做檢視
- 基本報告
- 從清單/檢視頁面匯出到列印友好/ HTML / Word / Excel / CSV / XML

- 多列排序
- 使用者可選的頁面大小
- 表特定清單頁面選項
- 檔案上傳到資料夾和資料庫
- 動態表加載
- 複合鍵
- 突出顯示並選取行彩色
- 自動建議文字方塊
- 自動填充在選取尋找欄位的值時填充關聯的欄位值
- 動態加入選取清單選項
- 具有多種選取支援的動態選取清單(SELECT,RADIO和CHECKBOX)
- 自動登入和自動重定向
- 多頁面加入/編輯/檢視頁面作為頁面標題的標籤頁
- 審計追蹤
- 加入/編輯/刪除的電子信件知會
- 可選CAPTCHA系統
- 檔案上傳到資料夾和資料庫
- 動態表加載
- 伺服器事件和用戶端腳本
- 代碼庫
- MD5和區分大小寫的密碼
- 完全可定制的模板和延伸

PHPMaker is a powerful automation tool that can generate a full set of PHP quickly from MySQL, PostgreSQL, Microsoft Access and Microsoft SQL Server databases. Using PHPMaker, you can instantly create web sites that allow users to view, edit, search, add and delete records on the web.

PHPMaker is designed for high flexibility, numerous options enable you to generate PHP applications that best suits your needs.The generated codes are clean, easy to understand and easily customizable.

The PHP scripts can be run on Windows servers (MySQL/PostgreSQL/Access/MSSQL) or Linux/Unix servers (MySQL/PostgreSQL). PHPMaker can save you tons of time and is suitable for both beginners and experienced develpers alike.

Here are some key features of "PHPMaker":
- All scripts linked up properly
- Optional list, add/copy, view, edit, delete, multi-update and search pages for each table/view. (See Table Setup) Customizable table display order.
- Optional Grid-Add, Grid-Edit, Inline-Add, Inline-Copy, Inline-Delete, Inline-Edit right in the List page
- Optional confirmation page before insering or updating record
- Pagers in List/View page
- Fully customizable View and Edit format for each field. (See Field Setup) Customizable field display order.
- Server-side validation and/or client-side JavaScript validation
- Optional search features (Quick, Extended Quick and Advanced) with search result highlight
- Optional User ID and User Level Advanced Security to protect data from unauthorized access. (See Security Settings) Supports Dynamic User Levels and Hierarchical Parent User ID.
- Complete user registration system with optional user activation
- Optional HTML settings. charset, font, CSS, customizable themes with preview. (See HTML Settings)
- Menu Editor
- Multiple Master/Detail pages
- Various PHP options. Charset, locale, default date formats, etc . (See PHP Settings)
- Saving and restoring project from Project File
- Synchronize project settings with changes in database.
- Creates virtual directory in IIS automatically
- CSS stylesheet integration
- Field aggregation (sum, average and count)
- Custom View with built-in visual query builder
- Basic reporting
- Export to Printer-friendly/HTML/Word/Excel/CSV/XML from List/View page
- Multi-column sorting
- User selectable page size
- Table-specific List page options
- File uploading to folder and database
- Dynamic table loading
- Composite key
- Highlight and select row color
- Auto-Suggest textbox
- Auto-Fill for filling related field values on selecting a value for a lookup field
- Adding option to Selection List dynamically
- Dynamic Selection List with multiple selection support (SELECT, RADIO and CHECKBOX)
- Auto-login and Auto-Redirect
- Multi-page add/edit/view pages as tabs with page captions
- Audit Trail
- Email Notification on Add/Edit/Delete
- Optional CAPTCHA system
- File uploading to folder and database
- Dynamic table loading
- Server events and client scripts
- Code repository
- MD5 and case-sensitive password
- Fully customizable template and extensions

(PHP程式設計)開發提高效率的技巧

【文章內容】:(PHP程式設計)開發提高效率的技巧

0、用單引號代替雙引號來包括字串,這樣做會更快一些。
因為PHP會在雙引號包圍的字串中搜尋變量,單引號則不會,注意:只有echo能這麼做,它是一種可以把多個字串當作參數的「函數」
(譯註:PHP手冊中說echo是語系結構,不是真正的函數,故把函數加上了雙引號)。

1、如果能將類的方法定義成static,就盡量定義成static,它的速度會提升將近4倍。

2、$row['ID']的速度是$row[id]的7倍。

3、echo 比 print 快,並且使用echo的多重參數(譯註:指用逗號而不是句點)代替字串連線,比如echo $str1,$str2。

4、在執行for迴圈之前確定最大迴圈數,不要每迴圈一次都計算最大值,最好運用foreach代替。

5、註銷那些不用的變量尤其是大陣列,以便釋放記憶體。

6、盡量避免使用__get,__set,__autoload。

7、require_once()代價昂貴。

8、include檔案時盡量使用絕對路徑,因為它避免了PHP去include_path裡尋找檔案的速度,解析操作系統路徑所需的時間會更少。

9、如果你想知道腳本開始執行(譯註:即伺服器端收到用戶端請求)的時刻,使用$_SERVER[『REQUEST_TIME』]要好於time()。

10、函數代替正則表達式完成相同功能。

11、str_replace函數比preg_replace函數快,但strtr函數的效率是str_replace函數的四倍。

12、如果一個字串取代函數,可接受陣列或字元作為參數,並且參數長度不太長,那麼可以考慮額外寫一段取代代碼,使得每次傳遞參數是一個字元,而不是只寫一行代碼接受陣列作為查詢和取代的參數。

13、使用選取分支語句(譯註:即switch case)好於使用多個if,else if語句。

14、用@屏蔽錯誤訊息的做法非常低效,極其低效。

15、開啟apache的mod_deflate模組,可以提高網頁的瀏覽速度。

16、資料庫連線當使用完畢時應關掉,不要用長連線。

17、錯誤訊息代價昂貴。

18、在方法中遞增局部變量,速度是最快的。幾乎與在函數中呼叫局部變量的速度相當。

19、遞增一個全局變量要比遞增一個局部變量慢2倍。

20、遞增一個物件屬性(如:$this->prop++)要比遞增一個局部變量慢3倍。

21、遞增一個未預定義的局部變量要比遞增一個預定義的局部變量慢9至10倍。

22、僅定義一個局部變量而沒在函數中呼叫它,同樣會減慢速度(其程度相當於遞增一個局部變量)。PHP大概會檢檢視是否存在全局變量。

23、方法呼叫看來與類中定義的方法的數量無關,因為我(在測試方法之前和之後都)加入了10個方法,但效能上沒有變化。

24、派生類中的方法運行起來要快於在基類中定義的同樣的方法。

25、呼叫帶有一個參數的空函數,其花費的時間相當於執行7至8次的局部變量遞增操作。類似的方法呼叫所花費的時間接近於15次的局部變量遞增操作。

attachments/201307/7238334217.jpg

--------------------------------------------------------------------------------
【文章標題】: (PHP程式設計)開發提高效率的技巧
【文章作者】: PHP程式設計+MySQL資料庫+Dreamweaver整合教學密訓基地
【作者信箱】: ster168ster@gmail.com
【作者首頁】: http://por.tw/php/
【PHP程式設計+MySQL資料庫+Dreamweaver整合教學課程】: http://por.tw/php/new-E_learning/index.php
【基地主機】: http://goto1688.com/php/
【版權聲明】: (原創)PHP程式設計+MySQL資料庫+Dreamweaver整合教學密訓基地,轉載必須保留完整標頭。刪除者依法追究!

--------------------------------------------------------------------------------
26、Apache解析一個PHP腳本的時間要比解析一個靜態HTML頁面慢2至10倍。盡量多用靜態HTML頁面,少用腳本。

27、除非腳本可以快取,否則每次呼叫時都會重新編譯一次。引入一套PHP快取機制通常可以提升25%至100%的效能,以免除編譯開銷。

28、盡量做快取,可使用memcached。memcached是一款高效能的記憶體物件快取系統,可用來加速動態Web應用程式,減輕資料庫負載。對操作碼 (OP code)的快取很有用,使得腳本不必為每個請求做重新編譯。

29、當操作字串並需要檢驗其長度是否滿足某種要求時,你想當然地會使用strlen()函數。此函數執行起來相當快,因為它不做任何計算,只返回在zval 結構(C的內建資料結構,用於存儲PHP變量)中存儲的已知字串長度。但是,由於strlen()是函數,多多少少會有些慢,因為函數呼叫會經由諸多步驟,如字母小寫化(譯註:指函數名小寫化,PHP不區分函數名大小寫)、哈希尋找,會跟隨被呼叫的函數一起執行。在某些情況下,你可以使用isset() 技巧加速執行你的代碼。

(舉例如下)
if (strlen($foo) < 5) { echo “Foo is too short”$$ }
(與下面的技巧做比較)
if (!isset($foo{5})) { echo “Foo is too short”$$ }

呼叫isset()恰巧比strlen()快,因為與後者不同的是,isset()作為一種語系結構,意味著它的執行不需要函數尋找和字母小寫化。也就是說,實際上在檢驗字串長度的頂層代碼中你沒有花太多開銷。

34、當執行變量$i的遞增或遞減時,$i++會比++$i慢一些。這種差異是PHP特有的,並不適用於其他語系,所以請不要修改你的C或Java代碼並指望它們能立即變快,沒用的。++$i更快是因為它只需要3條指令(opcodes),$i++則需要4條指令。後置遞增實際上會產生一個臨時變量,這個臨時變量隨後被遞增。而前置遞增直接在原值上遞增。這是最改善處理的一種,正如Zend的PHP改善器所作的那樣。牢記這個改善處理不失為一個好主意,因為並不是所有的指令改善器都會做同樣的改善處理,並且存在大量沒有裝配指令改善器的網際網路服務提供商(ISPs)和伺服器。

35、並不是事必面向物件(OOP),面向物件往往開銷很大,每個方法和物件呼叫都會消耗很多記憶體。

36、並非要用類實現所有的資料結構,陣列也很有用。

37、不要把方法細分得過多,仔細想想你真正打算重用的是哪些代碼?

38、當你需要時,你總能把代碼分解成方法。

39、盡量採用大量的PHP內建函數。

40、如果在代碼中存在大量耗時的函數,你可以考慮用C延伸的模式實現它們。

41、評估檢驗(profile)你的代碼。檢驗器會告訴你,代碼的哪些部分消耗了多少時間。Xdebug除錯器包括了檢驗程式,評估檢驗總體上可以顯示出代碼的瓶頸。

42、mod_zip可作為Apache模組,用來即時壓縮你的資料,並可讓資料傳輸量降低80%。

43、在可以用file_get_contents替代file、fopen、feof、fgets等系列方法的情況下,盡量用file_get_contents,因為他的效率高得多!但是要注意file_get_contents在開啟一個URL檔案時候的PHP版本問題;

44、盡量的少進行檔案操作,雖然PHP的檔案操作效率也不低的;

45、改善Select SQL語句,在可能的情況下盡量少的進行Insert、Update操作(在update上,我被惡批過);

46、盡可能的使用PHP內定函數(但是我卻為了找個PHP裡面不存在的函數,浪費了本可以寫出一個自訂函數的時間,經驗問題啊!);

47、迴圈內定不要聲明變量,尤其是大變量:物件(這好像不只是PHP裡面要注意的問題吧?);

48、多維陣列盡量不要迴圈嵌套賦值;

49、在可以用PHP內定字串操作函數的情況下,不要用正則表達式;

50、foreach效率更高,盡量用foreach代替while和for迴圈;

51、用單引號替代雙引號引用字串;

52、「用i+=1代替i=i+1。符合c/c++的習慣,效率還高」;

53、對global變量,應該用完就unset()掉;

--------------------------------------------------------------------------------
你在摸索如何PHP程式設計+MySQL資料庫+Dreamweaver整合建構網站嗎?
有【技術顧問服務】可諮詢嗎?
當問題無法解決你要發很多時間處理(或許永遠找出答案)
那是自己摸索 PHP+MySQL+Dreamweaver整合痛苦開始!
購買【PHP程式設計+MySQL資料庫+Dreamweaver整合】DVD課程
就可獲得【PHP+MySQL+Dreamweaver】技術【顧問諮詢服務】!

 

php.ini中的php-5.2.0配置指令詳解

php.ini中的php-5.2.0配置指令詳解

本文並非是對英文版 php.ini 的簡單翻譯,而是參考了眾多資料以後,結合自己的理解,

在原有 php.ini 基礎上增加了一些實用模組的配置說明,同時對檔案內容的安排進行了調整。

由於作者不喜歡 no-free 的玩意兒,所以刪除了除 MySQL 和 PostgreSQL 以外的其他資料庫模組配置選項。

關於php.ini ;;

這個檔案必須命名為''php.ini''並放置在httpd.conf中的PHPIniDir指令特殊的目錄中。

語法

該檔案的語法非常簡單。空白字元和以分號開始的行被簡單地忽略。

章節標題(例如: [php])也被簡單地忽略,即使將來它們可能有某種意義。

設定指令的格式如下:

directive = value

指令名(directive)是大小寫敏感的!所以"foo=bar"不同於"FOO=bar"。

值(value)可以是:

1. 用引號界定的字串(如:"foo")

2. 一個數字(整數或浮點數,如:0, 1, 34, -1, 33.55)

3. 一個PHP常量(如:E_ALL, M_PI)

4. 一個INI常量(On, Off, none)

5. 一個表達式(如:E_ALL & ~E_NOTICE)

INI檔案中的表達式僅使用:位運算符、邏輯非、圓括號:

| 位或

& 位與

~ 位非

! 邏輯非

布爾標誌用 On 表示開啟,用 Off 表示關閉。

一個空字串可以用在等號後不寫任何東西表示,或是用 none 關鍵字:

foo =     ; 將foo設為空字串

foo = none  ; 將foo設為空字串

foo = "none" ; 將foo設為字串''none''



如果你在指令值中使用動態延伸(PHP延伸或Zend延伸)中的常量,

那麼你只能在加載這些動態延伸的指令行之後使用這些常量。

httpd.conf ;;

還可以在httpd.conf中覆蓋php.ini的值,以進行更靈活的配置:

php_value name value ;設定非bool型的指令,將value設為none則清除先前的設定

php_flag name on|off ;僅用於設定bool型的指令



PHP常量(如E_ALL)僅能在php.ini中使用,在httpd.conf中必須使用相應的遮罩值。

帶"SYS"標誌的指令只能在httpd.conf中的全局配置部分使用,

帶"ini"標誌的指令不能在httpd.conf中使用,它們僅能用於php.ini中。

====================配置指令詳解========================================

以下每個指令的設定值都與 PHP-5.2.0 內建的預設值相同。

也就是說,如果''php.ini''不存在,或是你刪掉了某些行,預設值與之相同。

;;;;;;;;;;;;

Apache ;;

;;;;;;;;;;;;

[Apache]

僅在將PHP作為Apache模組時才有效。

engine = On

是否啟用PHP解析引擎。

可以在httpd.conf中基於目錄或是虛擬主電腦來開啟或是關閉PHP解析引擎。

last_modified = Off

是否在Last-Modified應答頭中放置該PHP腳本的最後修改時間。

xbithack = Off

是否不管檔案結尾是什麼,都作為PHP可執行位組來解析。

child_terminate = Off

PHP腳本在請求結束後是否容許使用apache_child_terminate()函數終止子程式。

該指令僅在UNIX平台上將PHP安裝為Apache1.3的模組時可用。其他情況下皆不存在。

;;;;;;;;;;;;;

PHP核心 ;;

;;;;;;;;;;;;;

[PHP-Core-DateTime]

前四個配置選項目前僅用於date_sunrise()和date_sunset()函數。

date.default_latitude = 31.7667

預設緯度

date.default_longitude = 35.2333

預設經度

date.sunrise_zenith = 90.583333

預設日出天頂

date.sunset_zenith = 90.583333

預設日落天頂

date.timezone =

未設定TZ環境變量時用於所有日期及時間函數的預設時區。

中國大陸應當使用"PRC"

應用時區的優先順序為:

1. 用date_default_timezone_set()函數設定的時區(如果設定了的話)

2. TZ 環境變量(如果非空的話)

3. 該指令的值(如果設定了的話)

4. PHP自己推測(如果操作系統支援)

5. 如果以上都不完成,則使用 UTC

[PHP-Core-Assert]

assert.active = On

是否啟用assert()斷言評估

assert.bail = Off

是否在發生失敗斷言時中止腳本的執行
 
回復 引用 舉報頂端  
落伍 離線
   

層級: 管理員
 
UID: 818
精華: 1
發帖: 232
金錢: 12043 金
威望: 293 點
貢獻值: 1 點
交易幣: 0 元
線上時間: 7(時)
註冊時間: 2008-09-18
最後登入: 2010-05-12  沙發  發表於: 2008-10-15    只看該作者 │  小 中 大


assert.callback =

發生失敗斷言時執行的回呼函數

assert.quiet_eval = Off

是否使用安靜評估(不顯示任何錯誤訊息,相當於error_reporting=0)。

若關閉則在評估斷言表達式的時候使用現用的的error_reporting指令值。

assert.warning = On

是否對每個失敗斷言都發出警示

[PHP-Core-SafeMode]

安全模式是為了解決共享伺服器的安全問題而設立的。

但試圖在PHP層解決這個問題在結構上是不合理的,

正確的做法應當是修改web伺服器層和操作系統層。

因此在PHP6中廢除了安全模式,並打算使用open_basedir指令取代之。

safe_mode = Off

SYS

是否啟用安全模式。

開啟時,PHP將檢查現用的腳本的擁有者是否和被操作的檔案的擁有者相同,

相同則容許操作,不同則拒絕操作。

safe_mode_gid = Off

SYS

在安全模式下,預設在訪問檔案時會做UID比較檢查。

但有些情況下嚴格的UID檢查反而是不適合的,寬鬆的GID檢查已經足夠。

如果你想將其放寬到僅做GID比較,可以開啟這個參數。

safe_mode_allowed_env_vars = "PHP_"

SYS

在安全模式下,使用者僅可以變更的環境變量的首碼清單(逗號分隔)。

容許使用者設定某些環境變量,可能會導致潛在的安全漏洞。

注意: 如果這一參數值為空,PHP將容許使用者變更任意環境變量!

safe_mode_protected_env_vars = "LD_LIBRARY_PATH"

SYS

在安全模式下,使用者不能變更的環境變量清單(逗號分隔)。

這些變量即使在safe_mode_allowed_env_vars指令設定為容許的情況下也會得到保護。

safe_mode_exec_dir = "/usr/local/php/bin"SYS

在安全模式下,只有該目錄下的可執行程式才容許被執行系統程式的函數執行。

這些函數是:system, escapeshellarg, escapeshellcmd, exec, passthru,

proc_close, proc_get_status, proc_nice, proc_open, proc_terminate, shell_exec

safe_mode_include_dir =

SYS

在安全模式下,該組目錄和其子目錄下的檔案被包括時,將略過UID/GID檢查。

換句話說,如果此處的值為空,任何UID/GID不符合的檔案都不容許被包括。

這裡設定的目錄必須已經存在於include_path指令中或是用完整路徑來包括。

多個目錄之間用冒號(Win下為分號)隔開。

特殊的限制實際上是一個首碼,而非一個目錄名,

也就是說"/dir/incl"將容許訪問"/dir/include"和"/dir/incls"

如果您希望將訪問控制在一個特殊的目錄,那麼請在結尾加上斜線。

sql.safe_mode = Off

SYS

是否使用SQL安全模式。

如果開啟,指定預設值的資料庫連線函數將會使用這些預設值代替支援的參數。

對於每個不同資料庫的連線函數,其預設值請參考相應的手冊頁面。

[PHP-Core-Safe]

allow_url_fopen = On

ini

是否容許開啟遠端檔案

allow_url_include = Off

SYS

是否容許include/require遠端檔案。

disable_classes =

ini

該指令接受一個用逗號分隔的類名清單,以禁用特定的類。

disable_functions =

ini

該指令接受一個用逗號分隔的函數名清單,以禁用特定的函數。

enable_dl = On

SYS

是否容許使用dl()函數。dl()函數僅在將PHP作為apache模組安裝時才有效。

禁用dl()函數主要是出於安全考慮,因為它可以繞過open_basedir指令的限制。

在安全模式下始終禁用dl()函數,而不管此處如何設定。

expose_php = On

ini

是否暴露PHP被安裝在伺服器上的事實(在http頭中加上其簽名)。

它不會有安全上的直接威脅,但它使得用戶端知道伺服器上安裝了PHP。

open_basedir =

SYS

將PHP容許操作的所有檔案(內含檔案自身)都限制在此組目錄清單下。

當一個腳本試圖開啟一個指定目錄樹之外的檔案時,將遭到拒絕。

所有的符號連線都會被解析,所以不可能通過符號連線來避開此限制。

特殊值''.''指定了存放該腳本的目錄將被當做基準目錄。

但這有些危險,因為腳本的工作目錄可以輕易被chdir()改變。

對於共享伺服器,在httpd.conf中靈活設定該指令將變得非常有用。

在Windows中用分號分隔目錄,UNIX系統中用冒號分隔目錄。

作為Apache模組時,父目錄中的open_basedir路徑將自動被繼承。

特殊的限制實際上是一個首碼,而非一個目錄名,

也就是說"/dir/incl"將容許訪問"/dir/include"和"/dir/incls",

如果您希望將訪問控制在一個特殊的目錄,那麼請在結尾加上一個斜線。

預設是容許開啟所有檔案。

[PHP-Core-Error]

error_reporting = E_ALL & ~E_NOTICE  
回復 引用 舉報頂端  
落伍 離線
   

層級: 管理員
 
UID: 818
精華: 1
發帖: 232
金錢: 12043 金
威望: 293 點
貢獻值: 1 點
交易幣: 0 元
線上時間: 7(時)
註冊時間: 2008-09-18
最後登入: 2010-05-12  2樓  發表於: 2008-10-15    只看該作者 │  小 中 大


錯誤報告層級是位欄位的疊加,推薦使用 E_ALL | E_STRICT

1 E_ERROR       致命的運行時錯誤

2 E_WARNING      運行時警示(非致命性錯誤)

4 E_PARSE       編譯時解析錯誤

8 E_NOTICE      運行時提醒(經常是bug,也可能是有意的)

16 E_CORE_ERROR    PHP啟動時起始化過程中的致命錯誤

32 E_CORE_WARNING   PHP啟動時起始化過程中的警示(非致命性錯)

64 E_COMPILE_ERROR   編譯時致命性錯

128 E_COMPILE_WARNING  編譯時警示(非致命性錯)

256 E_USER_ERROR    使用者自訂的致命錯誤

512 E_USER_WARNING   使用者自訂的警示(非致命性錯誤)

1024 E_USER_NOTICE    使用者自訂的提醒(經常是bug,也可能是有意的)

2048 E_STRICT      編碼標準化警示(建議如何修改以向前相容)

4096 E_RECOVERABLE_ERROR 接近致命的運行時錯誤,若未被捕獲則視同E_ERROR

6143 E_ALL        除E_STRICT外的所有錯誤(PHP6中為8191,即包括所有)

track_errors = Off

是否在變量$php_errormsg中儲存最近一個錯誤或警示訊息。

display_errors = On

是否將錯誤訊息作為輸出的一部分顯示。

在最終發佈的web站台上,強烈建議你關掉這個特性,並使用錯誤日誌代替(參看下面)。

在最終發佈的web站台開啟這個特性可能暴露一些安全訊息,

例如你的web服務上的檔案路徑、資料庫規劃或別的訊息。

display_startup_errors = Off

是否顯示PHP啟動時的錯誤。

即使display_errors指令被開啟,關閉此參數也將不顯示PHP啟動時的錯誤。

建議你關掉這個特性,除非你必須要用於除錯中。

report_memleaks = On

是否報告記憶體洩漏。這個參數只在以除錯模式編譯的PHP中起作用,

並且必須在error_reporting指令中包括 E_WARNING

report_zend_debug = On

尚無說明文件

html_errors = On

是否在出錯訊息中使用HTML標示。

注意: 不要在發佈的站台上使用這個特性!

docref_root = ;"http://localhost/phpmanual/"

docref_ext =  ;".html"

如果開啟了html_errors指令,PHP將會在出錯訊息上顯示超連線,

直接連結到一個說明這個錯誤或是導致這個錯誤的函數的頁面。

你可以從http://www.php.net/docs.php下載php手冊,

並將docref_root指令指向你本地的手冊所在的URL目錄。

你還必須設定docref_ext指令來指定檔案的副檔名(必須含有''.'')。

注意: 不要在發佈的站台上使用這個特性。

error_prepend_string = ;"<font color=#f00>"

用於錯誤訊息前輸出的字串

error_append_string =  ;"</font>"

用於錯誤訊息後輸出的字串

xmlrpc_errors = Off

xmlrpc_error_number = 0

尚無文件

[PHP-Core-Logging]

define_syslog_variables = Off

是否定義各種系統日誌變量,如:$LOG_PID, $LOG_CRON 等等。

關掉它以提高效率的好主意。

你可以在運行時呼叫define_syslog_variables()函數來定義這些變量。

error_log =

將錯誤日誌記錄到哪個檔案中。該檔案必須對Web伺服器使用者可寫。

syslog 表示記錄到系統日誌中(NT下的事件日誌, Unix下的syslog(3))

如果此處未設定任何值,則錯誤將被記錄到Web伺服器的錯誤日誌中。

log_errors = Off

是否在記錄檔案裡記錄錯誤,具體在哪裡記錄取決於error_log指令。

強烈建議你在最終發佈的web站台時使用日誌記錄錯誤而不是直接輸出,

這樣可以讓你既知道那裡出了問題,又不會暴露敏感訊息。

log_errors_max_len = 1024

設定錯誤日誌中附加的與錯誤訊息關聯聯的錯誤源的最大長度。

這裡設定的值對顯示的和記錄的錯誤以及$php_errormsg都有效。

設為 0 可以容許無限長度。

ignore_repeated_errors = Off

記錄錯誤日誌時是否忽略重複的錯誤訊息。

錯誤訊息必須出現在同一檔案的同一行才被被視為重複。

ignore_repeated_source = Off

是否在忽略重複的錯誤訊息時忽略重複的錯誤源。

[PHP-Core-Mail]

要使信件函數可用,PHP必須在編譯時能夠訪問sendmail程式。

如果使用其它的信件程式,如qmail或postfix,確保使用了相應的sendmail包裝。

PHP首先會在系統的PATH環境變量中搜尋sendmail,接著按以下順序搜尋:

/usr/bin:/usr/sbin:/usr/etc:/etc:/usr/ucblib:/usr/lib

強烈建議在PATH中能夠找到sendmail。

另外,編譯PHP的使用者必須能夠訪問sendmail程式。

SMTP = "localhost"

mail()函數中用來傳送信件的SMTP伺服器的主電腦名稱或是IP位址。僅用於win32。

smtp_port = 25

SMTP伺服器的埠號。僅用於win32。

sendmail_from =

傳送信件時使用的"From:"頭中的信件位址。僅用於win32

該選項還同時設定了"Return-Path:"頭。

sendmail_path = "-t -i"

SYS

僅用於unix,也可支援參數(預設的是''sendmail -t -i'')

sendmail程式的路徑,通常為"/usr/sbin/sendmail或/usr/lib/sendmail"。

configure腳本會嘗試找到該程式並設定為預設值,但是如果失敗的話,可以在這裡設定。

不使用sendmail的系統應將此指令設定為sendmail替代程式(如果有的話)。

例如,Qmail使用者通常可以設為"/var/qmail/bin/sendmail"或"/var/qmail/bin/qmail-inject"。

qmail-inject 不需要任何選項就能正確處理信件。

mail.force_extra_parameters =

作為額外的參數傳遞給sendmail庫的強制特殊的參數附加值。

這些參數總是會取代掉mail()的第5個參數,即使在安全模式下也是如此。

[PHP-Core-ResourceLimit]

default_socket_timeout = 60

預設socket逾時(秒)

max_execution_time = 30

每個腳本最大容許執行時間(秒),0 表示沒有限制。

這個參數有助於阻止劣質腳本無休止的佔用伺服器資源。

該指令僅影響腳本本身的運行時間,任何其它花費在腳本運行之外的時間,

如用system()/sleep()函數的使用、資料庫查詢、檔案上傳等,都不內含在內。

在安全模式下,你不能用ini_set()在運行時改變這個設定。  

memory_limit = 16M

一個腳本所能夠申請到的最大記憶體位元組數(可以使用K和M作為單位)。

這有助於防止劣質腳本消耗完伺服器上的所有記憶體。

要能夠使用該指令必須在編譯時使用"--enable-memory-limit"配置選項。

如果要取消記憶體限制,則必須將其設為 -1 。

設定了該指令後,memory_get_usage()函數將變為可用。

max_input_time = -1

每個腳本解析輸入資料(POST, GET, upload)的最大容許時間(秒)。

-1 表示不限制。

post_max_size = 8M

容許的POST資料最大位元組長度。此設定也影響到檔案上傳。

如果POST資料超出限制,那麼$_POST和$_FILES將會為空。

要上傳大檔案,該值必須大於upload_max_filesize指令的值。

如果啟用了記憶體限制,那麼該值應當小於memory_limit指令的值。

realpath_cache_size = 16K

SYS

指定PHP使用的realpath(規範化的絕對路徑名)緩沖區大小。

在PHP開啟大量檔案的系統上應當增大該值以提高效能。

realpath_cache_ttl = 120

SYS

realpath緩沖區中訊息的有效期(秒)。

對檔案很少變動的系統,可以增大該值以提高效能。

[PHP-Core-FileUpLoad]

file_uploads = On

SYS

是否容許HTTP檔案上傳。

參見upload_max_filesize, upload_tmp_dir, post_max_size指令

upload_max_filesize = 2M

容許上傳的檔案的最大尺寸。

upload_tmp_dir =

SYS

檔案上傳時存放檔案的臨時目錄(必須是PHP程式使用者可寫的目錄)。

如果未指定則PHP使用系統預設的臨時目錄。

[PHP-Core-MagicQuotes]

PHP6將取消魔術引號,相當於下列指令全部為 Off

magic_quotes_gpc = On

是否對輸入的GET/POST/Cookie資料使用自動字串轉義( '' "  NULL )。

這裡的設定將自動影響 $_GEST $_POST $_COOKIE 陣列的值。

若將本指令與magic_quotes_sybase指令同時開啟,則僅將單引號('')轉義為(''''),

其它特殊字元將不被轉義,即( "  NULL )將保持原樣!!

建議關閉此特性,並使用自訂的過濾函數。

magic_quotes_runtime = Off

是否對運行時從外部資源產生的資料使用自動字串轉義( '' "  NULL )。

若開啟本指令,則大多數函數從外部資源(資料庫,文字檔案等)返回資料都將被轉義。

例如:用SQL查詢得到的資料,用exec()函數得到的資料,等等---www.bianceng.cn

若將本指令與magic_quotes_sybase指令同時開啟,則僅將單引號('')轉義為(''''),

其它特殊字元將不被轉義,即( "  NULL )將保持原樣!!

建議關閉此特性,並視具體情況使用自訂的過濾函數。

magic_quotes_sybase = Off

是否採用Sybase形式的自動字串轉義(用 '''' 表示 '')

[PHP-Core-HighLight]

highlight.bg = "#FFFFFF"

highlight.comment = "#FF8000"

highlight.default = "#0000BB"

highlight.html = "#000000"

highlight.keyword = "#007700"

highlight.string = "#DD0000"

語法高亮模式的色彩(通常用於顯示 .phps 檔案)。

只要能被<font color=xxx>接受的東西就能標準工作。

[PHP-Core-Langue]

short_open_tag = On

是否容許使用"<? ?>"短標識。否則必須使用"<?php ?>"長標識。

除非你的php程式僅在受控環境下運行,且只供自己使用,否則請不要使用短標示。

如果要和XML結合使用PHP,可以選取關閉此選項以方便直接內嵌"<?xml ... ?>",

不然你必須用PHP來輸出:<? echo ''<?xml version="1.0"''; ?>

本指令也會影響到縮寫形式"<?=",它和"<? echo"等價,要使用它也必須開啟短標示。

asp_tags = Off

是否容許ASP風格的標示"<% %>",這也會影響到縮寫形式"<%="。

PHP6中將刪除此指令

arg_separator.output = "&"

PHP所產生的URL中用來分隔參數的分隔設定。

另外還可以用"&"或","等等。

arg_separator.input = "&"

PHP解析URL中的變量時使用的分隔設定清單。

字串中的每一個字元都會被當作分割符。

另外還可以用",&"等等。

allow_call_time_pass_reference = On

是否強迫在函數呼叫時按引用傳遞參數(每次使用此特性都會收到一條警示)。

php反對這種做法,並在將來的版本裡不再支援,因為它影響到了代碼的整潔。

鼓勵的方法是在函數聲明裡明確指定哪些參數按引用傳遞。

我們鼓勵你關閉這一選項,以保證你的腳本在將來版本的語系裡仍能標準工作。

auto_globals_jit = On

是否僅在使用到$_SERVER和$_ENV變量時才建立(而不是在腳本一啟動時就自動建立)。

如果並未在腳本中使用這兩個陣列,開啟該指令將會獲得效能上的提升。

要想該指令生效,必須關閉register_globals和register_long_arrays指令。

auto_prepend_file =

auto_append_file =

指定在主檔案之前/後自動解析的檔名。為空表示禁用該特性。

該檔案就像呼叫了include()函數被包括進來一樣,因此會使用include_path指令的值。

注意:如果腳本通過exit()終止,那麼自動副檔名將不會發生。---www.bianceng.cn

variables_order = "EGPCS"

PHP註冊 Environment, GET, POST, Cookie, Server 變量的順序。

分別用 E, G, P, C, S 表示,按從左到右註冊,新值覆蓋舊值。

舉例說,設為"GP"將會導致用POST變量覆蓋同名的GET變量,

並完全忽略 Environment, Cookie, Server 變量。

推薦使用"GPC"或"GPCS",並使用getenv()函數訪問環境變量。

register_globals = Off

是否將 E, G, P, C, S 變量註冊為全局變量。

開啟該指令可能會導致嚴重的安全問題,除非你的腳本經由非常仔細的檢查。

推薦使用預定義的超全局變量:$_ENV, $_GET, $_POST, $_COOKIE, $_SERVER

該指令受variables_order指令的影響。

PHP6中已經刪除此指令。

register_argc_argv = On

是否聲明$argv和$argc全局變量(包括用GET方法的訊息)。

建議不要使用這兩個變量,並關掉該指令以提高效能。

register_long_arrays = On

是否啟用舊式的長式陣列(HTTP_*_VARS)。

鼓勵使用短式的預定義超全局陣列,並關閉該特性以獲得更好的效能。

PHP6中已經刪除此指令。

always_populate_raw_post_data = Off

是否總是生成$HTTP_RAW_POST_DATA變量(原始POST資料)。

否則,此變量僅在遇到不能識別的MIME類型的資料時才產生。

不過,訪問原始POST資料的更好方法是 php://input 。

$HTTP_RAW_POST_DATA對於enctype="multipart/form-data"的表單資料不可用。

unserialize_callback_func =

如果解序列化處理器需要案例化一個未定義的類,

這裡特殊的回呼函數將以該未定義類的名字作為參數被unserialize()呼叫,

以免得到不完整的"__PHP_Incomplete_Class"對象。

如果這裡沒有指定函數,或特殊的函數不包括(或實現)那個未定義的類,將會顯示警示訊息。

所以僅在確實需要實現這樣的回呼函數時才設定該指令。

若要禁止這個特性,只需置空即可。

y2k_compliance = On

是否強制開啟2000年適應(可能在非Y2K適應的瀏覽器中導致問題)。

zend.ze1_compatibility_mode = Off

是否使用相容Zend引擎I(PHP 4.x)的模式。

這將影響對象的複製、構造(無屬性的對象會產生FALSE或0)、比較。

相容模式下,物件將按值傳遞,而不是預設的按引用傳遞。

precision = 14

浮點型資料顯示的有效位數。

serialize_precision = 100

將浮點型和雙精度型資料序列化存儲時的精度(有效位數)。

預設值能夠確保浮點型資料被解序列化程式解碼時不會丟失資料。

[PHP-Core-OutputControl]

輸出控制函數很有用,特別是在已經輸出了訊息之後再傳送HTTP頭的情況下。

輸出控制函數不會作用於header()或setcookie()等函數傳送的HTTP頭,

而只會影響類似於echo()函數輸出的訊息和內嵌在PHP代碼之間的訊息。

implicit_flush = Off

是否要求PHP輸出層在每個輸出塊之後自動重整資料。

這等效於在每個 print()、echo()、HTML塊 之後自動呼叫flush()函數。

開啟這個選項對程式執行的效能有嚴重的影響,通常只推薦在除錯時使用。

在CLI SAPI的執行模式下,該指令預設為 On 。

output_buffering = 0

輸出緩沖區大小(位元組)。建議值為4096~8192。

輸出緩衝容許你甚至在輸出正文內容之後再傳送HTTP頭(內含cookies)。

其代價是輸出層減慢一點點速度。

設定輸出緩衝可以減少寫入,有時還能減少網路封包的傳送。

這個參數的實際收益很大程度上取決於你使用的是什麼Web伺服器以及什麼樣的腳本。

output_handler =

將所有腳本的輸出重導至一個輸出處理函數。

比如,重導至mb_output_handler()函數時,字元編碼將被透明地轉換為特殊的編碼。

一旦你在這裡指定了輸出處理程式,輸出緩衝將被自動開啟(output_buffering=4096)。

注意0: 此處僅能使用PHP內建的函數,自訂函數應在腳本中使用ob_start()指定。

注意1: 可移植腳本不能依賴該指令,而應使用ob_start()函數明確指定輸出處理函數。

使用這個指令可能會導致某些你不熟悉的腳本出錯。

注意2: 你不能同時使用"mb_output_handler"和"ob_iconv_handler"兩個輸出處理函數。

你也不能同時使用"ob_gzhandler"輸出處理函數和zlib.output_compression指令。

注意3: 如果使用zlib.output_handler指令開啟zlib輸出壓縮,該指令必須為空。

[PHP-Core-Directory]

doc_root =

SYS

PHP的"根目錄"。僅在非空時有效。

如果safe_mode=On,則此目錄之外的檔案一概被拒絕。

如果編譯PHP時沒有指定FORCE_REDIRECT,並且在非IIS伺服器上以CGI模式運行,

則必須設定此指令(參見手冊中的安全部分)。

替代專案是使用的cgi.force_redirect指令。

include_path = ".:/path/to/php/pear"

指定一組目錄用於require(), include(), fopen_with_path()函數尋找檔案。

格式和系統的PATH環境變量類似(UNIX下用冒號分隔,Windows下用分號分隔):

UNIX: "/path1:/path2"

Windows: "path1;path2"

在包括路徑中使用''.''可以容許相對路徑,它代表現用的目錄。

user_dir =

SYS

告訴php在使用 /~username 開啟腳本時到哪個目錄下去找,僅在非空時有效。

也就是在使用者目錄之下使用PHP檔案的基本目錄名,例如:"public_html"

extension_dir = "/path/to/php"

SYS

存放延伸庫(模組)的目錄,也就是PHP用來尋找動態延伸模組的目錄。

Windows下預設為"C:/php5"

[PHP-Core-HTTP]

default_mimetype = "text/html"

default_charset = ;"utf-8"

PHP預設會自動輸出"Content-Type: text/html" HTTP頭。

如果將default_charset指令設為"utf-8",

那麼將會自動輸出"Content-Type: text/html; charset=utf-8"。

[PHP-Core-Unicode]

detect_unicode = On

尚無文件

[PHP-Core-Misc]

auto_detect_line_endings = Off

是否讓PHP自動偵測行結束符(EOL)。

如果的你腳本必須處理Macintosh檔案,

或是你運行在Macintosh上,同時又要處理unix或win32檔案,

開啟這個指令可以讓PHP自動偵測EOL,以便fgets()和file()函數可以標準工作。

但同時也會導致在Unix系統下使用換行符(CR)作為項目分隔設定的人遭遇不相容行為。

cgi.rfc2616_headers = 0

指定PHP在傳送HTTP響應代碼時使用何種報頭。

0 表示傳送一個"Status: "報頭,Apache和其它web伺服器都支援。

若設為1,則PHP使用RFC2616標準的頭。

除非你知道自己在做什麼,否則保持其預設值 0

cgi.nph = Off

在CGI模式下是否強制對所有請求都傳送"Status: 200"狀態碼。

fastcgi.impersonate = Off

IIS中的FastCGI支援模仿用戶端安全令牌的能力。

這使得IIS能夠定義運行時所基於的請求的安全上下文。

Apache中的mod_fastcgi不支援此特性(03/17/2002)

如果在IIS中運行則設為On,預設為Off。

fastcgi.logging = On

是否記錄通過FastCGI進行的連線。

[PHP-Core-Weirdy]

這些選項僅存在於文件中,卻不存在於phpinfo()函數的輸出中

async_send = Off

是否異步傳送。

from = ;"john@doe.com"

定義匿名ftp的密碼(一個email位址)

近核心模組 ;;

[Pcre]

Perl相容正則表達式模組

pcre.backtrack_limit = 100000

PCRE的最大回溯(backtracking)步數。

pcre.recursion_limit = 100000

PCRE的最大遞歸(recursion)深度。

如果你將該值設的非常高,將可能耗盡程式的棧空間,導致PHP崩潰。

[Session]

除非使用session_register()或$_SESSION註冊了一個變量。

否則不管是否使用了session_start(),都不會自動加入任何session記錄。

內含resource變量或有迴圈引用的對象包括指向自身的引用的對象,不能儲存在會話中。

register_globals指令會影響到會話變量的存儲和還原。

session.save_handler = "files"

存儲和檢索與會話關聯的資料的處理器名字。預設為檔案("files")。

如果想要使用自訂的處理器(如基於資料庫的處理器),可用"user"。

有一個使用PostgreSQL的處理器:http://sourceforge.net/projects/phpform-ext/

session.save_path = "/tmp"

傳遞給存儲處理器的參數。對於files處理器,此值是建立會話資料檔的路徑。

Windows下預設為暫存檔夾路徑。

你可以使用"N;[MODE;]/path"這樣模式定義該路徑(N是一個整數)。

N表示使用N層深度的子目錄,而不是將所有資料檔都儲存在一個目錄下。

[MODE;]可選,必須使用8進位數,預設600(=384),表示每個目錄下最多儲存的會話檔案數量。

這是一個提高大量會話效能的好主意。

簡單的使用PHP程式(日曆算法)

您知道在使用PHP程式中,日曆算法是如何達成的嗎?

/**
  * 日曆
  *
  */
 if (function_exists('date_default_timezone_set')) {
     date_default_timezone_set('Asia/Chongqing');
 }
 $date = isset($_GET['date']) ? $_GET['date'] : date('Y-m-d');
 $date = getdate(strtotime($date));
 $end = getdate(mktime(0, 0, 0, $date['mon'] + 1, 1, $date['year']) - 1);
 $start = getdate(mktime(0, 0, 0, $date['mon'], 1, $date['year']));
 $pre = date('Y-m-d', $start[0] - 1);
 $next = date('Y-m-d', $end[0] + 86400);
 $html = '<table border="1">';
 $html .= '<tr>';
 $html .= '<td><a href="' . $PHP_SELF . '?date=' . $pre . '">-</a></td>';
 $html .= '<td colspan="5">' . $date['year'] . ';' . $date['month'] . '</td>';
 $html .= '<td><a href="' . $PHP_SELF . '?date=' . $next . '">+</a></td>';
 $html .= '</tr>';
 $arr_tpl = array(0 => '', 1 => '', 2 => '', 3 => '', 4 => '', 5 => '', 6 => '');
 $date_arr = array();
 $j = 0;
 for ($i = 0; $i < $end['mday']; $i++) {
     if (!isset($date_arr[$j])) {
         $date_arr[$j] = $arr_tpl;
     }
     $date_arr[$j][($i+$start['wday'])%7] = $i+1;
     if ($date_arr[$j][6]) {
         $j++;
     }
 }
 foreach ($date_arr as $value) {
     $html .= '<tr>';
     foreach ($value as $v) {
         if ($v) {
             if ($v == $date['mday']) {
                 $html .= '<td><b>' . $v . '</b></td>';
             } else {
                 $html .= '<td>' . $v . '</td>';
             }
         } else {
             $html .= '<td>&nbsp;</td>';
         }
     }
     $html .= '</tr>';
 }
 $html .= '</table>';
 echo $html;  
  • 1 
本PHP程式設計+MySQL資料庫+Dreamweaver整合教學(PHPMaker運用設計網站教學)密訓基地立志於收集各類PHP程式設計、MySQL資料庫及網頁設計技術教學資訊,便於本人和廣大網友及網友查詢檢索,無論公司或個人認為本站存在侵權內容均可與本站聯繫,任何此類反饋資訊一經查明屬實後,將立即移除!