php使用parse_str实现查询字符串解析到变量中的方法

开发技术 作者: 2024-08-17 00:45:01
这篇文章主要介绍了php使用parse_str实现查询字符串解析到变量中的方法,较为详细的分析了parse_str()函数的功能及字符串解析为变量的具体用法,并总结了使用中的相关注意事项,需要的朋友可以参考下

@H_502_0@本文实例讲述了PHP使用parse_str实现查询字符串解析到变量中的方法。分享给大家供大家参考,具体如下:


@H_502_0@parse_str()函数可实现把字符串解析到变量中,这意味着实现了字符串与变量之间的一种转换机制,在与客户端数据传递的过程中,数据是通过字符串的形式传递,如GET请求,然后在服务器端通过$_GET/$_POST等全局变量实现字符串与变量的转换,如://www.jb51.cc/?index.PHP?var1=1&var2=2,请求后服务端可使用$_GET['var1']的方式获取var1=1&var2=2这一段字符串转换成变量。parse_str()函数可实现用样的功能,使用parse_str()函数解析$_SERVER['QUERYSTRING']的值,就可以直接实现字符串与变量的转换,如$var1。


@H
502_0@

一、函数原型


@H_502_0@void parsestr ( string str [,array &arr] )


@H
5020@

二、版本兼容


@H
502_0@<span style="color: #0000ff">PHP 3,PHP 4,PHP 5


@H_502_0@

三、函数基础用法与实例


@H_502_0@1. 解析字符串为变量


<div class="jb51code">
<pre class="brush:PHP;">
<?php
parse_str("var1=jb51&var2=parse_str");
echo $var1.$var2;
?>

@H_502_0@2. 解析字符串并将变量存储到数组中

@H_502_0@输出:

jb51 [var2] => parse_str )
@H_502_0@说明:这种将变量存储到数组中在PHP 4.0.3 才增加

@H_502_0@3. 解析的字符串有空格

@H_502_0@输出:

jb51 [var_2] => parse_str )
@H_502_0@说明:直接将空格转换为下划线_

@H_502_0@

四、注意事项

@H_502_0@1. 如果未设置 array 参数,由该函数设置的变量将覆盖已由同名变量。

@H_502_0@2. PHP.ini 中的 magic_quotes_gpc 设置影响该函数的输出。如果已启用,那么在 parse_str() 解析之前,变量会被 addslashes() 转换。

@H_502_0@3. parse_str() 函数在处理参数时存在漏洞,攻击者可以利用这个漏洞启用register_globals,从而进一步利用其他PHP脚本中的漏洞。如果仅以一个参数调用 parse_str()的话,该函数会认为该参数是通过URL传送的请求字符串那样解析所提供的字符串,但外部攻击者可以在调用 parse_str()期间发送很多请求变量来触发memory_limit请求终止。如果在调用parse_str()期间执行了请求关闭的话,则在相关webserver进程的其余生命周期期间register_globals标签会一直打开。

@H_502_0@更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《》

@H_502_0@希望本文所述对大家PHP程序设计有所帮助。

原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_63503.html

本站采用系统自动发货方式,付款后即出现下载入口,如有疑问请咨询在线客服!

售后时间:早10点 - 晚11:30点

咨询售后客服

推荐精华