中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java獲取任意http網頁源代碼的方法

發布時間:2020-10-21 20:52:39 來源:腳本之家 閱讀:144 作者:dackwind 欄目:編程語言

本文實例講述了JAVA獲取任意http網頁源代碼。分享給大家供大家參考,具體如下:

JAVA獲取任意http網頁源代碼可實現如下功能:

1. 獲取任意http網頁的代碼
2. 獲取任意http網頁去掉HTML標簽的代碼

Webpage類:

/**
 * 網頁操作相關類
 */
package test;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.URL;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
 * @author winddack
 *
 */
public class Webpage {
  private String pageUrl;//定義需要操作的網頁地址
  private String pageEncode="UTF8";//定義需要操作的網頁的編碼
  public String getPageUrl() {
    return pageUrl;
  }
  public void setPageUrl(String pageUrl) {
    this.pageUrl = pageUrl;
  }
  public String getPageEncode() {
    return pageEncode;
  }
  public void setPageEncode(String pageEncode) {
    this.pageEncode = pageEncode;
  }
  //定義取源碼的方法
  public String getPageSource()
  {
    StringBuffer sb = new StringBuffer();
    try {
      //構建一URL對象
      URL url = new URL(pageUrl);
      //使用openStream得到一輸入流并由此構造一個BufferedReader對象
      BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream(), pageEncode));
      String line;
      //讀取www資源
      while ((line = in.readLine()) != null)
      {
        sb.append(line);
      }
      in.close();
    }
    catch (Exception ex)
    {
      System.err.println(ex);
    }
    return sb.toString();
  }
  //定義一個把HTML標簽刪除過的源碼的方法
  public String getPageSourceWithoutHtml()
  {
    final String regEx_script = "<script[^>]*?>[\\s\\S]*?<\\/script>"; // 定義script的正則表達式
    final String regEx_style = "<style[^>]*?>[\\s\\S]*?<\\/style>"; // 定義style的正則表達式
    final String regEx_html = "<[^>]+>"; // 定義HTML標簽的正則表達式
    final String regEx_space = "\\s*|\t|\r|\n";//定義空格回車換行符
    String htmlStr = getPageSource();//獲取未處理過的源碼
    Pattern p_script = Pattern.compile(regEx_script, Pattern.CASE_INSENSITIVE);
    Matcher m_script = p_script.matcher(htmlStr);
    htmlStr = m_script.replaceAll(""); // 過濾script標簽
    Pattern p_style = Pattern.compile(regEx_style, Pattern.CASE_INSENSITIVE);
    Matcher m_style = p_style.matcher(htmlStr);
    htmlStr = m_style.replaceAll(""); // 過濾style標簽
    Pattern p_html = Pattern.compile(regEx_html, Pattern.CASE_INSENSITIVE);
    Matcher m_html = p_html.matcher(htmlStr);
    htmlStr = m_html.replaceAll(""); // 過濾html標簽
    Pattern p_space = Pattern.compile(regEx_space, Pattern.CASE_INSENSITIVE);
    Matcher m_space = p_space.matcher(htmlStr);
    htmlStr = m_space.replaceAll(""); // 過濾空格回車標簽
    htmlStr = htmlStr.trim(); // 返回文本字符串
    htmlStr = htmlStr.replaceAll("&nbsp;", "");
    htmlStr = htmlStr.substring(0, htmlStr.indexOf("。")+1);
    return htmlStr;
  }
}

調用:

Webpage page=new Webpage();
page.setPageUrl("http://www.baidu.com");
String code=page.getPageSourceWithoutHtml();
System.out.println(code);

PS:這里再為大家提供2款非常方便的正則表達式工具供大家參考使用:

JavaScript正則表達式在線測試工具:
http://tools.jb51.net/regex/javascript

正則表達式在線生成工具:
http://tools.jb51.net/regex/create_reg

更多關于java算法相關內容感興趣的讀者可查看本站專題:《Java正則表達式技巧大全》、《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇康县| 水富县| 普宁市| 敦化市| 灵山县| 楚雄市| 吴堡县| 龙口市| 武清区| 浪卡子县| 团风县| 克什克腾旗| 西盟| 绥滨县| 长沙县| 秦安县| 河间市| 黄梅县| 华阴市| 和平区| 新巴尔虎右旗| 长春市| 大余县| 阿拉尔市| 盖州市| 塔河县| 巴林右旗| 巴彦淖尔市| 青神县| 嘉鱼县| 佳木斯市| 湘乡市| 卢龙县| 三原县| 江陵县| 清水河县| 刚察县| 金秀| 寿宁县| 凉山| 翁牛特旗|