java将图片转为base64返回给前端

本文实例为大家分享了java将图片转为base64返回给前端的具体代码,供大家参考,具体内容如下

一、controller端代码

@RequestMapping(value = "/captcha")
 public void imagecode(HttpServletRequest request, HttpServletResponse response) throws Exception {
 JSONObject object = new JSONObject();
 CaptchaGenerator vcg = new CaptchaGenerator();
 String vcode = vcg.generatorVCode();
 BufferedImage vcodeImage = vcg.generatorVCodeImage(vcode, true);
 response.setDateHeader("Expires", 0);
 response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");
 response.addHeader("Cache-Control", "post-check=0, pre-check=0");
 response.setHeader("Pragma", "no-cache");
 ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
 response.addHeader("code", vcode.toLowerCase());
 try {
  ImageIO.write(vcodeImage, "png", outputStream);
  BASE64Encoder encoder = new BASE64Encoder();
  String base64 = encoder.encodeBuffer(outputStream.toByteArray()).trim();
  base64 = base64.replaceAll("\n", "").replaceAll("\r", "");
  object.put("code", "data:image/jpg;base64," + base64);
  response.getWriter().write(object.toString());
 } catch (IOException e) {
  response.getWriter().write("");
 } finally {
  if (outputStream != null) {
  outputStream.flush();
  outputStream.close();
  response.getWriter().close();
  }
 }

 }

二、生成验证码的代码

(从某博客拷过来直接用的)

package com.kinth.security.web.util;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.util.Random;

/**
 * 验证码生成器
 *
 *
 */
public class CaptchaGenerator {

  /**
   * 验证码来源
   */
  final private char[] code = {
    '2', '3', '4', '5', '6', '7', '8', '9',
    'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
    'k', 'm', 'n', 'p', 'q', 'r', 's', 't', 'u', 'v',
    'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F',
    'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R',
    'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'
  };
  /**
   * 字体
   */
  final private String[] fontNames = new String[]{
      "黑体", "宋体", "Courier", "Arial",
      "Verdana", "Times", "Tahoma", "Georgia"};
  /**
   * 字体样式
   */
  final private int[] fontStyles = new int[]{
      Font.BOLD, Font.ITALIC|Font.BOLD
  };

  /**
   * 验证码长度
   * 默认4个字符
   */
  private int vcodeLen = 4;
  /**
   * 验证码图片字体大小
   * 默认17
   */
  private int fontsize = 21;
  /**
   * 验证码图片宽度
   */
  private int width = (fontsize+1)*vcodeLen+10;
  /**
   * 验证码图片高度
   */
  private int height = fontsize+12;
  /**
   * 干扰线条数
   * 默认3条
   */
  private int disturbline = 3;

  public CaptchaGenerator(){}

  /**
   * 指定验证码长度
   * @param vcodeLen 验证码长度
   */
  public CaptchaGenerator(int vcodeLen) {
    this.vcodeLen = vcodeLen;
    this.width = (fontsize+1)*vcodeLen+10;
  }

