如何通过form认证

时间:2021-05-06 05:29:00
用java程序访问web,怎样才能通过form认证?是不是要写特定的http头信息

9 个解决方案

#1


1、在web.xml中设置。在JB中有向导可以设置很方便的。

  <login-config>
    <auth-method>FORM</auth-method>
    <form-login-config>
      <form-login-page>/login.jsp</form-login-page>
      <form-error-page>/error.jsp</form-error-page>
    </form-login-config>
  </login-config>



2、你的form有特别格式。

<form method=”POST” action=”j_security_check”>
<input type=”text” name=”j_username”>
<input type=”password” name=”j_password”>
</form>

#2


具体可参阅我的网站相关文章 www.sharetop.com

-----------
我是燕赤霞,替人办事是要收钱的。

#3


URLConnection c = CGIurl.openConnection();
c.setDoOutput(true);
c.setUseCaches(false);
c.setRequestProperty("Authorization",Base64.encode(username)+" "+Base64.encode(password));



                 /)  (\
            .-._((,~~.))_.-,
             `-.   @@   ,-'
               / ,n--n. \
       (`'\   ( ( .__. ) )  /`')
        `.'"._ ) `----' (_,"`.'
          "._             _,"
             /            \
       hjw  (              )
       `97  (`-.__    __.-')
             \   /`--'\   /
              ) /      \ (
             /._\      /_,\

Power by CSDN论坛助手

#4



Sorry,我的回答方向错误 :)

你如果是访问基于认证的网站用楼上路人甲的方法是可行的。

如果是访问基于form的网站(不是认证的,就是简单的getParameter的话),直接把参数传过去即可。

#5


路人甲的方法我试了一下,结果是"java.io.IOException: Server returned HTTP response code: 403 "
不知道路人甲老兄用的Base64.encode是哪个package里的,我随便找了一个,也不知有没有问题

#6


还有CGIurl是怎么new出来的?
我写的是URL url = new URL("http://localhost:88/NASApp/myapp/myservlet");

#7


Identify yourself using HTTP Authentification
import java.net.*;
import java.io.*;

public class auth {

  URLConnection conn = null;

  public static void main (String args[]){
    auth a = new auth();
    a.doit(args);
    }

  public void doit(String args[]) {
    /*
    ** args[0]  is the URL protected
    ** args[1]  is the username
    ** args[2]  is the password
    */
    try {
      BufferedReader in = new BufferedReader(
          new InputStreamReader
             (openURLForInput(new URL(args[0]), args[1], args[2])));
      String line;
      while ((line = in.readLine()) != null) {
          System.out.println(line);
          }
      }
    catch (IOException e) {
      e.printStackTrace();
      }
    }

  public InputStream openURLForInput (URL url, String uname, String pword)
       throws IOException  {
    conn = url.openConnection();
    conn.setDoInput (true);
    conn.setRequestProperty ("Authorization",
       userNamePasswordBase64(uname,pword));
    conn.connect ();
    return conn.getInputStream();
    }

  public String userNamePasswordBase64(String username, String password) {
    return "Basic " + base64Encode (username + ":" + password);
    }

  private final static char base64Array [] = {
      'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H',
      'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',
      'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X',
      'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
      'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
      'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
      'w', 'x', 'y', 'z', '0', '1', '2', '3',
      '4', '5', '6', '7', '8', '9', '+', '/'
 };

  private static String base64Encode (String string)    {
    String encodedString = "";
    byte bytes [] = string.getBytes ();
    int i = 0;
    int pad = 0;
    while (i < bytes.length) {
      byte b1 = bytes [i++];
      byte b2;
      byte b3;
      if (i >= bytes.length) {
         b2 = 0;
         b3 = 0;
         pad = 2;
         }
      else {
         b2 = bytes [i++];
         if (i >= bytes.length) {
            b3 = 0;
            pad = 1;
            }
         else
            b3 = bytes [i++];
         }
      byte c1 = (byte)(b1 >> 2);
      byte c2 = (byte)(((b1 & 0x3) << 4) | (b2 >> 4));
      byte c3 = (byte)(((b2 & 0xf) << 2) | (b3 >> 6));
      byte c4 = (byte)(b3 & 0x3f);
      encodedString += base64Array [c1];
      encodedString += base64Array [c2];
      switch (pad) {
       case 0:
         encodedString += base64Array [c3];
         encodedString += base64Array [c4];
         break;
       case 1:
         encodedString += base64Array [c3];
         encodedString += "=";
         break;
       case 2:
         encodedString += "==";
         break;
       }
      }
      return encodedString;
  }

#8


好象很久没看到skyyoung(路人甲)了

#9


这种方法只能通过http的basic认证,对于自定义的form认证也无能为力。

#1


1、在web.xml中设置。在JB中有向导可以设置很方便的。

  <login-config>
    <auth-method>FORM</auth-method>
    <form-login-config>
      <form-login-page>/login.jsp</form-login-page>
      <form-error-page>/error.jsp</form-error-page>
    </form-login-config>
  </login-config>



2、你的form有特别格式。

<form method=”POST” action=”j_security_check”>
<input type=”text” name=”j_username”>
<input type=”password” name=”j_password”>
</form>

#2


具体可参阅我的网站相关文章 www.sharetop.com

-----------
我是燕赤霞,替人办事是要收钱的。

#3


URLConnection c = CGIurl.openConnection();
c.setDoOutput(true);
c.setUseCaches(false);
c.setRequestProperty("Authorization",Base64.encode(username)+" "+Base64.encode(password));



                 /)  (\
            .-._((,~~.))_.-,
             `-.   @@   ,-'
               / ,n--n. \
       (`'\   ( ( .__. ) )  /`')
        `.'"._ ) `----' (_,"`.'
          "._             _,"
             /            \
       hjw  (              )
       `97  (`-.__    __.-')
             \   /`--'\   /
              ) /      \ (
             /._\      /_,\

Power by CSDN论坛助手

#4



Sorry,我的回答方向错误 :)

你如果是访问基于认证的网站用楼上路人甲的方法是可行的。

如果是访问基于form的网站(不是认证的,就是简单的getParameter的话),直接把参数传过去即可。

#5


路人甲的方法我试了一下,结果是"java.io.IOException: Server returned HTTP response code: 403 "
不知道路人甲老兄用的Base64.encode是哪个package里的,我随便找了一个,也不知有没有问题

#6


还有CGIurl是怎么new出来的?
我写的是URL url = new URL("http://localhost:88/NASApp/myapp/myservlet");

#7


Identify yourself using HTTP Authentification
import java.net.*;
import java.io.*;

public class auth {

  URLConnection conn = null;

  public static void main (String args[]){
    auth a = new auth();
    a.doit(args);
    }

  public void doit(String args[]) {
    /*
    ** args[0]  is the URL protected
    ** args[1]  is the username
    ** args[2]  is the password
    */
    try {
      BufferedReader in = new BufferedReader(
          new InputStreamReader
             (openURLForInput(new URL(args[0]), args[1], args[2])));
      String line;
      while ((line = in.readLine()) != null) {
          System.out.println(line);
          }
      }
    catch (IOException e) {
      e.printStackTrace();
      }
    }

  public InputStream openURLForInput (URL url, String uname, String pword)
       throws IOException  {
    conn = url.openConnection();
    conn.setDoInput (true);
    conn.setRequestProperty ("Authorization",
       userNamePasswordBase64(uname,pword));
    conn.connect ();
    return conn.getInputStream();
    }

  public String userNamePasswordBase64(String username, String password) {
    return "Basic " + base64Encode (username + ":" + password);
    }

  private final static char base64Array [] = {
      'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H',
      'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P',
      'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X',
      'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f',
      'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
      'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
      'w', 'x', 'y', 'z', '0', '1', '2', '3',
      '4', '5', '6', '7', '8', '9', '+', '/'
 };

  private static String base64Encode (String string)    {
    String encodedString = "";
    byte bytes [] = string.getBytes ();
    int i = 0;
    int pad = 0;
    while (i < bytes.length) {
      byte b1 = bytes [i++];
      byte b2;
      byte b3;
      if (i >= bytes.length) {
         b2 = 0;
         b3 = 0;
         pad = 2;
         }
      else {
         b2 = bytes [i++];
         if (i >= bytes.length) {
            b3 = 0;
            pad = 1;
            }
         else
            b3 = bytes [i++];
         }
      byte c1 = (byte)(b1 >> 2);
      byte c2 = (byte)(((b1 & 0x3) << 4) | (b2 >> 4));
      byte c3 = (byte)(((b2 & 0xf) << 2) | (b3 >> 6));
      byte c4 = (byte)(b3 & 0x3f);
      encodedString += base64Array [c1];
      encodedString += base64Array [c2];
      switch (pad) {
       case 0:
         encodedString += base64Array [c3];
         encodedString += base64Array [c4];
         break;
       case 1:
         encodedString += base64Array [c3];
         encodedString += "=";
         break;
       case 2:
         encodedString += "==";
         break;
       }
      }
      return encodedString;
  }

#8


好象很久没看到skyyoung(路人甲)了

#9


这种方法只能通过http的basic认证,对于自定义的form认证也无能为力。