本文目錄一覽:
- 1、幫我解釋一下這段PHP的代碼,新人不太明白
- 2、幫我解釋下這段PHP代碼的意思
- 3、麻煩幫解釋下這段PHP代碼 是什麼意思 謝謝!
- 4、這段php代碼的意思?
- 5、帥哥麻煩能否幫我解釋一下這段PHP代碼謝謝!
幫我解釋一下這段PHP的代碼,新人不太明白
分成二部分看
function make_safe($variable)
{$variable = addslashes(trim($variable));
return $variable;}
是一個函數 作用是將$variable中的單引號之類的特殊符號加上』\『進行轉義,是簡單的安全過濾
$y0=make_safe($_REQUEST[“y0”]);
$x=make_safe($_REQUEST[“x”]);
$y=make_safe($_REQUEST[“y”]);
if ($y0 != “”)
{switch($y0){case “+”:$daan =$y+$x;
break;case “-“:$daan =$y-$x;
break;case “*”:$daan =$y*$x;
break;case “/”:$daan =$y/$x;
break;default:}
echo $y.$y0.$x.”=”.$daan;}
這是一個簡單的計算器,y0應該是運行符,前台應該有三個輸入框 name 分別是 y0,x,y,提交後傳到這個php文件中,最後輸出類似與 1+1=2 ,2-1=1 的樣式
幫我解釋下這段PHP代碼的意思
$lev=0;循環中第一次運行的代碼,以後不再運行
如果$lev$level*2-1執行代碼部分,$level_nbsp.=”
“,「.」的意思相當於JAVASCRIPT中的+或者VB中的。這條語句的意思也就是說,把空格追加到變數$level_nbsp後面
執行完畢以後再執行$lev++,++的意思就是$lev自身加1,然後再回到$lev$level*2-1,知道條件不成立為止
麻煩幫解釋下這段PHP代碼 是什麼意思 謝謝!
就是寫出你朋友的數量和各個名字,你運行一次就知道了。
你的朋友是:”Robert Barwell”, “Mike Parry”, “Jeremy Beacock”
數量是friendNames.Length
這段php代碼的意思?
整個代碼是用來過濾惡意注入的。
if(isset($_REQUEST[‘GLOBALS’]) || isset($_FILES[‘GLOBALS’])) exit(‘Request Denied’);
這一行是發現有惡意的全局變數提交上來就攔截。
@set_magic_quotes_runtime(0);
$MQG = get_magic_quotes_gpc();
這裡是讀取系統環境變數
foreach(array(‘_POST’, ‘_GET’, ‘_COOKIE’) as $__R) {
這個是新建一個數組,三個值就在上面了。
if(isset($$__R)) {
foreach($$__R as $__k = $__v) {
if(isset($$__k) $$__k == $__v) unset($$__k);
}
估計難的就是這裡吧。。$__R 在第一次循環時,值是 _POST 前面再加一個 $ 即 $_POST
如果 $_POST 已經賦值,這個有點多餘,因為這是內置變數,一定存在的。
之後把 $$__R 分別看成 $_POST $_GET 啥的即可,拆分 $_POST 每個值到 $__V 里,索引存到 $__K 里。如果有 $_POST[‘a’] = ‘b’; 那 $__K 就是 a ,$__V 就是 b。下面是同樣的意思。
如果 $($__K) 即 $a 已經存在,並且這個變數的值和現在 POST 過來的值相同,就把原來的變數註銷掉。只保留 POST 過來的那個變數。
也就是說,如果代碼原來有 $a=’b’ 現在又提交了一個 $_POST[‘a’]=’b’; 現在就刪掉原來的 $a 保留 POST 的那個。這是用於別人已經成功注入的情況下,可以把他們已經注入的變數幹掉。
if(!$MQG)$$__R = daddslashes($$__R);
上面這個是檢查環境變數,魔法引號是否開啟,如果沒有開啟的話,過濾整個 $_POST(GET COOKIE)
$$__R = strip_sql($$__R);
$$__R = dsafe($$__R);
上面這兩個是自定義過濾,看樣子是過濾 SQL 注入啥的。原理同上。
}
}
帥哥麻煩能否幫我解釋一下這段PHP代碼謝謝!
?php
if($item[‘q_content’]){
//檢查數組變數$item[‘q_content’]是否存在
$item_q_content = unserialize($item[‘q_content’]);//用 unserialize() 還原已經序列化的對象
$keysvalue = $new_array = array();//聲明數組變數
foreach($item_q_content as $k=$v){
//將$item_q_content循環,由此可以斷定它是個數組
$keysvalue[$k] = $v[‘time’];//將 $item_q_content中的time鍵值複製到新變數$keysvalue中去(結合下面的代碼,這賦值一點意義都沒有,你要的只是鍵值而已)
$h=date(“H”,$v[‘time’]);//取得小時
$i=date(“i”,$v[‘time’]);//取得分鐘
$s=date(“s”,$v[‘time’]);//取得秒
list($timesss,$msss) = explode(“.”,$v[‘time’]);//用.字元串分割$v[‘time’]
$item_q_content[$k][‘timeadd’] = $h.$i.$s.$msss;//重新賦值$item_q_content,並建立一個多維數組
}
arsort($keysvalue); //asort($keysvalue);正序
reset($keysvalue);//將 array 的內部指針倒回到第一個單元
foreach ($keysvalue as $k=$v){
//遍歷$keysvalue,得到$k,也就是鍵值
$new_array[$k] = $item_q_content[$k];//取得變數$item_q_content中鍵值的值,並且重新賦值給新變數$new_array
}
$item[‘q_content’] = $new_array;//賦值
}
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/244357.html