我试图通过ajax做一个http基本认证。
$.ajax({
url: 'secure/index.php',
beforeSend: function(xhr) {
xhr.setRequestHeader("Authorization", "Basic " + Base64.encode("user" + ":" + "password") //May need to use "Authorization" instead
},
success: function(result) {
alert(result);
},
error:function (xhr, ajaxOptions, throwBnError){
alert(xhr);
alert(thrownError);
}
Ok。问题是,我没有使用任何。htaccess文件来做HTTP认证。
我有一个简单的PHP文件,它使身份验证:
header('WWW-Authenticate: Basic realm="Secret page"');
header('HTTP/1.0 401 Unauthorized');
和我的ajax请求不希望工作..
我做错了什么?
我以前也遇到过类似的问题;尝试将此函数添加到PHP身份验证文件
function http_auth_get($url,$username,$password){
$cred = sprintf('Authorization: Basic %s',
base64_encode("$username:$password") );
$opts = array(
'http'=>array(
'method'=>'GET',
'header'=>$cred
)
);
$ctx = stream_context_create($opts);
$handle = @fopen($url, 'r', false,$ctx);
if (!$handle) {
die($http_response_header[0]);
}
return stream_get_contents($handle);
}
你可以这样使用这个函数:
$return = http_auth_get(http://example.com,user,pass);
如何使用$return变量取决于您试图访问
您是否尝试过在.ajax中使用用户名和密码字段?
$.ajax({
url: "http://mydomain/mypage.php",
username: u,
password: p,
error: function () {
}
}).done(function(html) {
//Do Stuff
});