位置: IT常识 - 正文

后台给前端传图片,Base64(后端怎么把图片传给前端的)

编辑:rootadmin
后台给前端传图片,Base64

推荐整理分享后台给前端传图片,Base64(后端怎么把图片传给前端的),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:前端图片上传后端服务器,前后端图片传输,后端传图片给前端,后端上传图片,前端图片上传后端服务器,前后端图片传输,后端传图片给前端,前端上传图片给后端,内容如对您有帮助,希望把文章链接给更多的朋友!

本文章是经查阅网上的一些文章,自己进行总结,做笔记方便以后查阅。

本篇文章背景:

因为想要实现给图片加文字,并在前端预览的功能,这涉及到Base64,特此记录。

后端给前端传图片:

一般后台给前端传图片,有两种方式:一种是通过response.getOutputStream直接将图片以流的形式写到页面显示,另一种是先把图片上传到服务器,拿到url地址后把url地址给前端。 此外,也可以将图片的字节数组通过Base64编译后返回给前端,前端直接拿了可以显示为图片。

一、字节数组Base64编译byte[] bytes;// 图片的字节数组BASE64Encoder encoder = new BASE64Encoder();String data = encoder.encode(bytes);// //data = iVBORw0KGgoAAAANSUhEUgAAAFAAAAAaCAIAAACvsEzwAAABxElEQVR42tWYS2rDMB......二、前端显示

前端拿到这个data字符串后,有两种方式显示图片: 先拼接一下前缀,分别是data:图片类型; 编码类型, data字符串数据

data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAFAAAAAaCAIAAACvsEzwAAABxElEQVR42tWYS2rDMB......

第一种方式,css:

div.image { width: 99px; height: 42px; background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA......);}

第二种方式,img标签

<img width="900" height="450" src="https://www.yuucn.com/wp-content/uploads/2022/11/1667293448-a1b8a387a5b4721.png"/>后台给前端传图片,Base64(后端怎么把图片传给前端的)

注意,如果图片很大的话,转成的data字符串也很长,原作者一个小图片就15w字符,所以这种方式适合比如logo,验证码这种小图片,又不希望存在服务器的应用场景!!!

Base64:

参考文章如下: 一篇文章彻底弄懂Base64编码原理

一、Base64的由来

在参数传输过程中:中文出现乱码、传输的字符不是可打印的字符,比如二进制文件、图片等。因此,Base64出现,其基于64个可打印的字符来表示二进制的数据,以解决上述问题。Base64在URL、Cookie、网页传输少量二进制文件中也有相应的应用。

二、Base64的原理

每当我们使用时Base64时,都会先定义一个类似的数组:

['A', 'B', 'C', ... 'a', 'b', 'c', ... '0', '1', ... '+', '/']

这是Base64的索引表,字符选用了“A-Z、a-z、0-9、+、/”64个可打印字符,这是标准的Base64协议规定。日常使用中还会看到“=”或“==”出现在Base64的编码结果中,“=”在此是作为填充字符出现,会面会讲到,适用于位数不足的情况。

三、具体转换步骤

1.将待转换的字符串每三个字节分为一组,每个字节占8bit,那么共有24个二进制位; 2.将上面的24个二进制位每6个一组,共分为4组; 3.在每组前面添加两个0,每组由6个变为8个二进制位,总共32个二进制位,即4个字节; 4.根据Base64编码对照表(见下图)获得对应的值;

0 A   17 R   34 i   51 z1 B   18 S   35 j   52 02 C   19 T   36 k   53 13 D   20 U   37 l   54 24 E   21 V   38 m   55 35 F   22 W   39 n   56 46 G   23 X   40 o   57 57 H   24 Y   41 p   58 68 I   25 Z   42 q   59 79 J   26 a   43 r   60 810 K  27 b   44 s   61 911 L  28 c   45 t   62 +12 M  29 d   46 u   63 /13 N  30 e   47 v14 O  31 f   48 w   15 P  32 g   49 x16 Q  33 h   50 y

从上面的步骤我们发现:

Base64字符表中的字符原本用6个bit就可以表示,现在前面添加2个0,变为8个bit,会造成一定的浪费。因此,Base64编码之后的文本,要比原文大约三分之一。为什么使用3个字节一组呢?因为6和8的最小公倍数为24,三个字节正好24个二进制位,每6个bit位一组,恰好能够分为4组。四、示例说明

以下面的表格为示例,具体分析: 对应步骤如下:

1.“M”、“a”、"n"对应的ASCII码值分别为77,97,110,对应的二进制值是01001101、01100001、01101110。如图第二三行所示,由此组成一个24位的二进制字符串。2.如图红色框,将24位每6位二进制位一组分成四组。3.在上面每一组前面补两个0,扩展成32个二进制位,此时变为四个字节:00010011、00010110、00000101、00101110。分别对应的值(Base64编码索引)为:19、22、5、46。4.用上面的值在Base64编码表中进行查找,分别对应:T、W、F、u。因此“Man”Base64编码之后就变为:TWFu。五、位数不足情况

