SpringMVC中controller返回图片

SpringMVC中controller返回图片


SpringMVC中controller通过返回ModelAndView然后通过ViewResolver找到相应的视图。可以返回jsp可以返回Map等。


在做验证码图片的时候如何处理让我作难,使用struts2的时候在Action中返回字节流,然后在struts.xml文件中配置result的type为stream即可。但在SpringMVC中如何处理呢?


下面我将以代码的方式讲解一下如何在SpringMVC中生成验证码图片:

首先,验证码图片生成工具类:

ImageUtil.java

package org.qxl.onlinexam.util;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;
import javax.imageio.ImageIO;

public final class ImageUtil {
	
	// 验证码字符集
	private static final char[] chars = { 
		'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 
		'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
		'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
		'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 
		'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};
	// 字符数量
	private static final int SIZE = 4;
	// 干扰线数量
	private static final int LINES = 5;
	// 宽度
	private static final int WIDTH = 80;
	// 高度
	private static final int HEIGHT = 40;
	// 字体大小
	private static final int FONT_SIZE = 30;

	/**
	 * 生成随机验证码及图片
	 * Object[0]:验证码字符串;
	 * Object[1]:验证码图片。
	 */
	public static Object[] createImage() {
		StringBuffer sb = new StringBuffer();
		// 1.创建空白图片
		BufferedImage image = new BufferedImage(
			WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);
		// 2.获取图片画笔
		Graphics graphic = image.getGraphics();
		// 3.设置画笔颜色
		graphic.setColor(Color.LIGHT_GRAY);
		// 4.绘制矩形背景
		graphic.fillRect(0, 0, WIDTH, HEIGHT);
		// 5.画随机字符
		Random ran = new Random();
		for (int i = 0; i <SIZE; i++) {
			// 取随机字符索引
			int n = ran.nextInt(chars.length);
			// 设置随机颜色
			graphic.setColor(getRandomColor());
			// 设置字体大小
			graphic.setFont(new Font(
				null, Font.BOLD + Font.ITALIC, FONT_SIZE));
			// 画字符
			graphic.drawString(
				chars[n] + "", i * WIDTH / SIZE, HEIGHT*2/3);
			// 记录字符
			sb.append(chars[n]);
		}
		// 6.画干扰线
		for (int i = 0; i < LINES; i++) {
			// 设置随机颜色
			graphic.setColor(getRandomColor());
			// 随机画线
			graphic.drawLine(ran.nextInt(WIDTH), ran.nextInt(HEIGHT),
					ran.nextInt(WIDTH), ran.nextInt(HEIGHT));
		}
		// 7.返回验证码和图片
		return new Object[]{sb.toString(), image};
	}

	/**
	 * 随机取色
	 */
	public static Color getRandomColor() {
		Random ran = new Random();
		Color color = new Color(ran.nextInt(256), 
				ran.nextInt(256), ran.nextInt(256));
		return color;
	}
	
	public static void main(String[] args) throws IOException {
		Object[] objs = createImage();
		BufferedImage image = (BufferedImage) objs[1];
		OutputStream os = new FileOutputStream("d:/1.png");
		ImageIO.write(image, "png", os);
		os.close();
	}

}

然后,写Controller

	//生成验证码图片
	@RequestMapping("/valicode.do") //对应/user/valicode.do请求
	public void valicode(HttpServletResponse response,HttpSession session) throws Exception{
		//利用图片工具生成图片
		//第一个参数是生成的验证码,第二个参数是生成的图片
		Object[] objs = ImageUtil.createImage();
		//将验证码存入Session
		session.setAttribute("imageCode",objs[0]);
		//将图片输出给浏览器
		BufferedImage image = (BufferedImage) objs[1];
		response.setContentType("image/png");
		OutputStream os = response.getOutputStream();
		ImageIO.write(image, "png", os);
		
	}

结果:


自此,就全部结束了。是不是很简单呢



  • 1
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
在Spring MVC获取MySQL图片可以通过以下步骤完成: 1. 在MySQL数据库创建一个表来存储图片,可以使用BLOB类型来存储二进制数据。 2. 在Spring MVC创建一个Controller用于获取图片数据。 3. 在Controller使用JDBC或MyBatis等框架从MySQL数据库读取图片数据。 4. 将读取到的图片数据以字节数组的形式返回给前端。 5. 在前端使用<img>标签来显示图片,将图片的src属性设置为返回的字节数组的Base64编码。 下面是一个简单的示例代码: ```java @Controller public class ImageController { @Autowired private JdbcTemplate jdbcTemplate; @RequestMapping(value = "/image/{id}", method = RequestMethod.GET, produces = MediaType.IMAGE_JPEG_VALUE) public ResponseEntity<byte[]> getImage(@PathVariable("id") int id) throws IOException { byte[] imageBytes = jdbcTemplate.queryForObject("SELECT image_data FROM images WHERE id = ?", new Object[]{id}, byte[].class); return ResponseEntity.ok().contentType(MediaType.IMAGE_JPEG).body(imageBytes); } } ``` 在上面的代码,我们定义了一个`getImage`方法用于获取图片数据。方法的参数`id`表示要获取的图片的ID。方法的返回值是一个`ResponseEntity<byte[]>`对象,其包含了图片的字节数组和图片的MIME类型。在方法,我们使用JdbcTemplate从MySQL数据库查询图片数据,并将查询结果直接返回给前端。在前端,我们可以使用以下HTML代码来显示图片: ```html <img src="/image/1"> ``` 其,`/image/1`表示要获取ID为1的图片。当浏览器加载这个图片时,会向服务器发送一个HTTP请求,服务器会返回图片的字节数组,浏览器会将这个字节数组解码并显示图片

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值