600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > Spring Boot 将image/png;base64格式图片以文件形式存储 并以url替换html文本src的内容

Spring Boot 将image/png;base64格式图片以文件形式存储 并以url替换html文本src的内容

时间:2022-09-28 04:12:58

相关推荐

Spring Boot 将image/png;base64格式图片以文件形式存储 并以url替换html文本src的内容

文章目录

前言一、数据准备二、图片上传指定服务器目录1. jsoup的方式解析出对应src内容2. base64图片上传指定服务器目录3. 更换src的内容为discuzQ论坛访问url 三、调用discuzQ论坛发布主题接口,完成主题添加1. spring boot 发送post请求 总结

前言

功能需求的背景和可以解决的问题:

(1)存在两个服务,本平台(spring boot)和discuzQ论坛(PHP)。需要将本平台中录上的问题,包括标题,问题,解答等等内容,在平台测推送至论坛当中,并展现。

(2)平台和论坛两个服务对问题的格式显示有所不同,文本的影响并不大,主要影响点就在图片。平台上的图片是以image/png;base64的形式来展现的,论坛显示html文本并不支持此种格式的显示,此为需要解决的问题。

功能需求流程大体为:

(1)在本平台中获取到已经存储好的问题详情的html内容,此内容包含image/png;base64图片

(2)通过Jsoup,获取到html文本中img src的内容

(3)通过base64转换方式生成文件字节流,上传至论坛指定目录

(4)根据论坛服务生成访问图片url,并使用Jsoup替换

(5)spring boot 发送post请求,调用论坛发布主题接口,完成主题添加

一、数据准备

从平台中获取到问题详细内容,比如说有文本有image/png;base64图片:

String strData = "<p>以下为译文:</p><p>JavaScript的框架数量非常多,而且几乎每隔几个月就会有新的框架问世。我知道有些人对于层出不穷的JavaScript框架感到厌烦,因为这些新框架真的太多了。不过,还是有人坚持使用vanilla JavaScript。</p><p>这些JavaScript框架的出现实际上是为了方便开发者,帮助他们提高效率,使其能够产出更好的代码。</p><p>不过我想不仅仅是我,其他人也可能注意到了,这些框架随着时间的推移变得越来越复杂,反而失去了一些本应该带给开发者的好处——即节省开发者的时间。</p><p>我尝试的第一个框架是Angular 1,我花了相当多的时间来学习它。在那个时代,它非常棒。接着Angular 2出现了。Angular 2让我觉得它变得“焕然一新”(也许因为我当时是JavaScript的新手),感觉像是又重新学了个完全不同的框架。</p><p>后来,我又尝试使用了React,但感觉它太复杂了,甚至一开始就不符合我的需求。虽然这么说,但是不可否认的是,React依然是一个好的框架,只是不适合我。我认为React适合像Facebook这样的大型应用,但是不适合我这样创建只有少数人使用的简单网络应用的人。(这个观点可能不那么“讨喜”)</p><p>然后我又转向了Vue,对我来说,Vue是一股清流——它不需要我设置复杂的开发工具,只需要插入一个脚本标签,就能快速开始项目。</p><p class=\"ql-indent-1\"><img src=\"\"></p><p>(图源Vue.js官网)</p><p>学习起来也不是很复杂,而且它完全满足我的需求。所以Vue成了我心中的No.1框架,直到现在我仍然在使用它创建所有的东西。</p><p>再后来Vue 2出现了,其中有一些小的增量变化。而这时由于我已经有能力适应这些变化了,所以我并不在意这些改变。</p><p>另外还有一些别的框架,比如ViteJs和NuxtJs,我可以把它们作为基于Vue的框架使用,(我认为ViteJs现在已经独立于Vue,所以可以把它与其他框架如React和Svelte结合起来一起使用)。</p><p>没什么好抱怨的,因为从Vue 1切换到Vue 2也没有什么新东西需要学习的。</p><p>但是,更新换代似乎永远不会停止了。最近,Vue 3取代了Vue 2,成为默认版本。我相信开发者投入了大量的精力来开发和创造让Vue 3变得更好。</p><p>虽然从Vue 2迁移到Vue 3并不困难,但我觉得相比于Vue 1和Vue 2,Vue 3复杂了好几倍。Vue 3让我感觉好像丧失了生产力,而且使用Vue 1时享受的简单性似乎也不复存在了。</p><p>所以,为什么我们不能在使这些框架变得更好的同时,不使它们的使用变得更加复杂呢?这是不是不可能实现?</p><p>你是否遇到过这样的问题呢?你用过哪些好用的JavaScript的框架呢?欢迎留言告诉我们。</p>";

