Java带有验证码的模拟登陆

本文介绍了使用Java进行带有验证码的模拟登录的过程。在尝试登录过程中遇到验证码过期的问题,解决方案是先请求验证码图片,识别后保存图片请求的Cookie,然后在模拟登录时携带该Cookie,确保验证码的有效性。经过调整后的代码成功实现了模拟登录。
摘要由CSDN通过智能技术生成
  • 需求:

        最近得到一个需求,需要模拟登陆网页,然后通过网页接口获取相应数据。一共两个网页,其中没有验证码的网页比较容易的模拟登陆成功。但是另一个带有验证码(图片)却总是登陆失败。

  • 代码:
获取识别后的验证码
public class AliYun {
    private static Logger logger = Logger.getLogger(AliYun.class);
    //    通过图片请求地址   获取图片Base64编码
    public static String getImageStrFromUrl(String imgURL) {
        byte[] data = null;
        InputStream inStream = null;
        try {
            // 创建URL
            URL url = new URL(imgURL);
            // 创建链接       (注意:稍后更改代码在这一部分)
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET");
            conn.setConnectTimeout(5 * 1000);
            inStream = conn.getInputStream();
            BufferedImage src = ImageIO.read(inStream);
            File file = new File("D:\\temp.jpg");
            ImageIO.write(src, "jpg", file);
            InputStream inputStream = new FileInputStream(file);
            data = new byte[inputStream.available()];
            inputStream.read(data);
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                inStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        // 对字节数组Base64编码
        BASE64Encoder encoder = new BASE64Encoder();
        // 返回Base64编码过的字节数组字符串
        return encoder.encode(data);
    }


    //    获取识别后的验证码
    public static String getLoginCode(String imgPath) {
        String baseImg = getImageStrFromUrl(imgPath);//base64转换
        baseImg = baseImg.replaceAll("\\r\\n", "");
        String host = "http://jisuyzmsb.market.alicloudapi.com";
        String path = "/captcha/recognize";
        String appcode = "你购买接口之后的Code";
        Map<String, String> bodys = new HashMap<String, String>();
        bodys.put("pic", baseImg);

        HttpRequest request = HttpRequest.post(host + path + "?type=en4", bodys, true).header("Authorization", "APPCODE " + appcode).header("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
        String result = request.body();
        logger.debug("阿里云接口识别结果:" + result);
        JSONObject jsonObject = JSON.parseObject(result);
        if (jsonObject.containsKey
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值