java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机

简介: 这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。

前言

一、map 遍历方法

package test.feng;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

/**
 * @ClassName Test
 * @Description TODO
 * @Author admin
 * @Date 2021/6/8 15:38
 * @Version 1.0
 */
public class TestMap {

    public static void main(String[] args) {
        System.out.println("this is text".matches("this is text"));
    }

    public static void main1(String[] args) {
        Map<String, String> map = new HashMap<String, String>();
        map.put("1", "value1");
        map.put("2", "value2");
        map.put("3", "value3");

        //第一种:普遍使用,二次取值
        System.out.println("通过Map.keySet遍历key和value:");
        Set<String> keySet = map.keySet();
        for (String key : keySet) {
            System.out.println("key= " + key + " and value= " + map.get(key));
        }

        //第二种
        System.out.println("通过Map.entrySet使用iterator遍历key和value:");
        Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
        while (it.hasNext()) {
            Map.Entry<String, String> entry = it.next();
            System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
        }

        //第三种:推荐,尤其是容量大时
        System.out.println("通过Map.entrySet遍历key和value");
        for (Map.Entry<String, String> entry : map.entrySet()) {
            System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
        }

        //第四种
        System.out.println("通过Map.values()遍历所有的value,但不能遍历key");
        for (String v : map.values()) {
            System.out.println("value= " + v);
        }
    }
}
AI 代码解读

二、java正则学习

正在学习中~

package test.feng;

/**
 * @ClassName Test
 * @Description TODO
 * @Author admin
 * @Date 2021/6/9 13:58
 * @Version 1.0
 */
public class TestMatches {
    public static void main(String[] args) {
        // study
        System.out.println("this is text".matches("this is text"));
        System.out.println("this     is      text".matches("this\\s+is\\s+text"));
        System.out.println("555".matches("^\\d+(\\.\\d+)?"));
        System.out.println("1.4".matches("^\\d+(\\.\\d+)?"));
        System.out.println("14.333334".matches("^\\d+(\\.\\d+)?"));
        System.out.println("144444.333334".matches("^\\d+(\\.\\d+)?"));
        System.out.println(".144444.333334".matches("^\\d+(\\.\\d+)?"));
        System.out.println(".144444.333334.".matches("^\\d+(\\.\\d+)?"));

        System.out.println("---------------");
        // 第一次斜杠 代表 转义字符
        System.out.println("24524.47".matches("^\\d+(\\.\\d+)?")); // true
        System.out.println("24524.47a".matches("^\\d+(\\.\\d+)?")); // false
        System.out.println("24524.47好".matches("^\\d+(\\.\\d+)?"));
    }
}
AI 代码解读

三、后端传到前端图片三种情况

第二个方式还未总结完,第一、三个方式总结完成。

1. 图片流数据(InputStream) 转 base64,前端展示保存

a. 后端:输入流转base,直接调用方法

引入

import org.apache.commons.io.IOUtils;
AI 代码解读
InputStream resourceAsStream = processService.resourceRead(id,type);
byte[] bytes = IOUtils.toByteArray(resourceAsStream);

String encoded = Base64.getEncoder().encodeToString(bytes);
AI 代码解读

b. 前端显示

HTML中使用和保存:

<img src="data:image/png;base64,..." />
<view class="save" @click="saveAlbum">保存二维码</view>
AI 代码解读

c. 保存

