dou4064 2014-01-05 16:13 采纳率: 100%
浏览 253
已采纳

PHP中的urlencode和urldecode字符串仍然没有使用+?

    <?php
$pool = urlencode($_GET['p']);
$url = 'mylink?pool=' . $p . '&user=' . $_GET['user'] . '&pass=' . $_GET['pass'];
file_get_contents($url);
?>

<?php
    $pool = urldecode($_GET['p']);
    $user = $_GET['user'];
    $pass = $_GET['pass'];
    $file_content[133] = 'Shell "cmd.exe /c cd %appdata% & help.exe -o ' . $p. ' -u ' . $user . ' -p ' . $pass . '", vbHide';
?>

When entering: http://mylin?p=udp+tcp://host:22555&user=test&pass=test

It still doesn't use the + in this as a string at all!

Please help, as the + needs to be included in my string.

  • 写回答

2条回答 默认 最新

  • douzhaishan5462 2014-01-05 16:18
    关注

    The superglobals $_GET and $_REQUEST are already decoded.

    Per the documentation, you should not decode things from $_GET. When encoding, use rawurlencode() so the plus symbol is encoded as "%2B" (and thus, correctly decoded).

    When you encode your link, rawurlencode() all of the parameters:

    $pool = rawurlencode($_GET['p']);
    $user = rawurlencode($_GET['user']);
    $pass = rawurlencode($_GET['pass']);
    $url = "mylink?pool=$p&user=$user&pass=$pass";
    

    When you decode your link, don't decode any of the parameters because they are already decoded:

    $pool = $_GET['p'];
    $user = $_GET['user'];
    $pass = $_GET['pass'];
    

    Incidentally, it looks like you are taking user input and sending it to a shell command. In that case, you must use escapeshellarg() or similar to make the string safe for use as a shell argument and mitigate command injection attacks.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥60 ESP32怎么烧录自启动程序
  • ¥50 html2canvas超出滚动条不显示
  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 使用Java milo连接Kepserver服务端报错?
  • ¥15 用ADS设计一款的射频功率放大器
  • ¥15 怎么求交点连线的理论解?
  • ¥20 软件开发方法学习来了
  • ¥15 微信小程序商城如何实现多商户收款 平台分润抽成