先看下手冊上怎么說的吧!

對一般人來說看下前兩段就可以了

Magic Quotes

代碼: Magic Quotes is a process that automagically escapes incoming " /> 18岁免费网站,黄色精品,成 人 黄 色 大片

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php magic_quotes_gpc的一點認識與分析

blankyao 說“學(xué)習(xí)的過程就是不斷的發(fā)現(xiàn)錯誤,不斷的改正錯誤”;

先看下手冊上怎么說的吧!

對一般人來說看下前兩段就可以了

Magic Quotes

代碼:
Magic Quotes is a process that automagically escapes incoming data to the php script. It's preferred to code with magic quotes off and to instead escape the data at runtime, as needed.
What are Magic Quotes


代碼:
When on, all ' (single-quote), " (double quote), / (backslash) and NULL characters are escaped with a backslash automatically. This is identical to what addslashes() does.

There are three magic quote directives:
magic_quotes_gpc

代碼:
Affects HTTP Request data (GET, POST, and COOKIE). Cannot be set at runtime, and defaults to on in php.
magic_quotes_runtime

代碼:
If enabled, most functions that return data from an external source, including databases and text files, will have quotes escaped with a backslash. Can be set at runtime, and defaults to off in php.
magic_quotes_sybase

代碼:
If enabled, a single-quote is escaped with a single-quote instead of a backslash. If on, it completely overrides magic_quotes_gpc. Having both directives enabled means only single quotes are escaped as ''. Double quotes, backslashes and NULL's will remain untouched and unescaped.
Why use Magic Quotes




1 Useful for beginners

Magic quotes are implemented in php to help code written by beginners from being dangerous. Although SQL Injection is still possible with magic quotes on, the risk is reduced.

2Convenience

For inserting data into a database, magic quotes essentially runs addslashes() on all Get, Post, and Cookie data, and does so automagically.


Why not to use Magic Quotes




1 Portability

代碼:
Assuming it to be on, or off, affects portability. Use get_magic_quotes_gpc() to check for this, and code accordingly.
2 Performance

代碼:
Because not every piece of escaped data is inserted into a database, there is a performance loss for escaping all this data. Simply calling on the escaping functions (like addslashes()) at runtime is more efficient.

Although php.ini-dist enables these directives by default, php.ini-recommended disables it. This recommendation is mainly due to performance reasons.
3 Inconvenience

代碼:
Because not all data needs escaping, it's often annoying to see escaped data where it shouldn't be. For example, emailing from a form, and seeing a bunch of /' within the email. To fix, this may require excessive use of stripslashes().
這些英文實在是需要像我這類人有足夠的耐心啊(不是說我有耐心,而是我英語爛),剛才也說了,對于一般人只看下前兩段就可以了,特別是我用紅色標出來的字!!!

另外,特別注意的是,魔術(shù)引用發(fā)生作用是在傳遞$_GET,$_POST,$_COOKIE時

下面是案例

代碼:
1.
條件: magic_quotes_gpc=off
寫入數(shù)據(jù)庫的字符串未經(jīng)過任何過濾處理。從數(shù)據(jù)庫讀出的字符串也未作任何處理。

數(shù)據(jù):  $data="snow''''sun" ; (snow和sun之間是四個連續(xù)的單引號).

操作: 將字符串:"snow''''sun" 寫入數(shù)據(jù)庫,

結(jié)果: 出現(xiàn)sql語句錯誤,mysql不能順利完成sql語句,寫入數(shù)據(jù)庫失敗。

數(shù)據(jù)庫保存格式:無數(shù)據(jù)。

輸出數(shù)據(jù)格式:無數(shù)據(jù)。

說明: 對于未經(jīng)處理的單引號在寫入數(shù)據(jù)庫時會使sql語句發(fā)生錯誤。

代碼:
2.
條件: magic_quotes_gpc=off
寫入數(shù)據(jù)庫的字符串經(jīng)過函數(shù)addslashes()處理。從數(shù)據(jù)庫讀出的字符串未作任何處理。

數(shù)據(jù):  $data="snow''''sun" ; (snow和sun之間是四個連續(xù)的單引號).

操作: 將字符串:"snow''''sun" 寫入數(shù)據(jù)庫,

結(jié)果: sql語句順利執(zhí)行,數(shù)據(jù)成功寫入數(shù)據(jù)庫

數(shù)據(jù)庫保存格式:snow''''sun (和輸入一樣)

輸出數(shù)據(jù)格式:snow''''sun (和輸入一樣)

說明: addslashes()函數(shù)將單引號轉(zhuǎn)換為/'的轉(zhuǎn)義字符使sql語句成功執(zhí)行,
但/'并未作為數(shù)據(jù)存入數(shù)據(jù)庫,數(shù)據(jù)庫保存的是snow''''sun 而并不是我們想象的snow/'/'/'/'sun

代碼:
3.
條件: magic_quotes_gpc=on
寫入數(shù)據(jù)庫的字符串未經(jīng)過任何處理。從數(shù)據(jù)庫讀出的字符串未作任何處理。

數(shù)據(jù):  $data="snow''''sun" ; (snow和sun之間是四個連續(xù)的單引號).

