JAVA实现图片打马赛克,高斯模糊处理图片

2024-02-23 10:52

本文主要是介绍JAVA实现图片打马赛克,高斯模糊处理图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JAVA实现图片打马赛克,高斯模糊处理图片


项目中有时需要对敏感图片进行打码或模糊处理,下面有两个方法可以参考

1.对图片固定坐标进行遮挡

public static final String BASE64_HEAD = "data:image/jpg;base64,";
    /*** 图片打马赛克,返回base64* @param path* @return*/public static String imageMosaic(String path) {String mosaicPath = "";try {// 加载图像BufferedImage bufferedImage = getImageInfo(path);if (bufferedImage == null) {return mosaicPath;}// 创建与输入图像相同大小的新图像BufferedImage outputImage = new BufferedImage(bufferedImage.getWidth(), bufferedImage.getHeight(), BufferedImage.TYPE_INT_RGB);// 创建画笔Graphics graphics = outputImage.getGraphics();// 将原始图像绘制到新图像中graphics.drawImage(bufferedImage, 0, 0, null);// 打码区域左上角x坐标int x = 50;// 打码区域左上角y坐标int y = 50;// 打码区域宽度int width = 90;// 打码区域高度int height = 90;graphics.setColor(Color.GRAY);graphics.fillRect(x, y, width, height);// 释放资源graphics.dispose();mosaicPath = encode(bufferedImageToBytes(outputImage));} catch (IOException e) {System.out.println("处理图像失败: " + e.getMessage());}return BASE64_HEAD + mosaicPath;}

1.1.BufferedImage bufferedImage = getImageInfo(path);中用到的方法

	/*** 获取图片信息** @param imageUrl 图片地址* @return*/@SneakyThrowspublic static BufferedImage getImageInfo(String imageUrl) {InputStream inputStream = readFile(imageUrl);if (inputStream == null) {return null;}return ImageIO.read(inputStream);}

1.2.InputStream inputStream = readFile(imageUrl);用到的方法

    /*** url转InputStream** @param fileUrl* @return InputStream*/public static InputStream readFile(String fileUrl) {if (BasicUtil.isNullOrEmpty(fileUrl)) {return null;}try {URL url = new URL(fileUrl);HttpURLConnection urlCon = (HttpURLConnection) url.openConnection();urlCon.setConnectTimeout(6000);urlCon.setReadTimeout(6000);int code = urlCon.getResponseCode();if (code != HttpURLConnection.HTTP_OK) {throw new Exception("文件读取失败" + code);}return urlCon.getInputStream();} catch (Exception e) {e.printStackTrace();}return null;}

1.3.mosaicPath = encode(bufferedImageToBytes(outputImage));用到的方法

    /*** 图片转字符串* @param image 图片Buffer* @return Base64编码*/public static String encode(byte[] image) {Base64.Encoder encoder = Base64.getEncoder();return replaceEnter(encoder.encodeToString(image));}/*** 字符替换* @param str 字符串* @return 替换后的字符串*/public static String replaceEnter(String str) {String reg = "[\n-\r]";Pattern p = Pattern.compile(reg);Matcher m = p.matcher(str);return m.replaceAll("");}

1.4.mosaicPath = encode(bufferedImageToBytes(outputImage));用到的方法

    /*** BufferedImage 转 byte[]** @param image* @return* @throws IOException*/public static byte[] bufferedImageToBytes(BufferedImage image) throws IOException {ByteArrayOutputStream outputStream = new ByteArrayOutputStream();ImageIO.write(image, "jpg", outputStream);return outputStream.toByteArray();}

2.对图片进行模糊处理,里面用到的方法,在上面有写

//maven依赖
<dependency><groupId>com.jhlabs</groupId><artifactId>filters</artifactId><version>2.0.235-1</version>
</dependency>
//gradle依赖
implementation 'com.jhlabs:filters:2.0.235-1'
 	/*** 高斯模糊处理图片,返回base64* @param url* @return*/@SneakyThrowspublic static String fuzzyImage(String url) {BufferedImage bufferedImage = getImageInfo(url);if (bufferedImage == null) {return "";}GaussianFilter filter = new GaussianFilter();//数字越大越模糊filter.setRadius(10);BufferedImage dstImage = new BufferedImage(bufferedImage.getWidth(), bufferedImage.getHeight(), BufferedImage.TYPE_USHORT_565_RGB);filter.filter(bufferedImage, dstImage);return BASE64_HEAD + encode(bufferedImageToBytes(dstImage));}
    public static void main(String[] args) {String path = "https://123456.jpg";System.out.println(fuzzyImage(path));}

欢迎交流互相学习

这篇关于JAVA实现图片打马赛克,高斯模糊处理图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/738378

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu