携程去哪儿机票爬虫,添加ip代理请求携程和去哪儿网,Java语言

  • Y0_963927
    了解作者
  • 30.5KB
    文件大小
  • zip
    文件格式
  • 0
    收藏次数
  • VIP专享
    资源类型
  • 0
    下载次数
  • 2022-06-05 09:35
    上传日期
携程去哪儿机票爬虫,添加ip代理请求携程和去哪儿网,Java语言
携程去哪儿机票爬虫.zip
  • 携程去哪儿机票爬虫
  • Test6.java
    3KB
  • Test8.java
    1.7KB
  • Test1.java
    1.9KB
  • BSI-FP&A Assistant Manager- Winnie Zhou-20211207.doc
    51.5KB
  • proxy.zip
    724B
  • Test3.java
    2.2KB
  • Test5.java
    2.6KB
  • Test4.java
    2.2KB
  • pom.xml
    3.1KB
  • TextUtils.java
    7.6KB
  • Test2.java
    1.6KB
  • Test7.java
    5.2KB
内容介绍
package com.kongjianma.yeegu; import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Random; public class TextUtils { public static String getSecPassword(String password) { try { byte[] hash = MessageDigest.getInstance("MD5").digest(password.getBytes("UTF-8")); StringBuilder hex = new StringBuilder(hash.length * 2); for (byte b : hash) { if ((b & 0xFF) < 0x10) { hex.append("0"); } hex.append(Integer.toHexString(b & 0xFF)); } return hex.toString(); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return null; } private final static String BIRTH_DATE_FORMAT = "yyyyMMdd"; // 身份证号码中的出生日期的格式 private final static Date MINIMAL_BIRTH_DATE = new Date(-2209017600000L); // 身份证的最小出生日期,1900年1月1日 private final static int NEW_CARD_NUMBER_LENGTH = 18; private final static int OLD_CARD_NUMBER_LENGTH = 15; private final static char[] VERIFY_CODE = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' }; // 18位身份证中最后一位校验码 private final static int[] VERIFY_CODE_WEIGHT = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };// 18位身份证中,各个数字的生成校验码时的权值 /** * 如果是15位身份证号码,则自动转换为18位 * * @param cardNumber * @return */ public static boolean check(String cardNumber){ if (null != cardNumber){ cardNumber = cardNumber.trim(); if (OLD_CARD_NUMBER_LENGTH == cardNumber.length()){ cardNumber = contertToNewCardNumber(cardNumber); } return validate(cardNumber); } return false; } public static boolean validate(String cardNumber){ boolean result = true; result = result && (null != cardNumber); // 身份证号不能为空 result = result && NEW_CARD_NUMBER_LENGTH == cardNumber.length(); // 身份证号长度是18(新证) // 身份证号的前17位必须是阿拉伯数字 for (int i = 0; result && i < NEW_CARD_NUMBER_LENGTH - 1; i++){ char ch = cardNumber.charAt(i); result = result && ch >= '0' && ch <= '9'; } // 身份证号的第18位校验正确 result = result && (calculateVerifyCode(cardNumber) == cardNumber .charAt(NEW_CARD_NUMBER_LENGTH - 1)); // 出生日期不能晚于当前时间,并且不能早于1900年 try{ Date birthDate = new SimpleDateFormat(BIRTH_DATE_FORMAT) .parse(getBirthDayPart(cardNumber)); result = result && null != birthDate; result = result && birthDate.before(new Date()); result = result && birthDate.after(MINIMAL_BIRTH_DATE); /** * 出生日期中的年、月、日必须正确,比如月份范围是[1,12], * 日期范围是[1,31],还需要校验闰年、大月、小月的情况时, * 月份和日期相符合 */ String birthdayPart = getBirthDayPart(cardNumber); String realBirthdayPart = new SimpleDateFormat(BIRTH_DATE_FORMAT) .format(birthDate); result = result && (birthdayPart.equals(realBirthdayPart)); }catch(Exception e){ result = false; } return result; } private static String getBirthDayPart(String cardNumber){ return cardNumber.substring(6, 14); } /** * 校验码(第十八位数): * * 十七位数字本体码加权求和公式 S = Sum(Ai * Wi), i = 0...16 ,先对前17位数字的权求和; * Ai:表示第i位置上的身份证号码数字值 Wi:表示第i位置上的加权因子 Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 * 2; 计算模 Y = mod(S, 11)< 通过模得到对应的校验码 Y: 0 1 2 3 4 5 6 7 8 9 10 校验码: 1 0 X 9 * 8 7 6 5 4 3 2 * * @param cardNumber * @return */ private static char calculateVerifyCode(CharSequence cardNumber){ int sum = 0; for (int i = 0; i < NEW_CARD_NUMBER_LENGTH - 1; i++){ char ch = cardNumber.charAt(i); sum += ((int) (ch - '0')) * VERIFY_CODE_WEIGHT[i]; } return VERIFY_CODE[sum % 11]; } /** * 把15位身份证号码转换到18位身份证号码<br> * 15位身份证号码与18位身份证号码的区别为:<br> * 1、15位身份证号码中,"出生年份"字段是2位,转换时需要补入"19",表示20世纪<br> * 2、15位身份证无最后一位校验码。18位身份证中,校验码根据根据前17位生成 * * @param cardNumber * @return */ private static String contertToNewCardNumber(String oldCardNumber){ StringBuilder buf = new StringBuilder(NEW_CARD_NUMBER_LENGTH); buf.append(oldCardNumber.substring(0, 6)); buf.append("19"); buf.append(oldCardNumber.substring(6)); buf.append(calculateVerifyCode(buf)); return buf.toString(); } public static String MD5(String s) { char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; try { byte[] btInput = s.getBytes(); MessageDigest mdInst = MessageDigest.getInstance("MD5"); mdInst.update(btInput); byte[] md = mdInst.digest(); int j = md.length; char str[] = new char[j * 2]; int k = 0; for (int i = 0; i < j; i++) { byte byte0 = md[i]; str[k++] = hexDigits[byte0 >>> 4 & 0xf]; str[k++] = hexDigits[byte0 & 0xf]; } return new String(str); } catch (Exception e) { e.printStackTrace(); return null; } } public static String getNonceNum(int count) { StringBuffer str = new StringBuffer(); Random random = new Random(); for (int i = 0; i < count; i++) { str.append(random.nextInt(10)); } return str.toString(); } public static String getNonceStr(int count) { char[] radixDigits = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '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' }; int length = radixDigits.length; StringBuffer nonceStr = new StringBuffer(); for (int i = 0; i < count; i++) { Random random = new Random(); nonceStr.append(radixDigits[random.nextInt(length)]); } return nonceStr.toString(); } /** * 检测是否有emoji表情 * * @param source * @return */ public static boolean containsEmoji(String source) { int len = source.length(); for (int i = 0; i < len; i++) { char codePoint = source.charAt(i); if (!isEmojiCharacter(codePoint)) { //如果不能匹配,则该字符是Emoji表情 return true; } } return false; } /** * 判断是否是Emoji * * @param codePoint 比较的单个字符 * @return */ private static boolean isEmojiCharacter(char codePoint) { return (codePoint == 0x0) || (codePoint == 0x9) || (codePoint == 0xA) || (codePoint == 0xD) || ((codePoint >= 0x20) && (codePoint <= 0xD7FF)) || ((codePoint >= 0xE000) && (codePoint <= 0xFFFD)) || ((codePoint >= 0x10000) && (codePoint <= 0x10FFFF)); } }
评论
    相关推荐
    • 爬虫javaDemo
      爬虫demo,直接使用,可实现各种网站内容的爬取,易于镶入已有项目,简单实用
    • 网络爬虫java
      网络爬虫,用java简单实现,能实现对一个网站的信息抓取,只需要修改一下正则表达式就行。
    • 网络爬虫java
      网络爬虫java
    • 网络爬虫JAVA扩展包
      网络爬虫JAVA扩展包,有commons-httpclient-3.1.jar, htmllexer.jar, htmlparser.jar, 试用了,可以正常用
    • 网络爬虫JAVA
      网络爬虫JAVA 网络爬虫JAVA
    • 网络爬虫 java
      java版本的网络爬虫,主要爬门户网站的新闻。代码导入ecplise就能用。抓取新闻,分析新闻,入库全部实现。内附数据库脚本。
    • 简单网络爬虫Java代码(借鉴)
      一个简单的网络爬虫代码,附带所需jar包,初学者可以借鉴
    • 京东苏宁爬虫java源码
      自己写的京东 苏宁 商品Java爬虫 用jsoup httpClient
    • 网络爬虫 Java
      网络爬虫源码,直接部署到MyEclipse下就可运行,只能爬搜狐网站
    • 网络爬虫 Java Websphinx
      Java编写的一个网络爬虫的程序,有相当参考价值