ホームページ > 記事 > ウェブフロントエンド > AjaxクロスドメインアクセスにおけるCookie消失の解決策の説明
Ajax のクロスドメイン アクセスは、jsonp メソッドまたは Access-Control-Allow-Origin の設定を使用して実現できます。クロスドメイン アクセスを実現するための Access-Control-Allow-Origin の設定については、以前に書いた「ajax」の記事を参照してください。 Access-Control-Allow-Originの設定によりクロスドメインアクセスが実現します》
まずクライアントドメイン名として2つのテストドメイン名
a.fdipzone.comを作成します
サーバーとしてのb.fdipzone.com ドメイン名
テストコード
setcookie.phpはサーバーCookieの設定に使用されます
<?phpsetcookie('data', time(), time()+3600);?>
server.phpはリクエストに使用されますclient
<?php$name = isset($_POST['name'])? $_POST['name'] : '';$ret = array( 'success' => true, 'name' => $name, 'cookie' => isset($_COOKIE['data'])? $_COOKIE['data'] : '');// 指定允许其他域名访问header('Access-Control-Allow-Origin:http://a.fdipzone.com');// 响应类型header('Access-Control-Allow-Methods:POST'); // 响应头设置header('Access-Control-Allow-Headers:x-requested-with,content-type'); header('content-type:application/json');echo json_encode($ret);?>
test.html クライアントエンド ページ
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8"> <script src="//code.jquery.com/jquery-1.11.0.min.js"></script> <title> ajax 跨域访问cookie丢失的解决方法 </title> </head> <body> <script type="text/javascript"> $(function(){ $.ajax({ url: 'http://b.fdipzone.com/server.php', // 跨域 dataType: 'json', type: 'post', data: {'name':'fdipzone'}, success:function(ret){ if(ret['success']==true){ alert('cookie:' + ret['cookie']); } } }); }) </script> </body></html>
をリクエストするには、まず http://b.fdipzone.com/setcookie.php を実行してサーバーサイド Cookie を作成します。
次に http://a.fdipzone.com/test.html を実行します
Output
{"success":true,"name":"fdipzone","cookie":""}
Cookieの取得に失敗しました。
クライアント リクエストを行うときに
withCredentials 属性を true に設定して、特定のリクエストが認証情報を送信するように指定できるようにします。サーバーが認証情報付きのリクエストを受信すると、次の HTTP ヘッダーで応答します。
ヘッダーを設定します
header("Access-Control-Allow-Credentials:true");
test.html次のように変更します<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<script src="//code.jquery.com/jquery-1.11.0.min.js"></script>
<title> ajax 跨域访问cookie丢失的解决方法 </title>
</head>
<body>
<script type="text/javascript">
$(function(){
$.ajax({
url: 'http://b.fdipzone.com/server.php', // 跨域
xhrFields:{withCredentials: true}, // 发送凭据
dataType: 'json',
type: 'post',
data: {'name':'fdipzone'},
success:function(ret){
if(ret['success']==true){
alert('cookie:' + ret['cookie']);
}
}
});
}) </script>
</body></html>
server.php次のように変更します<?php$name = isset($_POST['name'])? $_POST['name'] : '';$ret = array( 'success' => true, 'name' => $name, 'cookie' => isset($_COOKIE['data'])? $_COOKIE['data'] : '');// 指定允许其他域名访问header('Access-Control-Allow-Origin:http://a.fdipzone.com');// 响应类型header('Access-Control-Allow-Methods:POST');
// 响应头设置header('Access-Control-Allow-Headers:x-requested-with,content-type');// 是否允许请求带有验证信息header('Access-Control-Allow-Credentials:true');
header('content-type:application/json');echo json_encode($ret);?>
リクエスト
{"success":true,"name":"fdipzone","cookie":"1484558863"}
Cookie の取得に成功しました
XMLHttpRequest cannot load http://b.fdipzone.com/server.php. Credentials flag is 'true', but the 'Access-Control-Allow-Credentials' header is ''. It must be 'true' to allow credentials. Origin 'http://a.fdipzone.com' is therefore not allowed access.
2. サーバーヘッダーで Access-Control-Allow-Credentials:true を設定した後、Access-Control-Allow-Origin を * に設定することはできません。ドメイン名に設定する必要があります。そうしないと、エラーが返されます。
XMLHttpRequest cannot load http://b.fdipzone.com/server.php. A wildcard '*' cannot be used in the 'Access-Control-Allow-Origin' header when the credentials flag is true. Origin 'http://a.fdipzone.com' is therefore not allowed access. The credentials mode of an XMLHttpRequest is controlled by the withCredentials attribute.
この記事では、Ajax クロスドメイン アクセスにおける Cookie 損失の解決策について説明します。関連コンテンツの詳細については、PHP 中国語 Web サイトを参照してください。
関連する推奨事項:
mysqlのkey_lenの計算方法の説明explaincurlを使用してphpを介してIPとソースアクセスをシミュレートする方法mysqlを介してNULLデータメソッドを変換する以上がAjaxクロスドメインアクセスにおけるCookie消失の解決策の説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。