HTTP基本认证(Basic Authentication)的JAVA实例代码
程序员文章站
2024-03-11 14:16:31
大家在登录网站的时候,大部分时候是通过一个表单提交登录信息。
但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用http基本认证。
下面来看看一看这个认...
大家在登录网站的时候,大部分时候是通过一个表单提交登录信息。
但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用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("<html> next step, authentication is : " + request.getsession().getattribute("auth") + "<br>"); pw.println("<br></html>"); } public void dopost(httpservletrequest request, httpservletresponse response) throws ioexception { doget(request, response); } }
当request第一次到达服务器时,服务器没有认证的信息,服务器会返回一个401 unauthozied给客户端。
认证之后将认证信息放在session,以后在session有效期内就不用再认证了。
以上就是小编为大家带来的http基本认证(basic authentication)的java实例代码全部内容了,希望大家多多支持~
上一篇: 详解Java解析XML的四种方法
下一篇: 浅谈Java方法的重载