忍受我。多年来,我开始明白我在解释自己时很糟糕。
我的网站上有一个完整的Spotify下载链接页面。在第一次访问时,人们需要填写联系表单以捕获他们的电子邮件,然后才能下载。之后,他们可以永久地下载尽可能多的播放列表。
Cookie正在按照预期进行设置,但我写的PHP并没有正常工作。
Cookie
<?php $cookie_name = 'spotify-download';
$cookie_value = 'allow';
$date_of_expiry = time() + (10 * 365 * 24 * 60 * 60);
if(isset($_GET['download']) && $_GET['download'] == 'true'){
setcookie($cookie_name, $cookie_value, $date_of_expiry, '/',null,false,true);
$_COOKIE['spotify-download'] = 'allow';
} ?>
PHP基本上说&#34;如果没有设置cookie,打开弹出窗口,否则,开始下载&#34;
<?php if(!isset($_COOKIE['spotify-download'])) { ?>
<script type="text/javascript">function zforms_open_window(...)></script><a></a>
<?php } else { ?>
<a href="<?php echo $link; ?>" target="_blank"></a>
<?php } ?>
帮助?
答案 0 :(得分:0)
我已经测试了你的代码并且它工作正常,但是在设置之前无法读取cookie。即,用户重定向到/?download = true设置cookie,然后需要重新加载页面或转到现在可以读取cookie的其他地方。
<?php
$cookie_name = 'spotify-download';
$cookie_value = 'allow';
$date_of_expiry = time() + (10 * 365 * 24 * 60 * 60);
if( isset( $_GET['download'] ) && $_GET['download'] === 'true' ){
setcookie($cookie_name, $cookie_value, $date_of_expiry);
$_COOKIE[$cookie_name] = $cookie_value;
}
if( isset( $_COOKIE[$cookie_name] ) && $_COOKIE[$cookie_name] === $cookie_value) {
echo "You have access!";
} else {
echo "Access denied.";
}