android Jsoup获取网站内容 android获取新闻标题实例

发布时间 - 2026-01-11 00:26:50    点击率:

近期做简单的新闻客户端界面使用到了Jsoup获取,使用起来特别方便,这也是被我一个学长称为学android网络必学的一个东西,在此也是分享一下自己近期所学。

首先还是给出效果:

上面是通过textview显示的一个从网站上获取的所有内容的显示,下面是通过listview显示一下获取的新闻的标题,如此显示比较便于理解。

MainActivity:

import android.app.Activity; 
import android.content.Intent; 
import android.net.Uri; 
import android.os.AsyncTask; 
import android.os.Bundle; 
import android.text.method.ScrollingMovementMethod; 
import android.util.Log; 
import android.view.Menu; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ArrayAdapter; 
import android.widget.ListView; 
import android.widget.TextView; 
 
import org.apache.http.HttpResponse; 
import org.apache.http.client.HttpClient; 
import org.apache.http.client.methods.HttpPost; 
import org.apache.http.impl.client.DefaultHttpClient; 
import org.apache.http.util.EntityUtils; 
import org.jsoup.Jsoup; 
import org.jsoup.nodes.Document; 
import org.jsoup.nodes.Element; 
import org.jsoup.select.Elements; 
 
import java.util.ArrayList; 
import java.util.List; 
 
@SuppressWarnings("unused") 
public class MainActivity extends Activity { 
  private TextView TV_HTMLCode; 
  //此处搞一个TextView主要来显示News列表里面存储的内容,仅仅便于分析和理解 
 
  private String URL_EOL = "http://www.cnwust.com/newsList/1_1", 
      TAG = "ATAG"; 
  //这是索要获取内容的网址 
 
  private List<News> NewsList; 
  //自定义的News的类,用于存放索要获取新闻的目录、时间以及点击后显示的网址 
 
  private ListView LV_Result; 
  private ArrayAdapter<String> LV_Adapter; 
 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    LV_Result = (ListView) findViewById(R.id.LV_Result); 
    TV_HTMLCode = (TextView) findViewById(R.id.TV_HTMLCode); 
    TV_HTMLCode.setMovementMethod(ScrollingMovementMethod.getInstance()); 
 
    ConnectTask C1 = new ConnectTask(); 
    C1.execute(); 
 
  } 
 
  @Override 
  public boolean onCreateOptionsMenu(Menu menu) { 
    getMenuInflater().inflate(R.menu.menu_main, menu); 
    return true; 
  } 
 
  public class ConnectTask extends AsyncTask<Void, Void, String> { 
 
    @Override 
    protected String doInBackground(Void... params) { 
      String result = ConnectEOL(); 
      return result; 
    } 
 
    @Override 
    protected void onPostExecute(String result) { 
      // TV_HTMLCode.setText(result); 
      NewsList = getNews(result); 
      List<String> NewsTitles = new ArrayList<String>(); 
      for (News news : NewsList) { 
        TV_HTMLCode.append(news.getNewsTitle() + "\n"); 
        TV_HTMLCode.append(news.getNewsTime() + "\n"); 
        TV_HTMLCode.append(news.getNewsUrl() + "\n"); 
        NewsTitles.add(news.getNewsTitle()); 
      } 
    /* 为ListView添加适配器 */ 
 
      LV_Adapter = new ArrayAdapter<String>(MainActivity.this, 
          android.R.layout.simple_list_item_1, NewsTitles); 
      LV_Result.setAdapter(LV_Adapter); 
 
    /* 为ListView添加点击打开对应网页功能 */ 
      LV_Result.setOnItemClickListener(new OnItemClickListener() { 
 
        @Override 
        public void onItemClick(AdapterView<?> arg0, View arg1, 
                    int arg2, long arg3) { 
          final Uri uri = Uri.parse(NewsList.get(arg2).getNewsUrl()); 
          final Intent it = new Intent(Intent.ACTION_VIEW, uri); 
          startActivity(it); 
        } 
 
      }); 
      //此处为了方便就点击就直接调用设备默认浏览器打开网址 
 
      super.onPostExecute(result); 
 
 
    } 
 
  } 
 
  /* 连接EOL的方法 返回整个网页经过截取之后的的源代码 */ 
  public String ConnectEOL() { 
    String result = ""; 
    try { 
      HttpClient httpclient = new DefaultHttpClient(); 
      HttpPost httppost = new HttpPost(URL_EOL); 
      HttpResponse response = httpclient.execute(httppost); 
      String Res = EntityUtils.toString(response.getEntity(), "UTF-8"); 
 
      int st = Res.indexOf("<div id=\"result\">"); 
      int ed = Res.indexOf("<div id=\"pager\">"); 
      //这边算是最重要的部分,代码获取的便是这两段之间的部分。 
 
      String content = Res.substring(st, ed); 
      st = content.indexOf("<ul>") + 4; 
      ed = content.indexOf("</ul>"); 
      content = content.substring(st, ed); 
      result = content; 
    } catch (Exception e) { 
      Log.d(TAG, e.toString()); 
    } 
    return result; 
  } 
 
  /* 对源代码进行解析截取的方法 返回一个News数组 */ 
  public List<News> getNews(String HTMLCode) { 
    List<News> newsList = new ArrayList<News>(); 
    Document doc = Jsoup.parse(HTMLCode); 
    Log.d(TAG, "解析html中"); 
    Elements lis = doc.getElementsByTag("li"); 
    Log.d(TAG, "lis的size " + lis.size()); 
    for (Element li : lis) { 
      String newstime = li.getElementsByTag("span").text(); 
      String newstitle = li.getElementsByTag("a").text(); 
      String newsurl = li.getElementsByTag("a").attr("href"); 
      //这三段算是Jsoup从html中获取内容的关键了,很容易理解。 
 
      newsurl = newsurl.replace("/news", "http://www.cnwust.com/news"); 
      //直接从html的代码中获取的URL是相对路径,此处使用replace改为绝对路径 
 
      Log.d(TAG, newstime); 
      Log.d(TAG, newstitle); 
      Log.d(TAG, newsurl); 
 
      News newst = new News(); 
      newst.setNewsTime(newstime); 
      newst.setNewsTitle(newstitle); 
      newst.setNewsUrl(newsurl); 
      newsList.add(newst); 
    } 
    return newsList; 
  } 
} 