上面是按照三个字节来举例说明的,如果字节数不足三个,那么该如何处理?

1个字节:共8个二进制位,按规则分组,每6个一组,则第二组缺少4位,用0补齐,得到两个Base64编码,而后面两组没有对应数据,都用“=”补上。因此,上图中“A”转换之后为“QQ==”;2个字节:共16个二进制位,按规则分组,每6个一组,则第三组缺少2位,用0补齐,得到三个Base64编码,第四组完全没有数据,则用“=”补上。因此,上图中“BC”转换之后为“QKM=”;六、注意事项大多数编码都是由字符串转化成二进制,而Base64的编码则是从二进制转换成字符串Base64编码主要用在传输、存储、表示二进制领域,不能算得上加密,只是无法直接看到明文,也可以通过打乱Base64编码来进行加密中文有多种编码(比如UTF-8、GB2312,GBK),不同编码对应Base64编码结果不一样七、延伸

上面我们已经看到了Base64就是用6位(2的6次幂就是64)表示字符,因此称为Base64。 同理,Base32就是用5位,Base16就是用4位。

八、验证

最后,用Java代码来验证一下上面的转换结果

package com.secbro2.blog.utils;import sun.misc.BASE64Encoder;public class Base64Utils {public static void main(String[] args) {String man = "Man";String a = "A";String bc = "BC";BASE64Encoder encoder = new BASE64Encoder();System.out.println("Man base64结果为:" + encoder.encode(man.getBytes()));// TWFuSystem.out.println("BC base64结果为:" + encoder.encode(bc.getBytes()));// QkM=System.out.println("A base64结果为:" + encoder.encode(a.getBytes()));// QQ==}}
本文链接地址:https://www.jiuchutong.com/zhishi/289637.html 转载请保留说明!

上一篇:Bojo河,菲律宾宿务 (© Amazing Aerial Agency/Offset by Shutterstock)(菲律宾薄荷岛疫情最新消息)

下一篇:大堡礁,澳大利亚昆士兰 (© AWL Images/Danita Delimont)(大堡礁分布在澳大利亚的哪里)

  • 增距镜原理(增距)(增距镜原理及用途详解)

    增距镜原理(增距)(增距镜原理及用途详解)

  • 大华监控怎么连接手机(大华监控怎么连接电视)

    大华监控怎么连接手机(大华监控怎么连接电视)

  • 微信机器人怎么弄的(微信机器人怎么离婚)

    微信机器人怎么弄的(微信机器人怎么离婚)

  • 淘宝视频上传尺寸不符合要求怎么办(淘宝视频上传尺寸多大)

    淘宝视频上传尺寸不符合要求怎么办(淘宝视频上传尺寸多大)

  • 小米手表怎么充电(小米手表怎么充电视频教程)

    小米手表怎么充电(小米手表怎么充电视频教程)

  • 微信聊天记录不小心删了还能恢复吗(微信聊天记录不见了)

    微信聊天记录不小心删了还能恢复吗(微信聊天记录不见了)

  • 抖音有隐身功能吗(抖音隐身功能在哪里)

    抖音有隐身功能吗(抖音隐身功能在哪里)

  • pon系统上行传输波长是多少(pon 上行)

    pon系统上行传输波长是多少(pon 上行)

  • 笔记本电脑多重一般(一般的笔记本电脑多重)

    笔记本电脑多重一般(一般的笔记本电脑多重)

  • 改密保手机必须等12小时吗(改密保手机必须关机吗)

    改密保手机必须等12小时吗(改密保手机必须关机吗)

  • 华为应用启动管理设置自动还是手动(华为应用启动管理应该是开启还是关闭)

    华为应用启动管理设置自动还是手动(华为应用启动管理应该是开启还是关闭)

  • 6p如何升ios13(6p如何升级13系统)

    6p如何升ios13(6p如何升级13系统)

  • 密码锁定是什么意思(密码锁锁了怎么办)

    密码锁定是什么意思(密码锁锁了怎么办)

  • 6s可以升级13.4吗(iphone6s能不能升级13)

    6s可以升级13.4吗(iphone6s能不能升级13)

  • ip协议提供的服务类型是(IP协议提供的服务是可靠服务吗)

    ip协议提供的服务类型是(IP协议提供的服务是可靠服务吗)

  • 关闭拼多多拼小圈好友还能看到动态吗(关闭拼多多拼小圈后拼友能看到我的好友吗)

    关闭拼多多拼小圈好友还能看到动态吗(关闭拼多多拼小圈后拼友能看到我的好友吗)

  • 朋友圈怎么发1分钟视频(朋友圈怎么发1080p视频)

    朋友圈怎么发1分钟视频(朋友圈怎么发1080p视频)

  • 滴滴桔视仪必须安装吗(滴滴要求安装桔视仪不安装不派单)

    滴滴桔视仪必须安装吗(滴滴要求安装桔视仪不安装不派单)

  • 小米mix2s多少万快充(小米mix2s多少钱刚出来)

    小米mix2s多少万快充(小米mix2s多少钱刚出来)

  • 拼多多店铺id在哪里查看(拼多多店铺id在哪看手机)

    拼多多店铺id在哪里查看(拼多多店铺id在哪看手机)

  • whatsapp号码禁用原因(whatsapp禁用怎么办)

    whatsapp号码禁用原因(whatsapp禁用怎么办)

  • 苹果无锁是什么意思(苹果无锁是啥)

    苹果无锁是什么意思(苹果无锁是啥)

  • 小米手环4可以打电话吗(小米手环4可以接电话吗)

    小米手环4可以打电话吗(小米手环4可以接电话吗)

  • 淘集集和淘宝一样吗(淘集集是不是下架了)

    淘集集和淘宝一样吗(淘集集是不是下架了)

  • 钉钉如何建群(钉钉如何建群上课)

    钉钉如何建群(钉钉如何建群上课)

  • 电脑开机显示屏显示无信号黑屏解决方法(电脑开机显示屏显示无信号黑屏怎么办)

    电脑开机显示屏显示无信号黑屏解决方法(电脑开机显示屏显示无信号黑屏怎么办)

  • JS日期与字符串相互转换(时间格式化YYYY-MM-DD,Dayjs的使用)(js日期字符串转换为指定格式的日期)

    JS日期与字符串相互转换(时间格式化YYYY-MM-DD,Dayjs的使用)(js日期字符串转换为指定格式的日期)

  • 《Python项目开发实战》PDF高清版下载(python项目开发案例集锦pdf百度网盘)

    《Python项目开发实战》PDF高清版下载(python项目开发案例集锦pdf百度网盘)

  • 啥是完税凭证
  • 股份支付为什么计入股本溢价
  • 长期投资算资产负债表吗
  • 红发票和蓝发票
  • 接受捐赠计入什么费用
  • 餐饮行业打折部门是什么
  • 知道增值税如何计算开票金额
  • 监控系统计入开户费用吗
  • 别人提供原材料加工后加工费
  • 报关单增值税税单收货人更改
  • 没有业务来往可以报税吗
  • 免税企业减免所得税政策
  • 进项发票不够如何避税
  • 营改增后一般纳税人动产租赁税率
  • 个体户开普票要交企业所得税吗
  • 发票密码区出来了一点
  • 物流公司的保险服务属于什么费用
  • 个税扣缴端如何删除员工信息
  • 什么是应收
  • 关闭通知横幅
  • 如何批量更改多个excel内容
  • NEC笔记本电脑开机启动热键
  • win11如何修复
  • PHP:mb_list_encodings()的用法_mbstring函数
  • 期货手续费是双向收取吗
  • 赠送礼品进项税需要转出吗
  • 房屋产权置换协议书范本
  • 邮政电信卡
  • 深入解析wordpress
  • 购买货物收到发票财务报表怎么提现
  • 前后端交互用什么技术
  • Joomla使用Apache重写模式的方法
  • 软件企业享受增值服务
  • 最新版本TVBox配置地址
  • smb命令执行
  • php基于单例模式开发
  • 苹果系统推送通知
  • 商业企业常用会计科目
  • 以非现金资产清偿债务的,债权人应当
  • mysql redo log buffer
  • 2022最好用的港澳台电视直播
  • 保险赔偿收入会计分录
  • 开办费新会计准则
  • 增值税专用发票怎么开
  • 应付福利费算支出吗
  • 有材料成本差异率怎么算材料成本差异
  • 在建工程什么情况下算竣工
  • 增值税专票已经认证了还能退吗
  • 企业银行流水可以不给税务吗
  • 留抵抵欠税附加税需要交嘛
  • 开诊所会计应如何做账
  • 什么是试算平衡表,编制试算平衡表时应注意哪些方面
  • 住宿费用专票可以抵扣吗
  • 暂估入库的税务怎么处理
  • 国有资产保值增值率
  • 股东的投资款可以直接私人银行卡转账吗
  • 关于投资收益纳税的说法
  • 以前年度不合规发票如何调年报
  • 企业转让固定资产企业所得税
  • 限定性净资产举例
  • 研发支出的帐务处理
  • 高新技术企业享受优惠时间
  • 物流运输公司的运营盈利模式
  • 其他商业项目
  • mysql查询表语句
  • win8.1操作系统关闭驱动数字签名
  • win10用浏览器
  • Windows update更新服务启动被拒绝访问
  • win7系统桌面设置
  • win8一直在开始界面
  • centos6.2安装教程
  • win7旗舰版怎么重装系统教程
  • 如何配置sendmail
  • cocos2dx游戏开发
  • 编程python怎么学
  • 简述python语言
  • 发票单位可以开一批吗?
  • 暖气费政府补贴
  • 企业税收筹划中的涉税风险及其防范
  • 我各位一个关于网上申报增值税所得税的申报流
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设