Rumah pembangunan bahagian belakang tutorial php register_globals使用上的一些补充说明_PHP教程

register_globals使用上的一些补充说明_PHP教程

Jul 13, 2016 am 10:34 AM
keselamatan

register_globals是php.ini里的一个配置,这个配置影响到php如何接收传递过来的参数,如果你的问题是:为什么我的表单无法传递数据?为什么我的程序无法得到传递过来的变量?等等,那么你需要仔细的阅读以下的内容。 

register_globals的值可以设置为:On或者Off,我们举一段代码来分别描述它们的不同。 

<form name="frmTest" id="frmTest" action="URL"> 
	<input type="text" name="user_name" id="user_name"> 
	<input type="password" name="user_pass" id="user_pass"> 
	<input type="submit" value="login"> 
</form> 
Salin selepas log masuk

当register_globals=Off的时候,下一个程序接收的时候应该用$_GET['user_name']和$_GET['user_pass']来接受传递过来的值。(注:当

的method属性为post的时候应该用$_POST['user_name']和$_POST['user_pass'])

当register_globals=On的时候,下一个程序可以直接使用$user_name和$user_pass来接受值。

顾名思义,register_globals的意思就是注册为全局变量,所以当On的时候,传递过来的值会被直接的注册为全局变量直接使用,而Off的时候,我们需要到特定的数组里去得到它。所以,碰到上边那些无法得到值的问题的朋友应该首先检查一下你的register_globals的设置和你获取值的方法是否匹配。(查看可以用phpinfo()函数或者直接查看php.ini)

那我们为什么要使用Off呢?

php以后的新版本默认都用Off,虽然你可以设置它为On,但是当你无法控制服务器的时候,你的代码的兼容性就成为一个大问题,所以,你最好从现在就开始用Off的风格开始编程。

现在还有一个问题就是,以前用On风格写的大量脚本怎么办?

如果你以前的脚本规划得好,有个公共包含文件,比如config.inc.php一类的文件,在这个文件里加上以下的代码来模拟一下(这个代码不保证100%可以解决你的问题,因为我没有大量测试,但是我觉得效果不错)。另外,这个帖子里的解决方法也可以参考一下:

<?php 
if ( !ini_get('register_globals') ) 
{ 
    extract($_POST); 
    extract($_GET); 
    extract($_SERVER); 
    extract($_FILES); 
    extract($_ENV); 
    extract($_COOKIE); 
    
    if ( isset($_SESSION) ) 
    { 
        extract($_SESSION); 
    } 
} 
?> 
Salin selepas log masuk

register_globals = Off的情况不仅仅影响到如何获取从

、url传递过来的数据,也影响到session、cookie,对应的,得到session、cookie的方式应该为:$_SESSION[]、$_COOKIE。同时对于session的处理也有一些改变,比如,session_register()没有必要而且失效,具体的变化,请查看php manual里的Session handling functions

php manual 写到:

Variables provided to the script via the GET, POST, and COOKIE input mechanisms, and which therefore cannot be trusted. The presence and order of variable inclusion in this array is defined according to the PHP variables_order configuration directive.

$_REQUEST中间的内容实际上还是来源于$_GET $_POST $_COOKIE,缺点是无法判断变量到底来自于get post 还是cookie,对要求比较严格的场合不适用。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/752365.htmlTechArticleregister_globals是php.ini里的一个配置,这个配置影响到php如何接收传递过来的参数,如果你的问题是:为什么我的表单无法传递数据?为什么...
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Prestasi dan keselamatan PHP5 dan PHP8: perbandingan dan penambahbaikan Prestasi dan keselamatan PHP5 dan PHP8: perbandingan dan penambahbaikan Jan 26, 2024 am 10:19 AM

