導航:首頁 > 編程語言 > php引用問題

php引用問題

發布時間:2022-09-10 01:14:07

php中文件引用的問題

./表示當前目錄
../表示上一級目錄
因為你的as.php是在B文件夾內,而conn.php是在www的根目錄下,所以要用
include("../conn.php");

⑵ php引用函數的使用方法

php引用函數的使用方法

在技術學習的道路上,能掌握一些有用的技巧,對於初學者是非常有幫助的,下面是php引用函數的使用方法,希望大家會喜歡。

1.不要在你的應用程序中gzip輸出,讓apache來做

考慮使用ob_gzhandler?不,別這樣做。它沒有任何意義。PHP應該是來寫應用程序的。不要擔心PHP中有關如何優化在伺服器和瀏覽器之間傳輸的數據。

使用apache mod_gzip/mod_deflate通過.htaccess文件壓縮內容。

2.從php echo javascript代碼時使用json_encode

有些時候一些JavaScript代碼是從php動態生成的。

$images = array( 'myself.png' , 'friends.png' , 'colleagues.png');

$js_code = '';foreach($images as $image)

{

$js_code .= "'$image' ,";

}

$js_code = 'var images = [' . $js_code . ']; ';echo $js_code;//Output is var images = ['myself.png' ,'friends.png' ,'colleagues.png' ,];

放聰明點。使用json_encode:

$images = array( 'myself.png' , 'friends.png' , 'colleagues.png');

$js_code = 'var images = ' . json_encode($images);

echo $js_code;//Output is : var images = ["myself.png","friends.png","colleagues.png"]

這不是很整潔?

3.在寫入任何文件之前檢查目錄是否可寫

在寫入或保存任何文件之前,請務必要檢查該目錄是否是可寫的,如果不可寫的話,會閃爍錯誤消息。這將節省你大量的「調試」時間。當你工作於Linux時,許可權是必須要處理的,並且會有很多很多的許可權問題時,當目錄不可寫,文件無法讀取等的時候。

請確保你的應用程序盡可能智能化,並在最短的時間內報告最重要的信息。

$contents = "All the content";

$file_path = "/var/www/project/content.txt";

file_put_contents($file_path , $contents);

這完全正確。但有一些間接的問題。file_put_contents可能會因為一些原因而失敗:

父目錄不存在

目錄存在,但不可寫

鎖定文件用於寫入?

因此,在寫入文件之前最好能夠一切都弄明確。

$contents = "All the content";

$dir = '/var/www/project';

$file_path = $dir . "/content.txt";if(is_writable($dir))

{

file_put_contents($file_path , $contents);

}else{ die("Directory $dir is not writable, or does not exist. Please check");

}

通過這樣做,你就能得到哪裡文件寫入失敗以及為什麼失敗的准確信息。

4.改變應用程序創建的文件的許可權

當在Linux環境下工作時,許可權處理會浪費你很多時間。因此,只要你的php應用程序創建了一些文件,那就應該修改它們的許可權以確保它們在外面「平易近人」。否則,例如,文件是由「php」用戶創建的,而你作為一個不同的用戶,系統就不會讓你訪問或打開文件,然後你必須努力獲得root許可權,更改文件許可權等等。

// Read and write for owner, read for everybody elsechmod("/somedir/somefile", 0644);// Everything for owner, read and execute for otherschmod("/somedir/somefile", 0755);

5.不要檢查提交按鈕值來檢查表單提交

if($_POST['submit'] == 'Save')

