php中get,post传值的对照

在目前我经历的一些ctf,awd比赛中,用的最多的两种传参方式就是get,post这两种

1. GET是从服务器上获取数据,POST是向服务器传送数据。

2. GET是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。POST是通过HTTP POST机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。

3.对于GET方式提交表单数据,服务器端用$_GET[‘name’]获取变量的值,对于POST方式提交表单数据,服务器端用$_POST[‘name’]获取提交的数据,当然,两者都可以通过$_REQUEST[‘name’]获得表单数据。对于REQUEST方式提交表单数据,服务器端用$_REQUEST[‘name’]获取变量的值,但这种方式很少用。

4. GET传送的数据量较小,不能大于2KB。POST传送的数据量较大,一般被默认为不受限制。但理论上,一般认为不能超过100KB。

5. GET安全性非常低,POST安全性较高。

6. GET表单值可以通过_GET获取;但通过action的url设置的参数总是获取不到的,跟是一样的,也就是说,在这种情况下,GET方式会忽略action页面后边带的参数列表。POST表单值可以通过_POST获取;但通过action的url参数设置的参数则可以不能通过_POST获取到。action=test.php?id=1这种就是GET方式传值,可以用$_REQUEST和$_GET接受传值,但不能用POST方式获取到值,即使表单是POST方式提交。所在,在提交表单时,如果action中同时有参数,最好只能通过POST表单方式,对于表单内数据,直接通过POST获取,对于action中参数,童工GET获取。

在做数据查询时,建议用GET方式,而在做数据添加、修改或删除时,建议用POST方式。

以上这些都是书面化的介绍下面上例子


GET传值的例子

创建两个php文件,分别是get1.php,get2.php

get1.php:

<a href="get2.php?m=100&n=101&w=ahaha&id='10'&name='xiaoqiang'">chick me</a>


get2.php:

<?php

echo $_GET['m'];

echo "<br/>";

echo $_GET['n'];

echo "<br/>";

echo $_GET['w'];

echo "<br/>";

echo $_GET['id'];

echo "<br/>";

echo $_GET['name'];

?>


这里通过get1.php中?后的语句给m,n等变量传值输出后结果如下图:

 
传值后样图

POST传值的例子

创建两个php文件,分别命名为post1.php,post2.php。

post1.php:

<form action="post2.php" method="post">

<table>

<tr>

<td>标题:</td>

<td><input type="text" name="title"/></td>

</tr>

<tr>

<td>作者:</td>

<td><input type="text" name="author"/></td>

</tr>

<tr>

<td>关键字</td>

<td><input type="text" name="keywords"/></td>

</tr>

<tr>

<td><input type="submit" value="提交"/></td>

</tr>

</table>

</form>


post2.php:

<?php

echo $_POST['title'];

echo "<br/>";

echo $_POST['author'];

echo "<br/>";

echo $_POST['keywords'];

echo "<br/>";

?>


 

 
post1.php
 
post2.php

结合例子看便于理解希望我的文章对你有帮助。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值