通过ajax和php的基本HTTP授权


basic http auth via ajax and php

我试图通过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
});