二、图片上传指定服务器目录

1. jsoup的方式解析出对应src内容

代码如下(示例):

Document document = Jsoup.parse(strData);Elements elements = document.getElementsByTag("img");String base64Image = el.attr("src");

这样就可以拿到src中图片base64的数据

2. base64图片上传指定服务器目录

代码如下:

/*** 将base64字符串,生成文件** @param fileBase64String* @param filePath 是指定论坛服务器的文件目录路径* @param fileName 是上传图片的名称,此处UUID生成* @return*/public static File convertBase64ToFile(String fileBase64String, String filePath, String fileName) {BufferedOutputStream bos = null;FileOutputStream fos = null;File file = null;try {File dir = new File(filePath);//判断文件目录是否存在if (!dir.exists() && !dir.isDirectory()) {dir.mkdirs();}String[] baseStrs = fileBase64String.split(",");BASE64Decoder base64Decoder = new BASE64Decoder();byte[] bfile = base64Decoder.decodeBuffer(baseStrs[1]);file = new File(filePath + File.separator + fileName);fos = new FileOutputStream(file);bos = new BufferedOutputStream(fos);bos.write(bfile);return file;} catch (Exception e) {e.printStackTrace();} finally {if (bos != null) {try {bos.close();} catch (IOException e1) {e1.printStackTrace();}}if (fos != null) {try {fos.close();} catch (IOException e1) {e1.printStackTrace();}}}return null;}

注意:这里fileBase64String的参数,就是(1)中获取的base64Image,在上传中注意…传逗号后面的内容

3. 更换src的内容为discuzQ论坛访问url

代码如下,此处我连接第一步给一个整体示例:

/*** 替换image成url地址** @param strData*/public static String imageToFile(String strData){Document document = Jsoup.parse(strData);Elements elements = document.getElementsByTag("img");for (Element el : elements) {String base64Image = el.attr("src");String path = "上传discuzQ的目录路径";String name = UUID.randomUUID().toString().replaceAll("-", "") + ".png";File file = ImageToBase64Util.convertBase64ToFile(base64Image,path,name);String newUrl = "论坛服务器访问图片文件的路径,这个和上面的path不一定是同一个,注意服务器访问具体形式" + file.getName();el.attr("src",newUrl);}String newComment = document.body().toString();String result = newComment.substring(7, newComment.length() - 8);return result;}

newComment.substring(7, newComment.length() - 8);此处是自身业务需求,去掉了body标签,至此图文html已替换完成

三、调用discuzQ论坛发布主题接口,完成主题添加

1. spring boot 发送post请求

代码如下:

/*** post方式调用discuzQ接口保存数据** @param comment 这里就是已经替换过src内容的html文本* @throws Exception*/private static void postSendMessage(String comment) throws Exception {RestTemplate restTemplate = new RestTemplate();HttpHeaders headers = new HttpHeaders();MediaType type = MediaType.parseMediaType("application/json;charset=UTF-8");headers.setContentType(type);headers.add("Accept", "application/json, text/plain, */*");Theme theme = new Theme();theme.setTitle("平台推送问题");theme.setCategoryId(1);Content com = new Content();com.setText(comment);theme.setContent(com);HttpEntity<String> formEntity = new HttpEntity<String>(JSONUtil.toJsonStr(theme), headers);String url = "discuzQ论坛发布主题接口url";String result = restTemplate.postForObject(url, formEntity, String.class);JSONObject resultJsonObject = JSONObject.parseObject(result);if (resultJsonObject.get("Message").equals("接口调用成功")){System.out.println("接口调用成功");}else {throw new Exception("调用服务异常" + JSONUtil.toJsonStr(resultJsonObject.toJSONString()));}}

提示:这里本需求发送post请求到discuzQ论坛,是无登录状态模式下的推送,是根据自身业务已经调整过discuzQ论坛发布主题的源码,说明一下,如果想要发送发布主题,应该是需要登录信息等内容。

至此,在discuzQ论坛中可以显示:

推送问题,功能需求完成

总结

主要是对image/png;base64图片上传指定服务器目录,并生成相应src的url,以替换原先内容,以RestTemplate的方式推送信息,discuzQ可显示正常的图文内容,以上。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。