saveAlbum() {
    uni.getSetting({ //获取用户的当前设置
        success: (res) => {
            if (res.authSetting['scope.writePhotosAlbum']) { //验证用户是否授权可以访问相册
                this.saveImageToPhotosAlbum();
            } else {
                uni.authorize({ //如果没有授权,向用户发起请求
                    scope: 'scope.writePhotosAlbum',
                    success: () => {
                        this.saveImageToPhotosAlbum();
                    },
                    fail: () => {
                        uni.showToast({
                            title: "请打开保存相册权限,再点击保存相册分享",
                            icon: "none",
                            duration: 3000
                        });
                        setTimeout(() => {
                            uni.openSetting({ //调起客户端小程序设置界面,让用户开启访问相册
                                success: (res2) => {
                                    // console.log(res2.authSetting)
                                }
                            });
                        }, 3000);
                    }
                })
            }
        }
    })

},
saveImageToPhotosAlbum() {
    let base64 = this.codeImg.replace(/^data:image\/\w+;base64,/, ""); //去掉data:image/png;base64,
    let filePath = wx.env.USER_DATA_PATH + '/hym_pay_qrcode.png';
    uni.getFileSystemManager().writeFile({
        filePath: filePath, //创建一个临时文件名
        data: base64, //写入的文本或二进制数据
        encoding: 'base64', //写入当前文件的字符编码
        success: res => {
            uni.saveImageToPhotosAlbum({
                filePath: filePath,
                success: function(res2) {
                    uni.showToast({
                        title: '保存成功',
                        icon: "none",
                        duration: 5000
                    })
                },
                fail: function(err) {
                    // console.log(err.errMsg);
                }
            })
        },
        fail: err => {
            //console.log(err)
        }
    })
}
AI 代码解读

2. 传图片流数据,前端展示保存

a. 后端控制成

OutputStream output = response.getOutputStream();
byte[] buffer = new byte[10240];
for (int length = 0; (length = erWeiMa.read(buffer)) > 0; ) {
    output.write(buffer, 0, length);
}
AI 代码解读

b. 前端展示

c. 照片保存

downLoad(data){
  let fileName = data.fileName; //下载的文件名字 data是我组件中传出来的
   this.fileDownLoadApi({id:data.id})
       .then(res=>{
           this.$Message.info('正在下载,请稍等...')
           //接受blob格式数据,然后保存起来
           let url = window.URL.createObjectURL(new Blob([res.data]))
           //下载方式。如果浏览器兼容下载,就直接下载
           if(window.navigator&&window.navigator.msSaveOrOpenBlob){
               window.navigator.msSaveOrOpenBlob(new Blob([res.data]),fileName)
           }else{
               //不兼容,利用a标签的点击属性自动下载,之前window.open(url)
               //只是打开一个新的窗口,并不触发下载动作,所以只能模拟a标签点击事件
               var eleLick = document.createElement('a');
               eleLick.download = fileName;
               eleLick.style.display = 'none';
               eleLick.href = url;
               document.body.appendChild(eleLick);
               eleLick.click();
               eleLick.remove();
               //释放
               window.URL.revokeObjectURL(url);
               // window.open(url)
           }
       }).catch(()=>{
           console.log('下载失败了');
       })
},
AI 代码解读

3. 传图片url,前端展示保存(简单)

a. 后端处理

后端生成图片,存到oss上,返回图片URL。

b. 前端展示

类似这种,直接放上图片URL即可

<img src=https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2496571732,442429806&fm=26&gp=0.jpg" />
AI 代码解读

c. 保存图片

项目开发用的是uni-app,所以这里下载保存图片也用的是uni-app的方法,方法参数的使用可以看具体官网。当然微信小程序的微信开发文档上面也有微信的保存方法。

uni-app(微信原生开发:微信开发文档)保存图片需要两步:

  1. 先使用 uni.downloadFile({}):下载文件方法; 返回文件临时路径
  2. 再使用 uni.saveImageToPhotosAlbum({}):保存图片到手机。

uni-app文档:https://uniapp.dcloud.io/api/request/network-file?id=downloadfile
微信开放文档:https://developers.weixin.qq.com/miniprogram/dev/api/file/wx.saveFile.html

