我的问题源于我向用户发送电子邮件,其中包含以下内容:
正如您所看到的,我要做的是将一个url作为参数“dest”传递,以便登录页面知道用户登录后的重定向位置。但是,我会看到以下内容:
这是我用来创建电子邮件的视图:
<p>
<?if($this->invitation->user):?>
<a href='<?=$this->serverUrl($this->baseUrl().$this->url(array(
'action'=>'index',
'controller'=>'login',
'dest'=>$this->url(array(
'action'=>'confirm',
'controller'=>'invitation',
'confirmation_key'=>$this->invitation->confirmation_key
))
)));?>'>Log in to confirm this invitation.</a>
//The view continues...
任何关于如何防止将URI编码的项目翻译为其文字值的想法都将非常感激。
答案 0 :(得分:6)
你不能把它作为simpel GET参数发送出去吗?
这就是它实际上是如何完成的。
答案 1 :(得分:1)
$_SERVER['referer']
答案 2 :(得分:0)
您还可以像这样升级您的链接:
<a href='<?=$this->serverUrl($this->baseUrl().$this->url(array(
'action'=>'index',
'controller'=>'login',
'dest'=>base64_encode($this->url(array(
'action'=>'confirm',
'controller'=>'invitation',
'confirmation_key'=>$this->invitation->confirmation_key
))))
));?>'>Log in to confirm this invitation.</a>
但是在/login/index
上,您需要使用base64_decode()
来获取原始的不是最漂亮的解决方案,但如果您无法使用简单的查询字符串,这是一种方式,如何安全地通过URL传递字符串。