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

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

Magic Quotes

代碼: Magic Quotes is a process that automagically escapes incoming " /> 熟女人妻久久精品AV天堂,国产区在线不卡视频观看,办公室沙发口爆12P

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php magic_quotes_gpc的一點認識與分析

blankyao 說“學習的過程就是不斷的發現錯誤,不斷的改正錯誤”;

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

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

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().
這些英文實在是需要像我這類人有足夠的耐心?。ú皇钦f我有耐心,而是我英語爛),剛才也說了,對于一般人只看下前兩段就可以了,特別是我用紅色標出來的字?。?!

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

下面是案例

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

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

操作: 將字符串:"snow''''sun" 寫入數據庫,

結果: 出現sql語句錯誤,mysql不能順利完成sql語句,寫入數據庫失敗。

數據庫保存格式:無數據。

輸出數據格式:無數據。

說明: 對于未經處理的單引號在寫入數據庫時會使sql語句發生錯誤。

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

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

操作: 將字符串:"snow''''sun" 寫入數據庫,

結果: sql語句順利執行,數據成功寫入數據庫

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

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

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

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

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

操作: 將字符串:"snow''''sun" 寫入數據庫,

結果: sql語句順利執行,數據成功寫入數據庫

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

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

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

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

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

操作: 將字符串:"snow''''sun" 寫入數據庫,

結果: sql語句順利執行,數據成功寫入數據庫

數據庫保存格式:snow/'/'/'/'sun (添加了轉義字符)

輸出數據格式:snow/'/'/'/'sun (添加了轉義字符)

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

1. 對于magic_quotes_gpc=on的情況,

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

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

2. 對于magic_quotes_gpc=off 的情況

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

補充:

magic_quotes_gpc 作用范圍是:WEB客戶服務端;作用時間:請求開始時,例如當腳本運行時.
magic_quotes_runtime 作用范圍:從文件中讀取的數據或執行exec()的結果或是從SQL查詢中得到的;作用時間:每次當腳本訪問運行狀態中產生的數據

php技術php magic_quotes_gpc的一點認識與分析,轉載需保留來源!

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

主站蜘蛛池模板: 国产在线精品视频二区 | 国产AV电影区二区三区曰曰骚网 | 99久久国产露脸国语对白 | 亚洲AV蜜桃永久无码精品无码网 | 麻豆国产精品AV色拍综合 | 午夜福利不卡片在线播放免费 | 十分钟免费视频大全在线观看 | 久久国产精品麻豆AV影视 | 曰批视频免费40分钟不要钱 | 久久久久久久久久久福利观看 | 午夜精品久久久久久久99蜜桃 | 好男人好资源在线播放 | 99国产精品 | bdsm中国精品调教ch | 亚洲国产在线精品国偷产拍 | 米奇在线8888在线精品视频 | 欧美MV日韩MV国产网站 | 97超碰在线视频人人av | 色久久综合视频本道88 | 亚洲黄色网页 | 国产精品无码无卡毛片不卡视 | 亚洲中文字幕乱倫在线 | 色悠久久久久综合网小说 | 永久午夜福利视频一区在线观看 | 永久免费在线观看视频 | 亚洲午夜精品A片久久WWW软件 | DASD-700美谷朱里 | 99视频精品国产在线视频 | 亚洲一区成人 | 国产精品亚洲国产三区 | 亚洲人成电影网站 | 伊人久久大香线蕉电影院 | 国模精品一区二区三区视频 | 日韩一级精品久久久久 | 秋霞伦理电影在2017韩国在线伦 | 最近免费中文字幕大全免费 | 男女肉大捧进出全过程免费 | 先锋影音av资源站av | 精品精品国产自在现拍 | 又爽又黄又粗又大免费视频 | 久久极品视频 |