News:

public class News { 
  private String newsTime; 
  private String newsUrl; 
  private String newsTitle; 
 
  public News() { 
 
  } 
 
  public News(String newsTitle, String newsTime, String newsUrl) { 
    this.newsTime = newsTime; 
    this.newsUrl = newsUrl; 
    this.newsTitle = newsTitle; 
  } 
 
  public String getNewsTime() { 
    return newsTime; 
  } 
 
  public void setNewsTime(String newsTime) { 
    this.newsTime = newsTime; 
  } 
 
  public String getNewsUrl() { 
    return newsUrl; 
  } 
 
  public void setNewsUrl(String newsUrl) { 
    this.newsUrl = newsUrl; 
  } 
 
  public String getNewsTitle() { 
    return newsTitle; 
  } 
 
  public void setNewsTitle(String newsTitle) { 
    this.newsTitle = newsTitle; 
  } 
 
} 

activity_main:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  xmlns:tools="http://schemas.android.com/tools" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" 
  android:paddingBottom="@dimen/activity_vertical_margin" 
  android:paddingLeft="@dimen/activity_horizontal_margin" 
  android:paddingRight="@dimen/activity_horizontal_margin" 
  android:paddingTop="@dimen/activity_vertical_margin" 
  tools:context=".NewsList" > 
 
  <TextView 
    android:id="@+id/TV_HTMLCode" 
    android:layout_width="match_parent" 
    android:layout_height="150dp" 
    android:layout_above="@+id/LV_Result" 
    android:layout_alignParentTop="true" 
    android:layout_centerHorizontal="true" 
    android:scrollbars="vertical" /> 
 
  <ListView 
    android:id="@+id/LV_Result" 
    android:layout_width="match_parent" 
    android:layout_height="230dp" 
    android:layout_alignLeft="@+id/TV_HTMLCode" 
    android:layout_alignParentBottom="true" > 
  </ListView> 
 
</RelativeLayout> 

此处对html代码的解析可能部分新手还是不太清楚,在此也是建议使用chrome浏览器,可以直接查看网站的源码。(有部分加密的网站看不到)下面看一下具体使用的截图:

1、首先先要打开到你要获取内容的网站


2、右击你要获取的内容,并选择  审查元素。


3、使用Jsoup解析html代码。


最后是附上源码下载地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# android  # Jsoup获取网站内容  # android获取新闻标题  # Jsoup获取  # 使用javascript为网页增加夜间模式  # 通过Nodejs搭建网站简单实现注册登录流程  # 让网站自动生成章节目录索引的多个js代码  # 利用JS测试目标网站的打开响应速度  # nodejs+express实现文件上传下载管理网站  # AngularJS实现网站换肤实例  # 基于JavaScript或jQuery实现网站夜间/高亮模式  # 你要  # 在此  # 源代码  # 这是  # 近期  # 下载地址  # 不太  # 最重要  # 很容易  # 可以直接  # 自定义  # 看一下  # 开到  # 所有内容  # 这三  # 大家多多  # 两段  # 右击  # 客户端  # 这也是 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 三星网站视频制作教程下载,三星w23网页如何全屏?  如何安全更换建站之星模板并保留数据?  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  如何彻底删除建站之星生成的Banner?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  Laravel定时任务怎么设置_Laravel Crontab调度器配置  Android okhttputils现在进度显示实例代码  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  如何自定义建站之星网站的导航菜单样式?  Laravel如何生成API文档?(Swagger/OpenAPI教程)  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  LinuxShell函数封装方法_脚本复用设计思路【教程】  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  Laravel如何配置Horizon来管理队列?(安装和使用)  Swift中swift中的switch 语句  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  Laravel如何自定义错误页面(404, 500)?(代码示例)  phpredis提高消息队列的实时性方法(推荐)  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  高性能网站服务器配置指南:安全稳定与高效建站核心方案  ,怎么在广州志愿者网站注册?  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  Laravel集合Collection怎么用_Laravel集合常用函数详解  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  如何用y主机助手快速搭建网站?  Laravel如何使用Sanctum进行API认证?(SPA实战)  ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法  Laravel安装步骤详细教程_Laravel环境搭建指南  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  如何用已有域名快速搭建网站?  如何实现javascript表单验证_正则表达式有哪些实用技巧  如何在云主机快速搭建网站站点?  如何在服务器上三步完成建站并提升流量?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  如何快速打造个性化非模板自助建站?  如何在IIS服务器上快速部署高效网站?  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  详解Android图表 MPAndroidChart折线图  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  PHP 500报错的快速解决方法  Python文件异常处理策略_健壮性说明【指导】  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  如何在阿里云通过域名搭建网站?  JavaScript如何操作视频_媒体API怎么控制播放