Servlet防止跨站引用

防止跨站引用
功能:本站点中的资源,比如图片资源,只允许在本站中的网站上使用,不允许直接下载该图片
Servlet名称:ImageServlet
特点:查看请求头中referer字段,如果该值不为空,则说明该图片是引用资源,则允许配访问

如何将图片(.jpg)发送给浏览器呢?
步骤:
1.创建一个图片文件file
2.使用图片文件构造一个FileInputStream输入流
3.使用FileInputStream输入流构造一个BufferedInputStream构造一个缓冲流bufferedInputStream
4.定义一个1k大小的字节数据,byte[] buffer = new byte[1024];
5.获取response对象中的输出流outPutStream对象
6.从bufferedInputStream中读取数据到buffer中,然后写到outPutStream对象中

7.关闭输入输出流


源代码:

package com.tanjie.download;

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.OutputStream;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet(urlPatterns={"/getImage"})
public class ImageServlet extends HttpServlet {

	private static final long serialVersionUID = 1L;

	@Override
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		String referer = request.getHeader("referer");
		if(referer != null){
			/*下载图片文件
			 * 1.从请求中获取imageId
			 * 2.获取图片存储路径imagePath
			 * 3.构造出file文件
			 * 4.构造FileInputStream、BufferedInputStream对象
			 * 5.写入到response的OutputStream对象中
			 * 6.关闭流
			 * */
			
			String imageId = request.getParameter("id");
			String imagePath = request.getServletContext().getRealPath("WEB-INF/image");
			File imageFile = new File(imagePath, imageId+".jpg");
			if(imageFile.exists()){
				response.setContentType("image/jpg");
				FileInputStream fileInputStream = null;
				BufferedInputStream bufferedInputStream = null;
				fileInputStream = new FileInputStream(imageFile);
				bufferedInputStream = new BufferedInputStream(fileInputStream);
				OutputStream outputStream = response.getOutputStream();
				byte[] buffer = new byte[1024];
				int i = bufferedInputStream.read(buffer);
				while(i != -1){
					outputStream.write(buffer, 0, i);
					i = bufferedInputStream.read(buffer);
				}
				if(fileInputStream != null)
					fileInputStream.close();
				if(bufferedInputStream != null)
					bufferedInputStream.close();
			}
		}
	}
	
}

<html>
<head>
    <title>Photo Gallery</title>
</head>
<body>
<img src="getImage?id=1"/>
<img src="getImage?id=2"/>
<img src="getImage?id=3"/>
<img src="getImage?id=4"/>
<img src="getImage?id=5"/>
<img src="getImage?id=6"/>
<img src="getImage?id=7"/>
<img src="getImage?id=8"/>
<img src="getImage?id=9"/>
<img src="getImage?id=10"/>
</body>
</html>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值