[英]Setting PHP session variables using Flash Actionscript
我有一个简单的 PHP 上传脚本,它是从我的 Flash 应用程序调用的。 我确定它会调用,因为它实际上上传了文件!
session_start();
$default_path = 'files/';
$target_path = ($_POST['dir']) ? $_POST['dir'] : $default_path;
if(!file_exists($target_path)) mkdir($target_path, 0777, true);
$destination = $target_path . basename( $_FILES[ 'Filedata' ][ 'name' ] );
$file_name = rand(1,9999).$_FILES[ 'Filedata' ][ 'name' ];
if(move_uploaded_file($_FILES[ 'Filedata' ][ 'tmp_name' ], $destination)){
$_SESSION['path'] = 'flashuploader_online/upload/'.$destination;
}
但是,我尝试在另一个脚本中使用 session 变量“路径”,但它给了我一个空值,是的。 我确保使用 session_start。
我错过了什么吗?
至少现在我知道问题出在哪里了。 但是我不确定如何解决它而不会因为传递 session 个变量而变得混乱? 有任何想法吗?
您将必须通过将 session_id 作为变量传递来在所有请求中保留它。 我 promise 它不会变得太乱。 您需要对显示 flash 的页面以及它发布到的脚本进行一些更改,您还需要对 Flash 应用程序本身进行一些更改。 这样它就可以在将文件上传到服务器时包含 session ID。
首先,您需要通过将其包含在 FlashVars 中来提供 flash 和 session ID。 您将需要显示 flash 的页面用 PHP 进行预处理,否则将无法保留 session。确保在输出 Flash 的页面中调用 session_start()。您最终会像这样:
<object classid="clsid:(blah)" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,28,0" width="800" height="800" id="ZoomifyHotspotViewer">
<param name="flashvars" value="phpsessionid=<? print session_id(); ?>">
<param name="src" value="YourSWF.swf">
<embed flashvars="phpsessionid=<? print session_id(); ?>" src="YourSWF.swf" pluginspage="http://www.adobe.com/go/getflashplayer" type="application/x-shockwave-flash" width="800" height="800" name="YourSWF"></embed>
</object>
这部分特别是需要在 param 和 embed 标签中添加的内容:
phpsessionid=<? print session_id(); ?>
然后,在您的 Flash 应用程序中发出请求时,您现在可以访问变量“phpsessionid”中的 session id。 您需要将值包含在名为 PHPSESSID(全部大写)的 POST 变量中 - 包括它,但是您将包含其他变量,例如您使用的“dir”变量。
包含该变量将确保当您在下一页调用 session_start() 时,将恢复 session 而不是启动新的 session。 有几个配置案例不会自动发生。 如果事实证明你是这种情况(即 session id 在下一页上仍然不同),你需要在处理上传的页面中执行以下操作:
session_id($_POST['PHPSESSID']);
session_start();
这将手动强制PHP使用指定ID更新已保存的session。 这甚至不应该是您必须处理的问题,但如果是,您可能必须在用户继续的下一页上做类似的事情,或者将一般情况添加到所有页面:
if (isset($_REQUEST['PHPSESSID'])) {
session_id($_REQUEST['PHPSESSID']);
}
session_start();
请确保,如果您最终需要以这种方式调用 session_id() 作为 setter,请在调用 session_start() 之前执行此操作。
每次 web 服务器向您提供响应(页面、图形等)时,它都有机会向您的浏览器发送一个 cookie。
1) 每个 cookie 只发送回同一个 web 站点,因为它首先来自 2) cookie 的“内容”(它包含的数据)只能由 web 服务器已经知道的任何信息组成.
所以你的浏览器会自动发送 cookies 到 HTTP 中的“Cookie”变量 header 中。你可以在 PHP 中使用以下命令读取它:
$headers = apache_request_headers();
echo $headers['Cookie'];
服务器(如果在 PHP 配置中启用了 session 支持)会自动在 cookie 中创建 PHPSESSID(您可以在配置中修改变量名称),您可以使用上面的脚本直接访问它(您需要解析 $headers 以获得 PHPSESSID 变量或任何其他曲奇饼)。 我觉得没必要用flashvars,你的浏览器自动在HTTP header添加Cookie变量。
希望这可以帮助 !
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.