以下の質問を読んでて、こうやればできるのでは?と思ってたことを
本当にやったら、できなかったので改めて解決策を質問させてください
元質問
##概要
BASIC認証配下のファイルのテキストデータを外部ドメインから取得したい
レスポンス側サーバー:Apache2.x (SSL)
root/
├ testBASIC
├ .htaccess ├ .htpasswd ├ secret.data
リクエスト側サーバー:Apache2.x
root/
├ testFolder
├ indexBASIC.html
.htaccess
<Files ~ "^.(htaccess|htpasswd)$"> deny from all </Files> AuthUserFile /home/users/0/****/web/testBASIC/.htpasswd AuthGroupFile /dev/null AuthName "Please enter your ID and password" AuthType Basic require valid-user Header append Access-Control-Allow-Origin: http://[リクエスト側ドメイン].jp Header append Access-Control-Allow-Headers: authorization
indexBASIC.html
JavaScript
1 $.ajax({ 2 beforeSend: function (xhr) { 3 xhr.overrideMimeType('text/html;charset=UTF-8'); 4 xhr.setRequestHeader ("Authorization", "Basic " + btoa('myUser:myPass')); 5 }, 6 url: 'https://[レスポンス側ドメイン]/testBASIC/secret.data', 7 type: 'GET' 8 }).done((data, textStatus, jqXHR) => { 9 console.log(data); 10 }).fail((jqXHR, textStatus, errorThrown) => { 11 console.log('エラーは:' + jqXHR.status); 12 })
ブラウザで直に'https://[レスポンス側ドメイン]/testBASIC/secret.data'にアクセスして
ID/Pass入力すれば問題なくデータが表示されます
しかしリクエスト側サーバーのindexBASIC.htmlにアクセスした場合のhttpヘッダの様子は
以下の画像のになります
リクエストヘッダに"Authorization"を追加しているので
preflightが飛んでると思うのですがその時点でアウトになってしまってるようで
ajaxのfailハンドラの出力は”エラーは0”となってて
本リクエストの送信はされていないようです
レスポンス側の.htaccessにヘッダに追加すればいいかもと思って
上記のようにしてみてるのですが401となってしまいます・・・
どのようにすれば無事にデータファイルにアクセスできるでしょうか?
回答1件
あなたの回答
tips
プレビュー