网页版的模拟登陆有验证码的网站

   模拟登陆就是向登陆链接提交表单。

  没有验证码的登陆很好办,但是现在的网站10个里8个有验证码。验证码识别算法正确率又很低。

如果是脚本模拟登陆的话直接把验证码拉回来人工识别,网页版的话如果把别的网站的验证码拉回来再显示在自己的网站上,多人访问的话就会造成验证码和sessionId不匹配而登不上。所以直接把对方的验证码直接写到我的页面上。

用到apache httpclient包,用ImageIO读取在写入。

方案:

public void getYzm(HttpServletResponse respons){
        HttpGet hg=new HttpGet(yzmUrl+Math.random());
        try {
            CloseableHttpResponse response=client.execute(hg);
            HttpEntity he=response.getEntity();
            InputStream is=he.getContent();
            OutputStream os=respons.getOutputStream();
            BufferedImage bi=ImageIO.read(is);
            respons.setHeader("Cache-Control", "no-cache");
            respons.setHeader("Pragma", "no-cache");
            respons.setDateHeader("Expires", 0);
            respons.setContentType("image/gif");
            ImageIO.write(bi,"gif",os);
            is.close();
            os.close();

        } catch (IOException e) {
            e.printStackTrace();
        }
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值