欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-12 13:09:32
大家在登录网站的时候,大部分时候是通过一个表单提交登录信息。 但是有时候浏览器会弹出一个登录验证的对话框,如下图,这就是使用http基本认证。 下面来看看一看这个认...

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

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

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

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

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

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

如下图。

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

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

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