PHP ialah bahasa skrip sebelah pelayan yang digunakan secara meluas yang digunakan untuk membangunkan aplikasi web. Ia telah berkembang menjadi beberapa versi, dan artikel ini akan membincangkan terutamanya perbandingan antara PHP5 dan PHP8, dengan tumpuan khusus pada peningkatan dalam prestasi dan keselamatan. Mula-mula mari kita lihat beberapa ciri PHP5. PHP5 dikeluarkan pada tahun 2004 dan memperkenalkan banyak fungsi dan ciri baharu, seperti pengaturcaraan berorientasikan objek (OOP), pengendalian pengecualian, ruang nama, dsb. Ciri-ciri ini menjadikan PHP5 lebih berkuasa dan fleksibel, membolehkan pembangun

Cabaran keselamatan dalam pembangunan Golang: Bagaimana untuk mengelak daripada dieksploitasi untuk penciptaan virus? Cabaran keselamatan dalam pembangunan Golang: Bagaimana untuk mengelak daripada dieksploitasi untuk penciptaan virus? Mar 19, 2024 pm 12:39 PM

Cabaran keselamatan dalam pembangunan Golang: Bagaimana untuk mengelak daripada dieksploitasi untuk penciptaan virus? Dengan aplikasi Golang yang luas dalam bidang pengaturcaraan, semakin ramai pembangun memilih untuk menggunakan Golang untuk membangunkan pelbagai jenis aplikasi. Walau bagaimanapun, seperti bahasa pengaturcaraan lain, terdapat cabaran keselamatan dalam pembangunan Golang. Khususnya, kuasa dan fleksibiliti Golang juga menjadikannya alat penciptaan virus yang berpotensi. Artikel ini akan membincangkan isu keselamatan dalam pembangunan Golang dan menyediakan beberapa kaedah untuk mengelakkan G

Cara mengendalikan permintaan merentas domain dan isu keselamatan dalam pembangunan C# Cara mengendalikan permintaan merentas domain dan isu keselamatan dalam pembangunan C# Oct 08, 2023 pm 09:21 PM

Cara mengendalikan permintaan merentas domain dan isu keselamatan dalam pembangunan C# Dalam pembangunan aplikasi rangkaian moden, permintaan merentas domain dan isu keselamatan ialah cabaran yang sering dihadapi oleh pembangun. Untuk memberikan pengalaman dan fungsi pengguna yang lebih baik, aplikasi selalunya perlu berinteraksi dengan domain atau pelayan lain. Walau bagaimanapun, dasar asal yang sama penyemak imbas menyebabkan permintaan merentas domain ini disekat, jadi beberapa langkah perlu diambil untuk mengendalikan permintaan merentas domain. Pada masa yang sama, untuk memastikan keselamatan data, pembangun juga perlu mempertimbangkan beberapa isu keselamatan. Artikel ini akan membincangkan cara mengendalikan permintaan merentas domain dalam pembangunan C#

Apakah hubungan antara teknik pengurusan memori dan keselamatan dalam fungsi Java? Apakah hubungan antara teknik pengurusan memori dan keselamatan dalam fungsi Java? May 02, 2024 pm 01:06 PM

Pengurusan memori dalam Java melibatkan pengurusan memori automatik, menggunakan pengumpulan sampah dan pengiraan rujukan untuk memperuntukkan, menggunakan dan menuntut semula memori. Pengurusan memori yang berkesan adalah penting untuk keselamatan kerana ia menghalang limpahan penimbal, petunjuk liar dan kebocoran memori, dengan itu meningkatkan keselamatan program anda. Contohnya, dengan melepaskan objek yang tidak lagi diperlukan dengan betul, anda boleh mengelakkan kebocoran memori, dengan itu meningkatkan prestasi program dan mencegah ranap sistem.

Keselamatan dan pelaksanaan penghantaran disulitkan protokol WebSocket Keselamatan dan pelaksanaan penghantaran disulitkan protokol WebSocket Oct 15, 2023 am 09:16 AM

