当前位置:   article > 正文

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

java 代码执行 httpbasic 认证

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

但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用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实例代码全部内容了,希望大家多多支持萬仟网~

希望与广大网友互动??

点此进行留言吧!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/615362
推荐阅读
相关标签
  

闽ICP备14008679号