我正在创建一个令牌,我将其作为页面上URL的一部分传递 . 我使用 rawurlencode ()对字符串进行编码并将其作为令牌发送,但是,我发现当我解码收到的令牌(作为URL参数传递)时,我得到一个稍微不同的字符串 .
我的网址如下所示:/path/to/file.html?token=abcd123
这是我正在使用的代码片段 . 我做的任何东西显然都是错的吗?如果失败了,有没有更好的方法来创建(加密)令牌并将其传递到网址?
//send
$raw = "some secret string";
$token = rawurlencode($raw);
//recieve
$data = rawurldecode($token);
?>
[Edit]
我已经删除了enc(dec)ryption功能 - 它们不是问题的原因 - 而且是一个红色的鲱鱼 . 我已经将问题缩小到专门针对rawurlencode / decode在工作方式上不对称的问题 .
解码时的rawurlencoded字符串会给出不同的字符串(类似的字符串,但缺少部分) . 当然,对于URLS来说,不可能存在一些错误 - 所以我必须做错事 . 问题是我无法发现它,到目前为止还没有人能够发现它......
[Additional Info]
我正在使用Symfony Web框架(v1.3.8),它可能通过编码和解码幕后的东西来搞乱请求 . 我将尝试直接从$ _POST变量获取token参数,看看Symfony是否是所有这些中的罪魁祸首 .