赞
踩
大家在登录网站的时候,大部分时候是通过一个表单提交登录信息。
但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用http基本认证。
下面来看看一看这个认证的工作过程:
第一步:客户端发送http request 给服务器,服务器验证该用户是否已经登录验证过了,如果没有的话,
服务器会返回一个401 unauthozied给客户端,并且在response 的 header "www-authenticate" 中添加信息。
如下图。
第三步: 服务器将authorization header中的用户名密码取出,进行验证, 如果验证通过,将根据请求,发送资源给客户端。
下面来看一个java的示例代码
import java.io.ioexception;
import java.io.printwriter;
import javax.servlet.http.httpservlet;
import javax.servlet.http.httpservletrequest;
import javax.servlet.http.httpservletresponse;
import sun.misc.base64decoder;
public class httpauthservlet extends httpservlet {
public void doget(httpservletrequest request, httpservletresponse response) throws ioexception {
string sessionauth = (string) request.getsession().getattribute("auth");
if (sessionauth != null) {
system.out.println("this is next step");
nextstep(request, response);
} else {
if(!checkheaderauth(request, response)){
response.setstatus(401);
response.setheader("cache-control", "no-store");
response.setdateheader("expires", 0);
response.setheader("www-authenticate", "basic realm=\"test\"");
}
}
}
private boolean checkheaderauth(httpservletrequest request, httpservletresponse response) throws ioexception {
string auth = request.getheader("authorization");
system.out.println("auth encoded in base64 is " + getfrombase64(auth));
if ((auth != null) && (auth.length() > 6)) {
auth = auth.substring(6, auth.length());
string decodedauth = getfrombase64(auth);
system.out.println("auth decoded from base64 is " + decodedauth);
request.getsession().setattribute("auth", decodedauth);
return true;
}else{
return false;
}
}
private string getfrombase64(string s) {
if (s == null)
return null;
base64decoder decoder = new base64decoder();
try {
byte[] b = decoder.decodebuffer(s);
return new string(b);
} catch (exception e) {
return null;
}
}
public void nextstep(httpservletrequest request, httpservletresponse response) throws ioexception {
printwriter pw = response.getwriter();
pw.println(" next step, authentication is : " + request.getsession().getattribute("auth") + "
");
pw.println("
");
}
public void dopost(httpservletrequest request, httpservletresponse response) throws ioexception {
doget(request, response);
}
}
当request第一次到达服务器时,服务器没有认证的信息,服务器会返回一个401 unauthozied给客户端。
认证之后将认证信息放在session,以后在session有效期内就不用再认证了。
以上就是小编为大家带来的http基本认证(basic authentication)的java实例代码全部内容了,希望大家多多支持萬仟网~
希望与广大网友互动??
点此进行留言吧!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。