{ //Save the things}

以上代碼在大多數時候是正確的,除了應用程序使用多語言的情況。然後「Save」可以是很多不同的東西。那麼你該如何再做比較?所以不能依靠提交按鈕的值。相反,使用這個:

if( $_SERVER['REQUEST_METHOD'] == 'POST' and isset($_POST['submit']) )

{ //Save the things}

現在你就可以擺脫提交按鈕的值了。

6.在函數中總是有相同值的地方使用靜態變數

//Delay for some timefunction delay(){

$sync_delay = get_option('sync_delay'); echo "

Delaying for $sync_delay seconds...";

sleep($sync_delay); echo "Done

";

}

相反,使用靜態變數:

//Delay for some timefunction delay(){ static $sync_delay = null; if($sync_delay == null)

{

$sync_delay = get_option('sync_delay');

} echo "

Delaying for $sync_delay seconds...";

sleep($sync_delay); echo "Done

";

}

7.不要直接使用$ _SESSION變數

一些簡單的例子是:

$_SESSION['username'] = $username;

$username = $_SESSION['username'];

但是這有一個問題。如果你正在相同域中運行多個應用程序,會話變數會發生沖突。2個不同的應用程序在會話變數中可能會設置相同的鍵名。舉個例子,一個相同域的前端門戶和後台管理應用程序。

因此,用包裝函數使用應用程序特定鍵:

define('APP_ID' , 'abc_corp_ecommerce');//Function to get a session variablefunction session_get($key){

$k = APP_ID . '.' . $key; if(isset($_SESSION[$k]))

{ return $_SESSION[$k];

} return false;

}//Function set the session variablefunction session_set($key , $value){

$k = APP_ID . '.' . $key;

$_SESSION[$k] = $value; return true;

}

8.封裝實用輔助函數到一個類中

所以,你必須在一個文件中有很多實用函數:

function utility_a(){ //This function does a utility thing like string processing}function utility_b(){ //This function does nother utility thing like database processing}function utility_c(){ //This function is ...}

自由地在應用程序中使用函數。那麼你或許想要將它們包裝成一個類作為靜態函數:

class Utility{ public static function utility_a()

{

} public static function utility_b()

{

} public static function utility_c()

{

}

}//and call them as $a = Utility::utility_a();

$b = Utility::utility_b();

這里你可以得到的一個明顯好處是,如果php有相似名稱的內置函數,那麼名稱不會發生沖突。

從另一個角度看,你可以在相同的應用程序中保持多個版本的相同類,而不會發生任何沖突。因為它被封裝了,就是這樣。

9.一些傻瓜式技巧

使用echo代替print

使用str_replace代替preg_replace,除非你確定需要它

不要使用short tags

對於簡單的'字元串使用單引號代替雙引號

在header重定向之後要記得做一個exit

千萬不要把函數調用放到for循環控制行中。

isset比strlen快

正確和一致地格式化你的代碼

不要丟失循環或if-else塊的括弧。

不要寫這樣的代碼:

if($a == true) $a_count++;

這絕對是一種浪費。

這樣寫

if($a == true)

{

$a_count++;

}

不要通過吃掉語法縮短你的代碼。而是要讓你的邏輯更簡短。使用具有代碼高亮功能的文本編輯器。代碼高亮有助於減少錯誤。

10. 使用array_map快速處理數組

比方說,你要trim一個數組的所有元素。新手會這樣做:

foreach($arr as $c => $v)

{

$arr[$c] = trim($v);

}

但它可以使用array_map變得更整潔:

$arr = array_map('trim' , $arr);

這適用於trim數組$arr的所有元素。另一個類似的函數是array_walk。

11.使用php過濾器驗證數據

你是不是使用正則表達式來驗證如電子郵件,IP地址等值?是的,每個人都是這樣做的。現在,讓我們試試一個不同的東西,那就是過濾器。

php過濾器擴展程序將提供簡單的方法來有效驗證或校驗值。

12.強制類型檢查

$amount = intval( $_GET['amount'] );

$rate = (int) $_GET['rate'];

這是一種好習慣。

13.使用set_error_handler()將Php錯誤寫入到文件

set_error_handler()可以用來設置自定義的錯誤處理程序。在文件中編寫一些重要的錯誤用於日誌是個好主意。

14.小心處理大型數組

大型的數組或字元串,如果一個變數保存了一些規模非常大的東西,那麼要小心處理。常見錯誤是創建副本,然後耗盡內存,並得到內存溢出的致命錯誤:

$db_records_in_array_format; //This is a big array holding 1000 rows from a table each having 20 columns , every row is atleast 100 bytes , so total 1000 * 20 * 100 = 2MB$cc = $db_records_in_array_format; //2MB moresome_function($cc); //Another 2MB ?

當導入csv文件或導出表到csv文件時,上面這樣的代碼很常見。

像上面這樣做可能經常會由於內存限制而讓腳本崩潰。對於小規模的變數它不會出現問題,但當處理大型數組時一定要對此加以避免。

考慮通過引用傳遞它們,或者將它們存儲在一個類變數中:

$a = get_large_array();

pass_to_function(&$a);

這樣一來,相同的變數(並非其副本)將用於該函數。

class A{ function first()

{ $this->a = get_large_array(); $this->pass_to_function();

} function pass_to_function()

{ //process $this->a

}

}

盡快復原它們,這樣內存就能被釋放,並且腳本的其餘部分就能放鬆。

下面是關於如何通過引用來賦值從而節省內存的一個簡單示例。

<?phpini_set('display_errors' , true);

error_reporting(E_ALL);

$a = array();for($i = 0; $i < 100000 ; $i++)

{

$a[$i] = 'A'.$i;

}echo 'Memory usage in MB : '. memory_get_usage() / 1000000 . '

';

$b = $a;

$b[0] = 'B';echo 'Memory usage in MB after 1st : '. memory_get_usage() / 1000000 . '

';

$c = $a;

$c[0] = 'B';echo 'Memory usage in MB after 2st : '. memory_get_usage() / 1000000 . '

';

$d =& $a;

$d[0] = 'B';echo 'Memory usage in MB after 3st (reference) : '. memory_get_usage() / 1000000 . '

';

一個典型php 5.4機器上的輸出是:

Memory usage in MB : 18.08208Memory usage in MB after 1st : 27.930944Memory usage in MB after 2st : 37.779808Memory usage in MB after 3st (reference) : 37.779864

因此可以看出,內存被保存在第3份通過引用的副本中。否則,在所有普通副本中內存將被越來越多地使用。

15.在整個腳本中使用單一的資料庫連接

請確保你在整個腳本使用單一的資料庫連接。從一開始就打開連接,使用至結束,並在結束時關閉它。不要像這樣在函數內打開連接:

function add_to_cart(){

$db = new Database();

$db->query("INSERT INTO cart .....");

}function empty_cart(){

$db = new Database();

$db->query("DELETE FROM cart .....");

}

有多個連接也不好,會因為每個連接都需要時間來創建和使用更多的內存,而導致執行減緩。

在特殊情況下。例如資料庫連接,可以使用單例模式。

;

⑶ php類的引用

如果用的是laravel(其他的framework可以參考類似操作):

一般有一個routes.php用於定義URI路徑,比如:

Route::get('/cs.php/T/{admin}',"MyController@testFunc");

這樣就把你說的URI定向到MyController.php文件的testFunc函數。請這樣定義testFunc:

<?php
//MyController.php
namespaceAppHttpControllers;

{
publicfunctiontestFunc($admin,Request$request)
{
//這里你就直接可以使用$admin的值了。
}
}

⑷ php引用外部文件的問題

  1. require()

    require()語句用於指定的文件代替語句本身,就象C語言中的include()語句一樣。如果php配置文件php.ini中的URL fopen
    wrappers 是打開的(默認情況下是打開的),就可以使用URL來指定文件的位置從而實現遠程文件的調用。

    有一點就是使用require()和include()語句時要特別的注意。那就是在被包含的文件中,處理器是按照html模式來解釋其中的內容的,處理完被包含的內容後又恢復到php模式。所以如果需要在被包含文件中使用php語法,就要使用正確的php開始和結束標記來把這些語句包含進去。

    require()和include()知識php中的一種語言特性,而不是函數。它們和函數有許多不同的地方。

  2. include()

    include()語句和require()語句有許多相同的地方。凡是在上邊require()語句中沒有明確說明不能適用於include()的部分外,require()語句的功能完全適用於include()語句。下邊介紹require()語句所沒有的include()語句的功能和特點。

    include語句只有在被執行時才會讀入要包含的文件。在錯誤處理方便,使用include語句,如果發生包含錯誤,程序將跳過include語句,雖然會顯示錯誤信息但是程序還是會繼續執行!

    php處理器會在每次遇到include()語句時,對它進行重新處理,所以可以根據不同情況的,在條件控制語句和循環語句中使用include()來包含不同的文件。

  3. require_once()和include_once()

    require_once()和include_once()語句分別對應於require()和include()語句。require_once()和include_once()語句主要用於需要包含多個文件時,可以有效地避免把同一段代碼包含進去而出現函數或變數重復定義的錯誤

⑸ php 文件引用路徑的問題

關鍵是要知道你這個c.class.php到底是在require.php中引用呢,還是a或b中引用。
在require.php引用,那麼路徑是「../c.class.php」。在a或b中的一個,那麼路徑是「../../c.class.php」

⑹ php 引用

1, $a = 123; $array = array(); $array[1] =& $a; $abc = $array; // 此時$abc[1]仍然引用自$a,不會解除 $a = 456; // 重新為$a賦值456 echo $abc[1]; // 顯示為456 理解這個意思了吧, 無論是什麼樣的數組, 只要其中某個是引用自其它地方,它就會一直引用著, 只有$abc[1]重新賦值才會解除引用 ########################################################### 2, new是php的關鍵字, 用於實例化對象, new foobar()的意思是初始化一個對象, 而對象自身傳值是直接使用引用而不是傳值的, foo(new foobar())等於說將這個foobar類實例化之後將這個對象當作參數傳進foo函數 ########################################################### 3, $someref是一個示例變數名, 它可以是$_GET[1]也可以是$GLOBALS[a], 這樣它就可以是整個php程序中任何的有效存在的變數 例子只是例子, 用在實際程序中才有它的存在意義, 的確這例子舉的很缺智慧就是了,很遺憾你找了本爛書 $_GET[1] = 1; function &a() { $a = $_GET[1]; return $a; } $x =& a(); $x = 'MoontoC'; echo $_GET[1]; // 此時這里會顯示 MoontoC, 而不是最初賦值的1, 你明白其中的意義了嗎, 使用函數傳值時必須雙方都使用引用符號才有意義真正的引用過去, 而任何一邊少了引用符號, 都不會得到錯誤的內容, 但內容是傳值, 而不是傳引用了, 沒有程序基礎的人最初學php的確很難理解傳值和傳引用的重要性, 覺得反正都能得到自己要的東西, 其實不是的, 很多時候雖然得到的東西一樣, 但是代價卻完全不一樣, 一個長達200萬字的值, 被當作值傳送就是400萬字同時放在內存中待用, 多耗費一倍內存的意思,而傳引用就只是一個快捷方式傳送過去而已 ########################################################### 4, 還是同一個問題, 樓主沒搞清楚啥叫例子 這個例子中存在一個沒有寫出來的$foo對象, 而這個對象是寫在/* ...code */里的, 它的確存在, 但這是例子, 沒必要寫的如此完整, 並不是所有的教程都把例子寫的一字不漏的, 很多事情需要我們腦補-_- $foobar = new foo(); function &find_var($param) { $found_var = $GLOBALS['foobar']; return $found_var; } 此時例子就接近完整了 $foo =& find_var($bar);// 此時$foo 引用自$GLOBALS['foobar'], 也就是全局變數的$foobar $foo->x = 2; // 相當於 $foobar->x = 2; 樓主不理解$foo->x = 2;的意義, 看來是看教程還沒看到對象和類吧, 看到那的時候你會理解對象屬性的意義, 也就明白 $foo->x其實是foo對象其中一個屬性x, = 2是為這個屬性賦值

⑺ php中有幾種方法引用另一個php文件又有什麼區別

有兩種方法引用另一個php文件。

PHP包括並要求語句。

使用include或require語句,您可以將PHP文件的內容插入另一個PHP文件(在伺服器執行該文件之前)。

除了錯誤處理外,包括和要求語句是相同的:

需要產生一個致命錯誤(E_COMPILE_ERROR)並停止腳本。

只包括生成警告(E_WARNING),腳本將繼續執行。

⑻ PHP中foreach循環中使用引用要注意的地方

復制代碼
代碼如下:
foreach
($array
as
&$row)
{
$row
=
explode('/',
$row);
}
foreach
($array
as
$row)
{
//do
something
}
這么寫,在第二個循環會出邏輯錯誤,加入第二個循環中do
something的地方是輸出$row,循環到最後一個的時候的輸出是倒數第二個元素,而不是最後一個
要這么寫
復制代碼
代碼如下:
foreach
($array
as
&$row)
{
$row
=
explode('/',
$row);
}
unset($row);
foreach
($array
as
$row)
{
//do
something
}
或者第一個循環這么寫
復制代碼
代碼如下:
foreach
($array
as
$key
=>
$row)
{
$array[$key]
=
explode('/',
$row);
}
說一下原理
第一個循環使用了引用,循環結束後,$row引用的是$array數組的最後一個元素,當開始第二個循環的時候,$row變數每次循環都會被賦一個新值,在php中,如果一個內存空間是被引用的,那麼當改變它的時候是直接改變這塊內存空間的值,也就是說,當第二個foreach的第一次循環,$array的最後一個元素的值就被改變為$array的第一個元素的值,第二次循環的時候,改變為第二個元素的值,倒數第二次循環的時候,被改變為倒數第二個元素值,而最後一次循環的時候得道的值必然是那個倒數第二個值
當然,如果php的for循環有作用域的話,也不會出現此問題.....

⑼ php 引用 和 foreach的問題

foreach ($a as &$val) 把$val指向每個元素的地址。當循環完的時候,$val指向的是$a最後一個元素3的地址。 第二次遍歷foreach ($a as $val)將每個元素依次賦值到最後一個地址上。 數組$a的變化循環第一次[1,2,1],第二次[1,2,2],第三次次[1,2,2] 避免這個問題,要在第一次foreach循環後加上 foreach ($a as &$val){} unset($val); //加上這句,取消$val對地址的引用,程序恢復正常。 foreach ($a as $val){}

閱讀全文

與php引用問題相關的資料

熱點內容
美食博主用什麼app拍視頻 瀏覽:812
ipone手機如何加密微信 瀏覽:354
自來水加密閥閥帽 瀏覽:431
華為交換機dhcp配置命令 瀏覽:315
androidbitmap縮小 瀏覽:271
單片機串口控制燈 瀏覽:84
大訊雲伺服器安裝視頻 瀏覽:784
華為演算法領先世界 瀏覽:654
linux路由重啟 瀏覽:566
php的模板編程 瀏覽:320
編譯器原理與實現書 瀏覽:709
dos選擇命令 瀏覽:17
apm固件編譯到單片機 瀏覽:121
聯通深藍卡都包含什麼app 瀏覽:264
如何判斷網路伺服器正常 瀏覽:652
路由器搭橋遠端伺服器地址是什麼 瀏覽:518
編譯動態庫時會連接依賴庫嗎 瀏覽:710
淘寶手機加密是隨機的嗎 瀏覽:675
解壓包子怎麼裝飾 瀏覽:588
四個數湊24演算法 瀏覽:679