  /**
   * 生成验证码图片
   * @param vcode 要画的验证码
   * @param drawline 是否画干扰线
   * @return
   */
  public BufferedImage generatorVCodeImage(String vcode, boolean drawline){
    //创建验证码图片
    BufferedImage vcodeImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
    Graphics g = vcodeImage.getGraphics();
    //填充背景色
    g.setColor(new Color(246, 240, 250));
    g.fillRect(0, 0, width, height);
    if(drawline){
      drawDisturbLine(g);
    }
    //用于生成伪随机数
    Random ran = new Random();
    //在图片上画验证码
    for(int i = 0;i < vcode.length();i++){
      //设置字体
      g.setFont(new Font(fontNames[ran.nextInt(fontNames.length)], fontStyles[ran.nextInt(fontStyles.length)], fontsize));
      //随机生成颜色
      g.setColor(getRandomColor());
      //画验证码
      g.drawString(vcode.charAt(i)+"", i*fontsize+10, fontsize+5);
    }
    //释放此图形的上下文以及它使用的所有系统资源
    g.dispose();

    return vcodeImage;
  }
  /**
   * 获得旋转字体的验证码图片
   * @param vcode
   * @param drawline 是否画干扰线
   * @return
   */
  public BufferedImage generatorRotateVCodeImage(String vcode, boolean drawline){
    //创建验证码图片
    BufferedImage rotateVcodeImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
    Graphics2D g2d = rotateVcodeImage.createGraphics();
    //填充背景色
    g2d.setColor(new Color(246, 240, 250));
    g2d.fillRect(0, 0, width, height);
    if(drawline){
      drawDisturbLine(g2d);
    }
    //在图片上画验证码
    for(int i = 0;i < vcode.length();i++){
      BufferedImage rotateImage = getRotateImage(vcode.charAt(i));
      g2d.drawImage(rotateImage, null, (int) (this.height * 0.7) * i, 0);
    }
    g2d.dispose();
    return rotateVcodeImage;
  }
  /**
   * 生成验证码
   * @return 验证码
   */
  public String generatorVCode(){
    int len = code.length;
    Random ran = new Random();
    StringBuffer sb = new StringBuffer();
    for(int i = 0;i < vcodeLen;i++){
      int index = ran.nextInt(len);
      sb.append(code[index]);
    }
    return sb.toString();
  }
  /**
   * 为验证码图片画一些干扰线
   * @param g
   */
  private void drawDisturbLine(Graphics g){
    Random ran = new Random();
    for(int i = 0;i < disturbline;i++){
      int x1 = ran.nextInt(width);
      int y1 = ran.nextInt(height);
      int x2 = ran.nextInt(width);
      int y2 = ran.nextInt(height);
      g.setColor(getRandomColor());
      //画干扰线
      g.drawLine(x1, y1, x2, y2);
    }
  }
  /**
   * 获取一张旋转的图片
   * @param c 要画的字符
   * @return
   */
  private BufferedImage getRotateImage(char c){
    BufferedImage rotateImage = new BufferedImage(height, height, BufferedImage.TYPE_INT_ARGB);
    Graphics2D g2d = rotateImage.createGraphics();
    //设置透明度为0
    g2d.setColor(new Color(255, 255, 255, 0));
    g2d.fillRect(0, 0, height, height);
    Random ran = new Random();
    g2d.setFont(new Font(fontNames[ran.nextInt(fontNames.length)], fontStyles[ran.nextInt(fontStyles.length)], fontsize));
    g2d.setColor(getRandomColor());
    double theta = getTheta();
    //旋转图片
    g2d.rotate(theta, height/2, height/2);
    g2d.drawString(Character.toString(c), (height-fontsize)/2, fontsize+5);
    g2d.dispose();

    return rotateImage;
  }
  /**
   * @return 返回一个随机颜色
   */
  private Color getRandomColor(){
    Random ran = new Random();
    return new Color(ran.nextInt(220), ran.nextInt(220), ran.nextInt(220));
  }
  /**
   * @return 角度
   */
  private double getTheta(){
    return ((int) (Math.random()*1000) % 2 == 0 ? -1 : 1)*Math.random();
  }

  /**
   * @return 验证码字符个数
   */
  public int getVcodeLen() {
    return vcodeLen;
  }
  /**
   * 设置验证码字符个数
   * @param vcodeLen
   */
  public void setVcodeLen(int vcodeLen) {
    this.width = (fontsize+3)*vcodeLen+10;
    this.vcodeLen = vcodeLen;
  }
  /**
   * @return 字体大小
   */
  public int getFontsize() {
    return fontsize;
  }
  /**
   * 设置字体大小
   * @param fontsize
   */
  public void setFontsize(int fontsize) {
    this.width = (fontsize+3)*vcodeLen+10;
    this.height = fontsize+15;
    this.fontsize = fontsize;
  }
  /**
   * @return 图片宽度
   */
  public int getWidth() {
    return width;
  }
  /**
   * 设置图片宽度
   * @param width
   */
  public void setWidth(int width) {
    this.width = width;
  }
  /**
   * @return 图片高度
   */
  public int getHeight() {
    return height;
  }
  /**
   * 设置图片高度
   * @param height
   */
  public void setHeight(int height) {
    this.height = height;
  }
  /**
   * @return 干扰线条数
   */
  public int getDisturbline() {
    return disturbline;
  }
  /**
   * 设置干扰线条数
   * @param disturbline
   */
  public void setDisturbline(int disturbline) {
    this.disturbline = disturbline;
  }

}

