写点什么

在线问题反馈模块实战 (十)​: 实现图片预览功能

作者:bug菌
  • 2022-10-22
    上海
  • 本文字数:4175 字

    阅读完需:约 14 分钟

在线问题反馈模块实战(十)​:实现图片预览功能

👨‍🎓作者:bug 菌

✏️博客:​​CSDN​​​、​​掘金​​等

💌公众号:​​猿圈奇妙屋​

🚫特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合。

🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系 bug 菌处理。 

一、前言🔥

       接下来的这几期,bug 菌想跟大家分享一下自己昨天刚接到一个临时的需求,热乎着呢,想分享一下自己是如何面对临时需求并制定整个开发周期,其中包括从梳理业务到创建业务表再到实现业务逻辑形成闭环再到与前端对接,其中会穿插一些业务拓展及功能性拓展,这一条龙流程在线与大家一起见证,分享给刚入门的小伙伴,希望对你们有所帮助。

环境说明:idea2019.3 + springboot2.3.1.REALSE + mybati-plus3.2.0 + mysql5.6 + jdk1.8

       若小伙伴们在批阅文章的过程中觉得文章对您有一丝丝帮助,还请别吝啬您手里的赞呀,大胆的把文章点亮👍吧,您的点赞三连(收藏⭐️+关注👨‍🎓+留言📃)就是对 bug 菌我创作道路上最好的鼓励与支持😘。时光不弃🏃🏻‍♀️,创作不停💕,加油☘️ 

二、正文🔥

        在上一期,我们是完整的讲述了从 Controller 接口定义到接口方法实现,完美实现了按指定路径进行图片上传及数据库记录插入。而这一期,我要给大家讲点什么嘞?你们想知道么?其实也有据可循,你们想想,一个业务肯定是要形成闭环,图片也是,图片上传就要支持本地下载、在线预览、在线删除等业务线。所以这一期,我给大家讲讲,如何实现指定图片在线预览功能,具有很好的教学价值,希望大家能挺我,认真把它看完。

三、图片预览功能🔥

        既然说到图片预览,那肯定也是得从接口定义开始,我们先来思考一下,接口入参有些啥,那就看具体业务了,我是按人分图片保存,自然就会涉及到用户账号 id,通过用户账号 id 进行把用户分成 n 个文件夹,然后再是具体的问题反馈图片,所以,入参 1 是查看图片所对应的用户账户 id,其次入参 2 就是要查看那张图片的完整名称,比如 test.png.这样我就能根据首路径+账户 id+图片名合拼出访问该图片的绝对路径了。

        废话不多说,我们接着看,既然确定了入参,那就大胆的把该接口定义出来吧啊。

1️⃣定义 Controller 请求

