java实现解析html获取图片或视频url

一、前言

有时在实际项目中,比如发布某篇文章,需要取文章中的某张图片作为封面,那么此时需要文章内容,获取html内容中的图片地址作为封面,下面讲下如何获取html中的图片或视频地址。

二、实现

1.先定义一个工具类,解析html获取图片地址。

复制代码
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.stream.Collectors;

public class HtmlParseUtil {
	private static final String regEx_img="<img [^>]*src=\"([^>]*?)\" alt=([^>]*?)>";
	private static final String regEx_video="<video [^>]*src=\"([^>]*?)\">[\\s\\S]*?</video>";

	/**
	 * 解析html获取图片或视频
	 * @param content
	 * @return
	 */
	public static String htmlParseImgOrVedio(String content) {
		Pattern p = Pattern.compile(regEx_img, Pattern.CASE_INSENSITIVE);
		Matcher m = p.matcher(content);
		if(m.find()) {
			return m.group(1).trim();
		}else {
			p = Pattern.compile(regEx_video, Pattern.CASE_INSENSITIVE);
			m=p.matcher(content);
			if(m.find()) {
				return m.group(1).trim();
			}
		}
		return "";
	}
}

上面通过正则匹配获取src中的地址。

2.通过main方法调用看是否可获取。

复制代码
public static void main(String[] args) {
		String s="<p style=\"text-align: center;\"><img src=\"https://myoss.oss-cn-hangzhou.aliyuncs.com/task/e4d1afba664b415cf5bf40eda33b7ba0/2021-04-21/161897103374171750.png\" alt=\"\"></p><p><br></p><p>内容发布后跳转页面有待优化,进来的时候是<strong>测试简介</strong></p><p><strong><img src=\"https://myoss.oss-cn-hangzhou.aliyuncs.com/task/e4d1afba664b415cf5bf40eda33b7ba0/2021-04-21/161897102930795080.png\" alt=\"\"></strong></p>";
		String s1="<p><video class=\"edui-upload-video  vjs-default-skin   video-js\" controls=\"\" preload=\"none\" width=\"420\" height=\"280\" src=\"https://myoss.oss-cn-shenzhen.aliyuncs.com/task/2019-11-28/2019112819471601813428538534561557.mp4\"><source src=\"https://myoss.oss-cn-shenzhen.aliyuncs.com/task/2019-11-28/2019112819471601813428538534561557.mp4\" type=\"video/mp4\"/></video></p>";
		Pattern p = Pattern.compile(regEx_img, Pattern.CASE_INSENSITIVE);
		Matcher m = p.matcher(s);
		if(m.find()) {
			System.err.println(m.group(1).trim());
		}
		Pattern p1 = Pattern.compile(regEx_video, Pattern.CASE_INSENSITIVE);
		Matcher m1 = p1.matcher(s1);
		if(m1.find()) {
			System.err.println(m1.group(1).trim());
		}
	}

运行结果如下:

结果是正常获取到了图片或视频的url。

相关推荐
哈喽姥爷6 小时前
Spring Boot---自动配置原理和自定义Starter
java·spring boot·后端·自定义starter·自动配置原理
老华带你飞8 小时前
考研论坛平台|考研论坛小程序系统|基于java和微信小程序的考研论坛平台小程序设计与实现(源码+数据库+文档)
java·vue.js·spring boot·考研·小程序·毕设·考研论坛平台小程序
CHEN5_028 小时前
leetcode-hot100 11.盛水最多容器
java·算法·leetcode
songx_998 小时前
leetcode18(无重复字符的最长子串)
java·算法·leetcode
Yvonne爱编码9 小时前
AJAX入门-AJAX 概念和 axios 使用
前端·javascript·ajax·html·js
在路上`9 小时前
前端学习之后端java小白(三)-sql外键约束一对多
java·前端·学习
dazhong20129 小时前
Spring Boot 项目新增 Module 完整指南
java·spring boot·后端
果壳~10 小时前
【Python】爬虫html提取内容基础,bs4
爬虫·python·html
xrkhy10 小时前
SpringBoot之日志处理(logback和AOP记录操作日志)
java·spring boot·logback
搬山境KL攻城狮10 小时前
MacBook logback日志输出到绝对路径
java·intellij-idea·logback