三、前端显示

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
 pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
<script src="../static/model/js/jquery-1.11.2.min.js"></script>
</head>
<body>

 <img id="randomImage" src="" />
 <script type="text/javascript">
 $(function() {
  refreshimg();
 })
 function refreshimg() {
  $.ajax({
  type : "POST",
  dataType : "json",
  url : "../article/captcha",
  success : function(data) {
   console.log('base64=' + data.codePic);
   $('#randomImage').attr('src', data.code);
  },
  error : function() {
  }
  });

  $("#randomImage").click(refreshimg)

 }
 </script>

</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

时间: 2020-02-14

Java实现图片与Base64编码互转

淘宝里面的html用base64转换图片,不知道为什么,不过看起来好像很美好,话不多说,直接上代码: import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import sun.misc.BASE64Decoder; import sun.misc.BA

java实现图片转base64字符串 java实现base64字符串转图片

java 图片转base64字符串.base64字符串转图片,具体内容如下 1. 图片转base64字符串: /** * base64编码字符串转换为图片 * @param imgStr base64编码字符串 * @param path 图片路径 * @return */ public static boolean base64StrToImage(String imgStr, String path) { if (imgStr == null) return false; BASE64Dec

Java 处理图片与base64 编码的相互转换的示例

今天项目优化了一下上传头像的功能.采用 imagecropper 插件完成裁剪图片的效果. 这个插件裁剪完的图片都是 base64 加密的字符串,上传头像也就涉及到了如何把加密的字符串转换成图片的问题. 以下是代码: /** * @Description: 将base64编码字符串转换为图片 * @Author: * @CreateTime: * @param imgStr base64编码字符串 * @param path 图片路径-具体到文件 * @return */ public stat

实例详解Java实现图片与base64字符串之间的转换

废话不多说了,直接给大家贴java实现图片与base84字符串之间的转换代码了,具体代码如下所示: package cn.com; import <a href="http://lib.csdn.net/base/javase" class='replace_word' title="Java SE知识库" target='_blank' style='color:#df3434; font-weight:bold;'>Java</a>.io

java 后台将base64字符串保存为图片的方法

本文介绍了java 后台将base64字符串保存为图片的方法,分享给大家,具体如下: 直接上代码: import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; public class Base64T

Java 8实现图片BASE64编解码

前言 Basic编码是标准的BASE64编码,用于处理常规的需求:输出的内容不添加换行符,而且输出的内容由字母加数字组成. 最近做了个Web模版,其中想用Base64背景图.虽然网络上有现成的编码器,但总想自己实现一个.可能很多人不知道,JDK 8新提供的Base64类可以非常方便地处理此项任务:Base64 (Java Platform SE 8 ). 一.先选一张图片 mm.png 二.建立HTML演示文件模版 test.html <!DOCTYPE html> <html>

Java实现base64图片编码数据转换为本地图片的方法

本文实例讲述了Java实现base64图片编码数据转换为本地图片的方法.分享给大家供大家参考,具体如下: 项目中用到的把base64图片数据转为本地图片的函数 /** * 替换html中的base64图片数据为实际图片 * @param html * @param fileRoot 本地路径 * @param serRoot 服务器路径 * @return */ public static String replaceBase64Image(String html,String fileRoot

使用Java代码将IP地址转换为int类型的方法

基本知识点    IP --> 整数: 把IP地址转化为字节数组 通过左移位(<<).与(&).或(|)这些操作转为int 整数 --> IP: 将整数值进行右移位操作(>>>),右移24位,再进行与操作符(&)0xFF,得到的数字即为第一段IP. 将整数值进行右移位操作(>>>),右移16位,再进行与操作符(&)0xFF,得到的数字即为第二段IP. 将整数值进行右移位操作(>>>),右移8位,再进行与操

Java基于Base64实现编码解码图片文件

BASE64 编码是一种常用的字符编码,在很多地方都会用到.但base64不是安全领域下的加密解密算法.能起到安全作用的效果很差,而且很容易破解,他核心作用应该是传输数据的正确性,有些网关或系统只能使用ASCII字符.Base64就是用来将非ASCII字符的数据转换成ASCII字符的一种方法,而且base64特别适合在http,mime协议下快速传输数据. 1.编码与解码代码如下所示: import java.awt.image.BufferedImage; import java.io.Byt

Java+mysql本地图片上传数据库及下载示例

做一个将本地图片上传到mysql数据库的小实例,顺便也下载下来到桌面检测是否上传成功. 在写代码之前得先在数据库中建立image表,用来存储图片. create table image (id int primary key auto_increment , name varchar(30) COMMENT '名称', content mediumblob COMMENT '图片'); 下面直接上代码: package jdbc_imagetest; import java.io.*; impo

java实现pdf按页转换为图片

本文实例为大家分享了java实现pdf按页转换为图片的具体代码,供大家参考,具体内容如下 本程序是利用jacob.jar包实现的,关于jacob.jar的配置见我上一篇文章,程序中可配置参数选择图片清晰图. package core.util; import java.awt.Image; import java.awt.Rectangle; import java.awt.image.BufferedImage; import java.io.File; import java.io.File

Python实现base64编码的图片保存到本地功能示例

本文实例讲述了Python实现base64编码的图片保存到本地功能.分享给大家供大家参考,具体如下: # -*- coding:utf-8 -*- #!python3 import os import base64 sss ="""/9j/4AAQSkZJRgABAQEASABIAAD//gAyUHJvY2Vzc2VkIEJ5IGVCYXkgd2l0aCBJbWFnZU1hZ2ljaywgejEuMS4wLiB8fEIy/9sAQwAGBAUGBQQGBgUGBwcGCAoQ

iOS把图片缓存到本地的几种方法(总结)

把图片缓存到本地,在很多场景都会用到,如果只是存储文件信息,那建一个plist文件,或者数据库就能很方便的解决问题,但是如果存储图片到沙盒就没那么方便了.这里简单介绍两种保存图片到沙盒的方法. 一.把图片转为base64的字符串存到数据库中或者plist文件中,然后用到的时候再取出来 //获取沙盒路径, NSString *path_sandox = NSHomeDirectory(); //创建一个存储plist文件的路径 NSString *newPath = [path_sandox st

Java程序中使用JavaMail发送带图片和附件的邮件

我们常常在邮件中添加附件,以达到传输较大文件的目的.而上一篇文章只是将本机的一张图片内嵌到邮件的 HTML 格式的正文当中,这样的邮件显得不够丰富多彩.我们想要一封正文部分图文并茂,而游客附带若干附件的邮件. 下面是代码结构中3个重要的方法: MimeBodyPart createAttachment(String fileName) 方法用于创建附件并返回: MimeBodyPart createContent(String body, String fileName) 方法用于创建正文部分并

Android应用中使用ContentProvider扫描本地图片并显示

之前群里面有朋友问我,有没有关于本地图片选择的Demo,类似微信的效果,他说网上没有这方面的Demo,问我能不能写一篇关于这个效果的Demo,于是我研究了下微信的本地图片选择的Demo,自己仿照的写了下分享给大家,希望对以后有这样子需求的朋友有一点帮助吧,主要使用的是ContentProvider扫描手机中的图片,并用GridView将图片显示出来,关于GridView和ListView显示图片的问题,一直是一个很头疼的问题,因为我们手机的内存有限,手机给每个应用程序分配的内存也有限,所以图片多