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);
        }
    }
}

二、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+)?"));
    }
}

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

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

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

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

引入

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

String encoded = Base64.getEncoder().encodeToString(bytes);

b. 前端显示

HTML中使用和保存:

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

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)
        }
    })
}

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);
}

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('下载失败了');
       })
},

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

a. 后端处理

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

b. 前端展示

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

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

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')
        }
    })
},
相关文章
|
7月前
|
Java 开发者
重学Java基础篇—Java类加载顺序深度解析
本文全面解析Java类的生命周期与加载顺序,涵盖从加载到卸载的七个阶段,并深入探讨初始化阶段的执行规则。通过单类、继承体系的实例分析,明确静态与实例初始化的顺序。同时,列举六种触发初始化的场景及特殊场景处理(如接口初始化)。提供类加载完整流程图与记忆口诀,助于理解复杂初始化逻辑。此外,针对空指针异常等问题提出排查方案,并给出最佳实践建议,帮助开发者优化程序设计、定位BUG及理解框架机制。最后扩展讲解类加载器层次与双亲委派机制,为深入研究奠定基础。
240 0
|
3月前
|
存储 Java 程序员
Java 基础知识点全面梳理包含核心要点及难点解析 Java 基础知识点
本文档系统梳理了Java基础知识点,涵盖核心特性、语法基础、面向对象编程、数组字符串、集合框架、异常处理及应用实例,帮助初学者全面掌握Java入门知识,提升编程实践能力。附示例代码下载链接。
129 1
|
5月前
|
IDE Java 开发工具
【Java基础-环境搭建-创建项目】IntelliJ IDEA创建Java项目的详细步骤
IntelliJ IDEA创建Java项目的图文详细步骤,手把手带你创建Java项目
731 10
【Java基础-环境搭建-创建项目】IntelliJ IDEA创建Java项目的详细步骤
|
4月前
|
存储 安全 Java
2025 年最新 40 个 Java 基础核心知识点全面梳理一文掌握 Java 基础关键概念
本文系统梳理了Java编程的40个核心知识点,涵盖基础语法、面向对象、集合框架、异常处理、多线程、IO流、反射机制等关键领域。重点包括:JVM运行原理、基本数据类型、封装/继承/多态三大特性、集合类对比(ArrayList vs LinkedList、HashMap vs TreeMap)、异常分类及处理方式、线程创建与同步机制、IO流体系结构以及反射的应用场景。这些基础知识是Java开发的根基,掌握后能为后续框架学习和项目开发奠定坚实基础。文中还提供了代码资源获取方式,方便读者进一步实践学习。
866 2
|
6月前
|
前端开发 Java 物联网
智慧班牌源码,采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署
智慧班牌系统是一款基于信息化与物联网技术的校园管理工具,集成电子屏显示、人脸识别及数据交互功能,实现班级信息展示、智能考勤与家校互通。系统采用Java + Spring Boot后端框架,搭配Vue2前端技术,支持SaaS云部署与私有化定制。核心功能涵盖信息发布、考勤管理、教务处理及数据分析,助力校园文化建设与教学优化。其综合性和可扩展性有效打破数据孤岛,提升交互体验并降低管理成本,适用于日常教学、考试管理和应急场景,为智慧校园建设提供全面解决方案。
399 70
|
5月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
297 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
7月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
309 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
4月前
|
存储 安全 Java
Java 基础知识面试题汇总 最全面的 Java 基础面试题整理
本文全面解析Java基础知识面试题,涵盖Java基础概念、面向对象编程、异常处理、集合框架等核心内容。通过实际应用场景,提供技术方案与应用实例,如JDK与JRE区别、==与equals()差异、String类特性、final与static关键字用法、多继承替代方案及接口与抽象类对比。帮助开发者夯实基础,高效备考,提升实战能力。附带完整代码示例,可供下载学习。
548 3
|
5月前
|
安全 Java API
【Java性能优化】Map.merge()方法:告别繁琐判空,3行代码搞定统计累加!
在日常开发中,我们经常需要对Map中的值进行累加统计。}else{代码冗长,重复调用get()方法需要显式处理null值非原子操作,多线程下不安全今天要介绍的方法,可以让你用一行代码优雅解决所有这些问题!方法的基本用法和优势与传统写法的对比分析多线程安全版本的实现Stream API的终极优化方案底层实现原理和性能优化建议一句话总结是Java 8为我们提供的Map操作利器,能让你的统计代码更简洁、更安全、更高效!// 合并两个列表});简单累加。
452 0
|
7月前
|
存储 监控 Java
《从头开始学java,一天一个知识点》之:数组入门:一维数组的定义与遍历
**你是否也经历过这些崩溃瞬间?** - 看了三天教程,连`i++`和`++i`的区别都说不清 - 面试时被追问&quot;`a==b`和`equals()`的区别&quot;,大脑突然空白 - 写出的代码总是莫名报NPE,却不知道问题出在哪个运算符 这个系列就是为你打造的Java「速效救心丸」!我们承诺:每天1分钟,地铁通勤、午休间隙即可完成学习;直击痛点,只讲高频考点和实际开发中的「坑位」;拒绝臃肿,没有冗长概念堆砌,每篇都有可运行的代码标本。明日预告:《多维数组与常见操作》。 通过实例讲解数组的核心认知、趣味场景应用、企业级开发规范及优化技巧,帮助你快速掌握Java数组的精髓。
127 23

热门文章

最新文章