什么是HTTP Basic Authentication?

luoyjx · 2016-05-31 14:12 · 99次阅读

什么是HTTP Basic Authentication? 直接看http://en.wikipedia.org/wiki/Basic_authentication_scheme吧。

在你访问一个需要HTTP Basic Authentication的URL的时候,如果你没有提供用户名和密码,服务器就会返回401,如果你直接在浏览器中打开,浏览器会提示你输入用户名和密码(google浏览器不会,bug?)。你可以尝试点击这个url看看效果:http://api.minicloud.com.cn/statuses/friends_timeline.xml
要在发送请求的时候添加HTTP Basic Authentication认证信息到请求中,有两种方法:

  1. 一是在请求头中添加Authorization:
    Authorization: “Basic 用户名和密码的base64加密字符串”
  2. 二是在url中添加用户名和密码:
    http://userName:password@api.minicloud.com.cn/statuses/friends_timeline.xml
//需要Base64见:http://www.webtoolkit.info/javascript-base64.html  
function make_base_auth(user, password) {  
  var tok = user + ':' + pass;  
  var hash = Base64.encode(tok);  
  return "Basic " + hash;  
}   
  
var auth = make_basic_auth('QLeelulu','mypassword');  
var url = 'http://example.com';   
  
// 原始JavaScript  
xml = new XMLHttpRequest();  
xml.setRequestHeader('Authorization', auth);  
xml.open('GET',url)

暂无评论

登录后可以进行评论。没有账号?马上注册