php幾個函數

1. dirname

(PHP 3, PHP 4, PHP 5)

dirname?--?返回路徑中的目錄部分

說明

string?dirname?( string path )

給出一個包含有指向一個文件的全路徑的字符串,本函數返回去掉文件名后的目錄名。

在 Windows 中,斜線(/)和反斜線(\)都可以用作目錄分隔符。在其它環境下是斜線(/)。

例子 1.?dirname()?例子

<?php
$path?
=?"/etc/passwd";
$file?=?dirname($path);?// $file is set to "/etc"
?>

注:?在 PHP 4.0.3 中,dirname()?被修正為 POSIX 兼容。本質上就意味著如果在?path?中沒有斜線,則返回一個點('.'),表示當前目錄。否則返回的是把?path?中結尾的?/component(最后一個斜線以及后面部分)去掉之后的字符串。注意這意味著在老的函數返回一個空字符串的情形下你通常從?dirname()?得到的是斜線或者一個點。

dirname()?從 PHP 4.3.0 開始有所改變 請看以下例子:

?

<?php

// PHP 4.3.0 以前
dirname('c:/');?// 返回 '.'

// PHP 4.3.0 以后
dirname('c:/');?// 返回 'c:'

?>

?

?

dirname()?的操作從 PHP 5.0.0 版開始是二進制安全的。

2. explode() 函數把字符串分割為數組。

在本例中,我們將把字符串分割為數組:

<?php
$str = "Hello world. It's a beautiful day.";
print_r (explode(" ",$str));
?>

輸出:

Array
(
[0] => Hello
[1] => world.
[2] => It's
[3] => a
[4] => beautiful
[5] => day.
)
3.$_SERVER['SCRIPT_NAME']

/test.php/123456的話

$_SERVER['SCRIPT_NAME']結果是/test.php?

4.?__FILE__ :被稱為PHP魔術常量,返回當前執行PHP腳本的完整路徑和文件名,包含一個絕對路徑

比如文件 b.php 包含如下內容:
<?php
$basedir = dirname(__FILE__);
echo $basedir
//將在頁面打印出一個這個文件所在絕對路徑!
?>
我做的測試得到結果: E:\website\othertest\cms
如果b.php被其他目錄里的a.php文件require 或者 include 去引用的話。?變量$basedir 的內容還是b.php所在的那個文件夾的路徑。 而不是變成a.php文件所在的目錄。
5.?

當 register_globals 打開以后,各種變量都被注入代碼,例如來自?HTML?表單的請求變量。再加上?PHP?在使用變量之前是無需進行初始化的,這就使得更容易寫出不安全的代碼。這是個很艱難的抉擇,但?PHP?社區還是決定默認關閉此選項。當打開時,人們使用變量時確實不知道變量是哪里來的,只能想當然。但是 register_globals 的關閉改變了這種代碼內部變量和客戶端發送的變量混雜在一起的糟糕情況。下面舉一個錯誤使用 register_globals 的例子:

?

Example #1 錯誤使用 register_globals = on 的例子

<?php
//?當用戶合法的時候,賦值?$authorized?=?true
if?(authenticated_user())?{
????$authorized?=?true;
}

//?由于并沒有事先把?$authorized?初始化為?false,
//?當?register_globals?打開時,可能通過GET?auth.php?authorized=1?來定義該變量值
//?所以任何人都可以繞過身份驗證
if?($authorized)?{
????include?"/highly/sensitive/data.php";
}
?>

當 register_globals = on 的時候,上面的代碼就會有危險了。如果是 off,$authorized?就不能通過如 URL 請求等方式來改變,這樣就好多了,盡管初始化變量是一個良好的編程習慣。比如說,如果在上面的代碼執行之前加入$authorized = false?的話,無論 register_globals 是 on 還是 off 都可以,因為用戶狀態被初始化為未經認證。

另一個例子是關于會話的。當 register_globals = on 的時候,$username?也可以用在下面的代碼中,但要意識到$username?也可能會從其它途徑進來,比如說通過?URL?的 GET。

?

Example #2 使用會話時同時兼容 register_globals on 和 off 的例子

<?php
//?我們不知道?$username?的來源,但很清楚?$_SESSION?是
//?來源于會話數據
if?(isset($_SESSION['username']))?{

????echo?"Hello?<b>{$_SESSION['username']}</b>";

}?else?{

????echo?"Hello?<b>Guest</b><br?/>";
????echo?"Would?you?like?to?login?";

}
?>