操作: 將字符串:"snow''''sun" 寫入數(shù)據(jù)庫,

結(jié)果: sql語句順利執(zhí)行,數(shù)據(jù)成功寫入數(shù)據(jù)庫

數(shù)據(jù)庫保存格式:snow''''sun (和輸入一樣)

輸出數(shù)據(jù)格式:snow''''sun (和輸入一樣)

說明: magic_quotes_gpc=on 將單引號轉(zhuǎn)換為/'的轉(zhuǎn)義字符使sql語句成功執(zhí)行,
但/'并未作為數(shù)據(jù)入數(shù)據(jù)庫,數(shù)據(jù)庫保存的是snow''''sun而并不是我們想象的snow/'/'/'/'sun。

代碼:
4.
條件: magic_quotes_gpc=on
寫入數(shù)據(jù)庫的字符串經(jīng)過函數(shù)addlashes()處理。從數(shù)據(jù)庫讀出的字符串未作任何處理。

數(shù)據(jù):  $data="snow''''sun" ; (snow和sun之間是四個連續(xù)的單引號).

操作: 將字符串:"snow''''sun" 寫入數(shù)據(jù)庫,

結(jié)果: sql語句順利執(zhí)行,數(shù)據(jù)成功寫入數(shù)據(jù)庫

數(shù)據(jù)庫保存格式:snow/'/'/'/'sun (添加了轉(zhuǎn)義字符)

輸出數(shù)據(jù)格式:snow/'/'/'/'sun (添加了轉(zhuǎn)義字符)

說明: magic_quotes_gpc=on 將單引號轉(zhuǎn)換為/'的轉(zhuǎn)義字符使sql語句成功執(zhí)行,
addslashes又將即將寫入數(shù)據(jù)庫的單引號轉(zhuǎn)換為/',后者的轉(zhuǎn)換被作為數(shù)據(jù)寫入
數(shù)據(jù)庫,數(shù)據(jù)庫保存的是snow/'/'/'/'sun
總結(jié)如下:

1. 對于magic_quotes_gpc=on的情況,

我們可以不對輸入和輸出數(shù)據(jù)庫的字符串?dāng)?shù)據(jù)作
addslashes()和stripslashes()的操作,數(shù)據(jù)也會正常顯示。

如果此時你對輸入的數(shù)據(jù)作了addslashes()處理,
那么在輸出的時候就必須使用stripslashes()去掉多余的反斜杠。

2. 對于magic_quotes_gpc=off 的情況

必須使用addslashes()對輸入數(shù)據(jù)進行處理,但并不需要使用stripslashes()格式化輸出
因為addslashes()并未將反斜杠一起寫入數(shù)據(jù)庫,只是幫助mysql完成了sql語句的執(zhí)行。

補充:

magic_quotes_gpc 作用范圍是:WEB客戶服務(wù)端;作用時間:請求開始時,例如當(dāng)腳本運行時.
magic_quotes_runtime 作用范圍:從文件中讀取的數(shù)據(jù)或執(zhí)行exec()的結(jié)果或是從SQL查詢中得到的;作用時間:每次當(dāng)腳本訪問運行狀態(tài)中產(chǎn)生的數(shù)據(jù)

php技術(shù)php magic_quotes_gpc的一點認識與分析,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: www.黑人| 国产在线观看精品一区二区三区91 | 中文激情 | 亚洲综合啪啪 | 日韩激情在线 | 一本大道加勒比久久综合 | 精品久久久久久久久久 | 天天色天天操天天 | 国产精品久久久久久福利 | 国产精品特黄一级国产大片 | 最新国产区 | 第一页综合| 永久免费品色堂 | 久久夜色精品国产欧美 | 欧美激情片在线观看 | 亚洲综合图片人成综合网 | 国产精品酒店视频 | 狠狠五月深爱婷婷网 | 国产一区国产二区国产三区 | 欧洲色综合精品 | 亚洲最大的成人网 | 凹凸精品视频分类国产品免费 | 美美女高清毛片视频免费观看 | 99精品久久精品一区二区 | 国产成人久久精品激情 | 国产精品久久久尹人香蕉 | 成人在线免费观看视频 | 精品视频专区 | 成年人福利视频 | 91久国产在线观看 | www.婷| 午夜视频精品 | 色婷婷欧美 | 亚洲人成一区二区三区 | 青青草97国产精品免费观看 | 视频一区 国产 | 国产欧美精品区一区二区三区 | 国产极品在线观看视频 | 久久精品国产99久久72 | 四虎免费永久在线播放 | 日本一区二区三区高清在线观看 |