0

したがって、Internet ExplorerのiFrame内にこのページをロードすると、空白のページが表示されます。他のすべてのブラウザは正常に動作します。

他の人が示唆しているように、私もp3pヘッダーを使用しようとしましたが、役に立ちませんでした。

<?php
require ("connect.php");
require ("config.php");
require ("fb_config.php");
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
  <head>
  <title>Login handler</title>
  <meta http-equiv="content-type" content="text/html; charset=iso-8859-1">
  <link rel="stylesheet" href="css/login.css" type="text/css">
  </head>
  <body>

  <?//=$user?>
  <?php


if($user == 0) {
echo "You are not logged into facebook. Nice try.";
}else{


$query = "SELECT id,fb_id,login_ip,login_count,activated,sitestate FROM login WHERE fb_id='".mysql_real_escape_string($user)."'"; 
$result = mysql_query($query) or die(mysql_error());
$row = mysql_fetch_array($result);

        if (mysql_num_rows($result) == 0) {
    $sql = "INSERT INTO login SET id = '', fb_id ='" .mysql_real_escape_string($user). "', name = '" .rand(10000000000000000,99999999999999999999). "', signup =NOW() , password = '" .mysql_real_escape_string($pass). "', state = '0', mail = '" .mysql_real_escape_string($_POST['mail']). "',location='".mysql_real_escape_string($randomlocation)."',location_start='".mysql_real_escape_string($randomlocation)."', signup_ip='".mysql_real_escape_string($_SERVER['REMOTE_ADDR'])."',ref='".mysql_real_escape_string($_POST['ref'])."', activation_id = '" .mysql_real_escape_string($activation_link). "',activated='2', killprotection = '$twodayprot',gender='" .mysql_real_escape_string($_POST["gender"]). "'";
    $res = mysql_query($sql);
    }


        //if($row['fb_id']  != $user){
        //echo "Your facebook ID: $user is NOT in the MW DB.";
        //exit();
        //}else{


        if(empty($row['login_ip'])){
        $row['login_ip'] = $_SERVER['REMOTE_ADDR'];
        }else{

        $ip_information = explode("-", $row['login_ip']);

        if (in_array($_SERVER['REMOTE_ADDR'], $ip_information)) {   
        $row['login_ip'] = $row['login_ip'];
        }else{  
        $row['login_ip'] = $row['login_ip']."-".$_SERVER['REMOTE_ADDR'];
        }
        }

$update_login = mysql_query("UPDATE login SET login_count=login_count+'1' WHERE name='".mysql_real_escape_string($_POST['username'])."'")
or die(mysql_error());

$_SESSION['user_id'] = $row['id'];

$result = mysql_query("UPDATE login SET userip='".mysql_real_escape_string($_SERVER['REMOTE_ADDR'])."',login_ip='".mysql_real_escape_string($row['login_ip'])."',login_count='0' WHERE id='".mysql_real_escape_string($_SESSION['user_id'])."'")
or die(mysql_error());


if ($row['sitestate'] == 0){
header("location: home.php");
} elseif ($row['sitestate'] == 2) {
header("location: killed.php?id={$row['id']}&encrypted={$row['password']}");
} else {
header("location: banned.php?id={$row['id']}&encrypted={$row['password']}");
}

}// id check.


?>
  </body>
</html>
4

2 に答える 2

1

おそらくp3pヘッダーが欠落しているため、ブラウザがサイトのFacebookからのCookieを受け入れません。

http://www.hanselman.com/blog/TheImportanceOfP3PAndACompactPrivacyPolicy.aspxを参照してください

またはhttp://www.admon.org/how-to-implement-p3p-http-headers-for-cross-site-cookies/で詳細を確認してください。

于 2012-04-10T16:52:15.417 に答える
0

外部のcssファイルを参照している行を削除して、ページが読み込まれるかどうかを確認してください。

私はちょうど私が持っていた同様の問題を解決しました。正しいp3pヘッダーを設定し、問題をcssに絞り込みました。

問題のあるcssスタイルはposition:relative;html、body要素にありました-これを削除すると、Facebookが私のiframeを空白のページとして表示する問題が修正されました。

すべてのCSSを削除するとページに何かが表示される場合は、CSSを段階的に追加して、他の種類のcssスタイルがページを壊す可能性があるため、原因を特定する必要があります。

于 2012-07-12T17:57:04.410 に答える