/**     * 图片预览     */    @GetMapping("/review-img-by-path")    @ApiOperation(value = "图片预览", notes = "根据图片地址进行预览")    public void reviewImgByPath(@ApiParam("图片路径") @RequestParam("imgPath") String imgPath,                                @ApiParam("反馈人的域账号id") @RequestParam("accountId")
复制代码

2️⃣定义接口方法 reviewImgByPath

        这里主要就是定义 reviewImgByPath 接口。具体如何定义请看如下:

void reviewImgByPath(String imgPath, String accountId);
复制代码

3️⃣实现 reviewImgByPath 方法

        这里可谓是核心业务逻辑了。毕竟你是要实现该方法的,我就来说说我的大致思路,主要的就是要拼接处该图片的绝对地址,也就是当初你保存的图片路径加固定的父路径加用户 id。

具体如何实现请看如下:

@Override    public void reviewImgByPath(String imgPath, String accountId) {
//获取response HttpServletResponse response = SpringServletContextUtils.getResponse();
//拼接预览图片全路径 String targetPath = this.buildImgPath(imgPath, accountId);
File file = new File(targetPath);
//调用预览方法
复制代码

对于 buildImgPath 方法,这跟图片上传共用一个方法,所以这里我们也是直接调用,没啥区分,都是合路径。

private String buildImgPath(String imgPath, String accountId) {        return
复制代码


既然 我们成功把图片的全路径拼接完成,最终就是呀如何通过代码的方式进行图片预览了,最笨的方式就是通过存储静态 资源 的方式,然后我们只需要访问静态路径就能预览图片,但是我们既然拿出来演示,自然就不会用这种这么 low 的方式了哈。

        至于如何实现,我们 接着往下看。 

4️⃣实现图片预览方法

         如下,我对于改图片预览实现,有研究出两种实现方式供大家参考,这个具体看大家兴趣,喜好那种就按那种实现方式来定,bug 菌亲测都是有效的哈,没有不收费。

预览方式 1:

/**     * 图片预览方式1     */    public void reviewImg1(HttpServletResponse response, String targetPath) throws IOException {
FileInputStream fis = new FileInputStream(targetPath); OutputStream os = response.getOutputStream(); try { int count = 0; byte[] buffer = new byte[1024 * 1024]; while ((count = fis.read(buffer)) != -1) { os.write(buffer, 0, count); os.flush(); } } catch (IOException e) { e.printStackTrace(); } finally { if (os != null) { os.close(); } if (fis != null) { fis.close(); } } }
复制代码

预览方式 2:

/**     * 图片预览方式2     */    public void reviewImg2(HttpServletResponse response,File file) {
//文件目录 if (file.exists()) { byte[] data = null; try { FileInputStream input = new FileInputStream(file); data = new byte[input.available()]; input.read(data); response.getOutputStream().write(data); input.close(); } catch (Exception e) { System.out.println(e); } } else { return; } }
复制代码

如上是我提供的两种预览图片的实现方式,如果对于你们而言,那种更易于理解,你们就倾向使用那种吧,虽然 都能实现图片预览,但是原理还是有些不同的,你们仔细品位品位,你们就会知道,它有何不同。 

5️⃣接口测试

        这里我提供两种预览方式,一是通过 postman 测试接口进行图片预览,postman 也是支持在线预览功能。

方式 2 就是直接在你的浏览器上进行接口访问,也是可以的。


 ... ...

        好啦,以上就是这期的所有内容啦,你们学废了么?如果对你有所帮助,还请不要忘记给 bug 菌[三连支持]哟。如果想获得更多的学习资源或者想和更多的技术爱好者一起交流,可以关注我的公众号『​​猿圈奇妙屋​​』,后台回复关键词领取学习资料、大厂面经、面试模板等海量资源,就等你来拿。

        若你们觉得只是需要了解其中某个知识点或者业务的话,也不反对,你就选择其中的几期进行学习就好,反正都已经完结啦;我只希望你们能有所收获,有所成长,也就不枉我苦心每天下班后给大家总结更新。

        若你们觉得只是需要了解其中某个知识点或者业务的话,也不反对,你就选择其中的几期进行学习就好,反正都已经完结啦;我只希望你们能有所收获,有所成长,也就不枉我苦心每天下班后给大家总结更新。

四、往期热文推荐🔥

        对于问题反馈模块实战开发,我完整的梳理了每一期的教学及链接地址,仅供参考:希望能对你们有所帮助。

        如上是整整二十期内容,每一期都是干货,对于一个模块的开发,如何一点一滴打造并测试部署上线,我再说一遍,这不是演习,是实战!是实战!是实战!

        若你们觉得只是需要了解其中某个知识点或者业务的话,也不反对,你就选择其中的几期进行学习就好,反正都已经完结啦;我只希望你们能有所收获,有所成长,也就不枉我苦心每天下班后给大家总结更新。

五、文末🔥

​《springboot零基础入门教学》​​,都是我一手打下的江山,持续更新中,希望能帮助到更多小伙伴们。

       我是 bug 菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!

        最后送大家两句我很喜欢的话,与诸君共勉!


☘️做你想做的人,没有时间限制,只要愿意,什么时候都可以 start。

🍀你能从现在开始改变,也可以一成不变,这件事,没有规矩可言,你可以活出最精彩的自己。




💌如果文章对您有所帮助,就请留下您的吧!(#^.^#);

💝如果喜欢 bug 菌分享的文章,就请给 bug 菌点个关注吧!(๑′ᴗ‵๑)づ╭❤~;

💗如果对文章有任何疑问,还请文末留言或者加群吧【QQ 交流群:708072830】;

💞鉴于个人经验有限,所有观点及技术研点,如有异议,请直接回复参与讨论(请勿发表攻击言论,谢谢);

💕版权声明:原创不易,转载请附上原文出处链接和本文声明,版权所有,盗版必究!!!谢谢。


发布于: 刚刚阅读数: 4
用户头像

bug菌

关注

公众号 | 猿圈奇妙屋 2020-07-30 加入

在CSDN、掘金等社区优质创作者,全网合计6w粉+,对一切技术都感兴趣,重心偏java方向,目前运营公众号[猿圈奇妙屋],欢迎小伙伴们的加入,一起秃头。

评论

发布
暂无评论
在线问题反馈模块实战(十)​:实现图片预览功能_springboot_bug菌_InfoQ写作社区