采取相應的預防措施以便在偽造變量輸入的時候給予警告是完全有可能的。如果事先確切知道變量是哪里來的,就可以檢查所提交的數據是否是從不正當的表單提交而來。不過這不能保證變量未被偽造,這需要攻擊者去猜測應該怎樣去偽造。如果不在乎請求數據來源的話,可以使用?$_REQUEST?數組,它包括了 GET、POST 和 COOKIE 的所有數據。詳情可參見本手冊的來自 PHP 之外的變量。

?

Example #3 探測有害變量

<?php
if?(isset($_COOKIE['MAGIC_COOKIE']))?{

????//?MAGIC_COOKIE?來自?cookie
????//?這樣做是確保是來自?cookie?的數據

}?elseif?(isset($_GET['MAGIC_COOKIE'])?||?isset($_POST['MAGIC_COOKIE']))?{

???mail("admin@example.com",?"Possible?breakin?attempt",?$_SERVER['REMOTE_ADDR']);
???echo?"Security?violation,?admin?has?been?alerted.";
???exit;

}?else?{

???//?這一次請求中并沒有設置?MAGIC_COOKIE?變量

}
?>

當然,單純地關閉 register_globals 并不代表所有的代碼都安全了。對于每一段提交上來的數據,都要對其進行具體的檢查。永遠要驗證用戶數據和對變量進行初始化!把?error_reporting()?設為?E_NOTICE?級別可以檢查未初始化的變量。

更多關于模擬 register_globals 為 on 或 off 的信息,請見此?FAQ。

轉載于:https://www.cnblogs.com/laojie4321/p/4187688.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375398.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375398.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375398.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Struts2 自定義攔截器(easy example)

要自定義攔截器需要實現com.opensymphony.xwork2.interceptor.Interceptor接口&#xff1a; 新建一個MyInterceptpackage com.action;import com.opensymphony.xwork2.ActionInvocation; import com.opensymphony.xwork2.interceptor.Interceptor;public class MyInterceptor i…

img標簽在div里上下居中

方法一&#xff1a;圖片尺寸未知&#xff0c;IE8-不支持 CSS部分&#xff1a; <style> .content{width:500px;height:500px;border:1px solid black;position:relative; } </style>DOM部分&#xff1a; <div class"content"> <img src"htt…

(接口)銀聯證書上傳被修改的問題和讀取證書的絕對路徑問題

最近在做對接銀聯的支付接口。相對于支付寶、微信支付&#xff0c;銀聯支付接口應該是做的最完美的了。銀聯支付平臺提供了足夠詳細的接口文檔&#xff0c;接口demo&#xff0c;常見問題解決方案。 更人性化的是&#xff0c;個人可以免費注冊一個商家賬號&#xff0c;提供給你免…

控制器對視圖聲明周期的控制

init&#xff0d;初始化程序 viewDidLoad&#xff0d;加載視圖 viewWillAppear&#xff0d;UIViewController對象的視圖即將加入窗口時調用&#xff1b; viewDidApper&#xff0d;UIViewController對象的視圖已經加入到窗口時調用&#xff1b; viewWillDisappear&#xff0d;UI…

MST:Bad Cowtractors(POJ 2377)

壞的牛圈建筑 題目大意&#xff1a;就是現在農夫又要牛修建牛欄了&#xff0c;但是農夫想不給錢&#xff0c;于是牛就想設計一個最大的花費的牛圈給他&#xff0c;牛圈的修理費用主要是用在連接牛圈上 這一題很簡單了&#xff0c;就是找最大生成樹&#xff0c;把Kruskal算法改一…

有關進程的一些基本概念

對進程的初步描述 一.和進程有關的一些概念 ①一個進程就是一個正在執行程序的實例&#xff0c;包括程序計數器&#xff0c;寄存器和變量的當前值。 從概念上說&#xff0c;每個進程擁有它自己的虛擬CPU&#xff0c;當然真實的CPU在各個進程之間來回切換。 ②在某一瞬間&…

第4章 maven依賴特性

第4章 maven依賴特性 本章詳細介紹maven的依賴特性和依賴范圍&#xff0c;如何排除依賴。 4.1 什么是依賴傳遞 舉個例子 在非maven項目中&#xff0c;你需要使用spring功能&#xff0c;你會想到導入spring的jar包&#xff0c;那么&#xff0c;srping又需要其他依賴jar包支持&a…

lintcode :Integer to Roman 整數轉羅馬數字

題目 整數轉羅馬數字 給定一個整數&#xff0c;將其轉換成羅馬數字。 返回的結果要求在1-3999的范圍內。 樣例 4 -> IV 12 -> XII 21 -> XXI 99 -> XCIX 更多案例&#xff0c;請戳 http://literacy.kent.edu/Minigrants/Cinci/romanchart.htm 說明 什么是 羅馬數字…

