http基本认证 java_HTTP基本认证(Basic Authentication)的JAVA实例代码

大家在登录网站的时候,大部分时候是通过一个表单提交登录信息。

但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用http基本认证。

0c030119b3a10f250155d6682e31eb1b.png

下面来看看一看这个认证的工作过程:

第一步:客户端发送http request 给服务器,服务器验证该用户是否已经登录验证过了,如果没有的话,

服务器会返回一个401 unauthozied给客户端,并且在response 的 header "www-authenticate" 中添加信息。

如下图。

b845fdeef2c7703efac957394abdda60.png

48f93cc8dab6d8ee45fdf32afcac1919.png

第三步: 服务器将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实例代码全部内容了,希望大家多多支持萬仟网~

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值