posterSure(){
    // 保存图片 到手机上
    uni.downloadFile({
        url: this.posterUrl,
        success: function (res) {
            console.log("aaaaaaaaaaaa:",JSON.stringify(res))
            if (res.statusCode === 200) {
                console.log('下载成功');
            }
            uni.saveImageToPhotosAlbum({
                filePath: res.tempFilePath,
                success: function (res) {
                    console.log(res)
                    console.log('下载成功');
                    this.$refs.uToast.show({
                        title: '保存成功',
                        type: 'success'
                    })
                },
                fail: function (res) {
                    console.log(res)
                    console.log('fail')
                }
            })
        },
        fail: function () {
            console.log('fail')
        }
    })
},
AI 代码解读
目录
打赏
0
1
1
0
49
分享
相关文章
【Java若依框架】RuoYi-Vue的前端和后端配置步骤和启动步骤
本文介绍了如何配置和启动基于Java的若依(RuoYi)项目,涵盖后端和前端的详细步骤。首先,准备Redis、MySQL以及IDE(如Idea和VS)。接着,通过GitHub获取代码并导入到IDE中,执行必要的SQL文件和配置数据库密码。然后,启动Redis并进行相关配置。最后,按照前端配置步骤克隆前端代码库,打开终端执行命令完成前端配置。整个过程详细记录了每一步的操作,帮助开发者顺利部署若依项目。 如果你觉得有帮助,请点赞、关注和收藏,这将是我持续分享的动力!
318 1
|
3月前
|
Java交换map的key和value值
通过本文介绍的几种方法,可以在Java中实现Map键值对的交换。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。对于简单的键值对交换,可以使用简单遍历法或Java 8的Stream API;对于需要处理值不唯一的情况,可以使用集合存储或Guava的Multimap。希望本文对您理解和实现Java中的Map键值对交换有所帮助。
68 1
在Java的Map家族中,HashMap和TreeMap各具特色
【10月更文挑战第19天】在Java的Map家族中,HashMap和TreeMap各具特色。HashMap基于哈希表实现,提供O(1)时间复杂度的高效操作,适合性能要求高的场景;TreeMap基于红黑树,提供O(log n)时间复杂度的有序操作,适合需要排序和范围查询的场景。两者在不同需求下各有优势,选择时需根据具体应用场景权衡。
52 2
|
4月前
|
优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。
【10月更文挑战第19天】本文介绍了如何优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。内容包括Map的初始化、使用Stream API处理Map、利用merge方法、使用ComputeIfAbsent和ComputeIfPresent,以及Map的默认方法。这些技巧不仅提高了代码的可读性和维护性,还提升了开发效率。
171 3
|
4月前
|
详细解析HashMap、TreeMap、LinkedHashMap等实现类,帮助您更好地理解和应用Java Map。
【10月更文挑战第19天】深入剖析Java Map:不仅是高效存储键值对的数据结构,更是展现设计艺术的典范。本文从基本概念、设计艺术和使用技巧三个方面,详细解析HashMap、TreeMap、LinkedHashMap等实现类,帮助您更好地理解和应用Java Map。
96 3
Java Map新玩法:深入探讨HashMap和TreeMap的高级特性
【10月更文挑战第19天】Java Map新玩法:深入探讨HashMap和TreeMap的高级特性,包括初始容量与加载因子的优化、高效的遍历方法、线程安全性处理以及TreeMap的自然排序、自定义排序、范围查询等功能,助你提升代码性能与灵活性。
41 2
Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效
【10月更文挑战第19天】在软件开发中,随着项目复杂度的增加,数据结构的组织和管理变得至关重要。Java中的Map接口提供了一种优雅的方式来管理数据结构,使代码更加清晰、高效。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,帮助开发者告别混乱,提升代码质量。
47 1
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第19天】本文介绍了Java编程中重要的数据结构——Map,通过问答形式讲解了Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的使用和性能优化技巧,适合初学者和进阶者学习。
136 4
Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
【10月更文挑战第17天】Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
107 2
|
4月前
|
告别混乱!用Java Map优雅管理你的数据结构
【10月更文挑战第17天】在软件开发中,随着项目复杂度增加,数据结构的组织和管理至关重要。Java中的Map接口提供了一种优雅的解决方案,帮助我们高效、清晰地管理数据。本文通过在线购物平台的案例,展示了Map在商品管理、用户管理和订单管理中的具体应用,有效提升了代码质量和维护性。
113 2

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等