Win32ASm學習[1]:RadASm下測試Debug

okay 正文開始下面的代碼如果不能編譯 請把你的RadAsm下的Masm32這個文件夾復制到任意一個磁盤的根目錄下&#xff0c;在進行編譯就可以了 或者安裝Masm32 SDK到任意磁盤根目錄下 .386.model flat,stdcalloption casemap:none;>>>>>>>>>>&g…

關于javascript閉包

1.閉包的概念 閉包就是能夠讀取其他函數內部變量的函數。 由于在Javascript語言中&#xff0c;只有函數內部的子函數才能讀取局部變量&#xff0c;因此可以把閉包簡單理解成“定義在一個函數內部的函數”。 所以&#xff0c;在本質上&#xff0c;閉包就是將函數內部和函數外部連…

Win32ASM學習[2]:運算符

算術運算符 名稱 優先級 () 圓括號 1 ,- 正、負 2 *,/ 乘、除 3 MOD 取模 3 ,- 加、減 4 ------------------------------------------------------------------------------------------------------------------------------------------ .386 .mo…

正式入住了

從13年開始從事iOS開發工作,就準備寫一些東西,記錄這一路學習工作之旅,但是總是想著堅持不下來,也就慢慢的放棄了,開始用一些記筆記的軟件,印象筆記用過,個人體驗比較差,后來又用了OneNote,這個APP還是比較舒服,但是由于公司的老版mac-pro,無法使用,也就突然想起了,也是時候重出…

VRRP協議具體解釋

轉帖&#xff1a;http://blog.chinaunix.net/space.php?uid11654074&doblog&id2857384 Contents Page 文件夾 入木三分學網絡…

Win32ASM學習[3]:局部變量

.386 .modelflat, stdcall include windows.inc include kernel32.inc include masm32.inc include debug.inc includelib kernel32.lib includelib masm32.lib includelib debug.lib .code main proc ;局部變量中的類型不能使用縮寫 LOCAL v1: dword …

WPF筆記(1.1 WPF基礎)——Hello,WPF!

WPF筆記(1.1 WPF基礎)——Hello&#xff0c;WPF&#xff01; 原文:WPF筆記(1.1 WPF基礎)——Hello&#xff0c;WPF&#xff01;Example 1-1. Minimal C# WPF application//MyApp.csusingSystem;usingSystem.Windows; //the root WPF namespacenamespaceMyFirstAvalonApp { cla…

c#入門系列——類和對象的代碼實現

面向對象 說起面向對象&#xff0c;大家因該都聽說過&#xff0c;也知道是一個編程的方法&#xff0c;簡稱oop技術。它將對象的算法和數據結構看作一個整體&#xff0c;而一個程序就是由多個對象結合的整體。這樣做可以提高代碼的復用率&#xff0c;提高了軟件的可維護性。 屬性…

安卓TCP通信版本2

PC做服務器&#xff0c;安卓做客戶端。 安卓獲取輸入框的內容并發送&#xff0c;然后等待接收服務器的消息 服務器先行開啟&#xff0c;接收到客戶端的數據&#xff0c;然后回復消息。 實現了對線程類的封裝&#xff0c;通過按鈕啟動線程發送并接收 服務器代碼&#xff08;java…

Win32ASM學習[5]: 數據對齊相關的偽指令(ALIGN、EVEN、ORG)

32 位的寄存器容量是 4 字節, 如果內存中的數據都按 4*n 字節對齊, 肯定會加快吞吐速度; 但事實并非如此, 不同大小的數據可能會讓寄存器別別扭扭地去處理, 從而降低了運行速度! 如果使用對齊, 就會浪費掉一些內存空間; 其實這是一個需要權衡 "速度" 與 "內存&…

常用Jquery前端操作

input只能輸入正整數 οnkeyup"this.valuethis.value.replace(/\D/g,)"if(!confirm("刪除后無法恢復&#xff0c;確認繼續&#xff1f;")){return false;}//判斷字符串里是否存在指定字符 if(str.indexOf("abc") ! -1){//表示存在}1.雙引號替換…

【Linux/Ubuntu學習 10】unbuntu 下 eclipse 中文亂碼的解決

wangddwdd-pc:~$ gedit /var/lib/locales/supported.d/local 添加&#xff1a; zh_CN.GBK GBKzh_CN.GB2312 GB2312 終端執行命令&#xff1a; sudo dpkg-reconfigure --force localesGenerating locales... en_AG.UTF-8... done en_AU.UTF-8... done en_BW.UTF-8... done …