Keselamatan dan Penghantaran Disulitkan Pelaksanaan Protokol WebSocket Dengan pembangunan Internet, protokol komunikasi rangkaian telah berkembang secara beransur-ansur Protokol HTTP tradisional kadangkala tidak dapat memenuhi keperluan komunikasi masa nyata. Sebagai protokol komunikasi yang baru muncul, protokol WebSocket mempunyai kelebihan prestasi masa nyata yang kuat, komunikasi dua hala dan kependaman rendah Ia digunakan secara meluas dalam bidang seperti sembang dalam talian, tolak masa nyata dan permainan. Walau bagaimanapun, disebabkan oleh ciri-ciri protokol WebSocket, mungkin terdapat beberapa isu keselamatan semasa proses komunikasi. Oleh itu, untuk WebSo

Adakah win11 perlu memasang perisian anti-virus? Adakah win11 perlu memasang perisian anti-virus? Dec 27, 2023 am 09:42 AM

Win11 datang dengan perisian anti-virus Secara umumnya, kesan anti-virus adalah sangat baik dan tidak perlu dipasang Namun, satu-satunya kelemahan ialah virus itu dinyahpasang terlebih dahulu dan bukannya mengingatkan anda terlebih dahulu sama ada anda memerlukannya. Jika anda menerimanya, anda tidak perlu memuat turun perisian anti-virus lain. Adakah win11 perlu memasang perisian anti-virus Jawapan: Tidak. Secara umumnya, win11 disertakan dengan perisian anti-virus dan tidak memerlukan pemasangan tambahan. Jika anda tidak menyukai cara perisian anti-virus yang disertakan dengan sistem win11 dikendalikan, anda boleh memasangnya semula. Bagaimana untuk mematikan perisian anti-virus yang disertakan dengan win11: 1. Pertama, kita masukkan tetapan dan klik "Privasi dan Keselamatan". 2. Kemudian klik "Pusat Keselamatan Tetingkap". 3. Kemudian pilih "Perlindungan virus dan ancaman". 4. Akhir sekali, anda boleh mematikannya

Kegagalan dan keselamatan pelayan Linux: Cara mengurus sistem anda dengan sihat Kegagalan dan keselamatan pelayan Linux: Cara mengurus sistem anda dengan sihat Sep 10, 2023 pm 04:02 PM

Dengan perkembangan teknologi Internet, semakin banyak perusahaan dan individu memilih untuk menggunakan pelayan Linux untuk mengehoskan dan mengurus aplikasi dan tapak web mereka. Walau bagaimanapun, apabila bilangan pelayan bertambah, kegagalan pelayan dan isu keselamatan menjadi tugas yang mendesak. Artikel ini akan meneroka punca kegagalan pelayan Linux dan cara mengurus serta melindungi sistem dengan sihat. Mula-mula, mari kita lihat beberapa sebab biasa yang boleh menyebabkan pelayan Linux tidak berfungsi. Pertama, kegagalan perkakasan adalah salah satu sebab yang paling biasa. Sebagai contoh, pelayan terlalu panas,

Analisis keselamatan kata laluan akaun lalai Oracle Analisis keselamatan kata laluan akaun lalai Oracle Mar 09, 2024 pm 04:24 PM

Pangkalan data Oracle ialah sistem pengurusan pangkalan data hubungan yang popular Banyak perusahaan dan organisasi memilih untuk menggunakan Oracle untuk menyimpan dan mengurus data penting mereka. Dalam pangkalan data Oracle, terdapat beberapa akaun lalai dan kata laluan yang dipratetap oleh sistem, seperti sys, sistem, dsb. Dalam pengurusan pangkalan data harian dan kerja operasi dan penyelenggaraan, pentadbir perlu memberi perhatian kepada keselamatan kata laluan akaun lalai ini, kerana akaun ini mempunyai kebenaran yang lebih tinggi dan boleh menyebabkan masalah keselamatan yang serius setelah ia dieksploitasi dengan niat jahat. Artikel ini akan membincangkan lalai Oracle

See all articles