用许多账号批量登陆
没做过
不知道从何学起
哪位兄长给个提示谢谢

解决方案 »

  1.   

    有帐号密码主动循环发起HTTP请求登录地址,如果没有图形码验证的话。
      

  2.   


    //比如这样
    for(..){
    String loginname="abc";
    String password="123";
    URL url = new URL("http://www.163.com/login.action?name=loginname&password=pwd");
    url.openConnection();
    }
    前提是,不用输入验证码。
    当然也可以用httpClient这个功能更强大
      

  3.   

    package test;   
      
    import org.apache.commons.httpclient.HttpClient;   
    import org.apache.commons.httpclient.methods.PostMethod;   
      
    /**  
     * 测试登录并提交表单功能  
     * @author adun  
     */  
    public class HttpTest {   
           
        static HttpClient CONN = new HttpClient();   
           
        static String DATA_ACTION = "http://localhost:8000/proc.jsp";   
        static String SIGNIN_ACTION = "http://localhost:8000/j_security_check";   
      
        public static void main(String[] args) throws Exception {   
            if(!postData()) {   
                System.out.println("尚未登录,尝试自动登录...");   
                postSignin();   
                postData();   
            }   
        }   
           
      /**  
         * 提交数据  
         * @return 是否提交成功  
         * @throws Exception  
         */  
       public static boolean postData() throws Exception {   
            UTF8PostMethod procPost = new UTF8PostMethod(DATA_ACTION);   
           procPost.addParameter("name", "天津爱通科技有限公司");   
            System.out.println("尝试提交数据...");   
            CONN.executeMethod(procPost);   
            String body = procPost.getResponseBodyAsString();   
            boolean success = body.indexOf("j_security_check") < 0;   
            if(!success) {   
               System.out.println("数据提交成功!");   
           }   
           return success;   
        }   
           
        /**  
         * 登录过程  
         * @throws Exception  
         */  
        public static void postSignin() throws Exception {   
            UTF8PostMethod signinPost = new UTF8PostMethod(SIGNIN_ACTION);   
            signinPost.addParameter("j_username", "admin");   
            signinPost.addParameter("j_password", "admin");   
            CONN.executeMethod(signinPost);   
        }   
    }   
      
    /**  
     * 重写PostMethod以解决UTF-8编码问题  
     * @author adun  
     */  
    class UTF8PostMethod extends PostMethod {   
       public UTF8PostMethod(String url) {   
            super(url);   
        }   
           
        @Override  
        public String getRequestCharSet() {   
            return "UTF-8";   
        }   
    } 找了篇代码,能给你点思路没?、
      

  4.   

    当然也可以用httpClient这个功能更强大
    还是解决不了验证码的问题,不过如果验证码信息写在cookie中,倒是好解决,当然话说回来,这样就不搞什么验证码了。