Servlet学习D3 --文件下载及servlet线程安全问题

Servlet学习D3 --文件下载及servlet线程安全问题

一、 文件下载

在servlet中实现文件下载需要注意的地方有两点。

1. 相应类型需要做修改,response.setContentType(“bin”);

2. 在相应中添加附加信息response.addHeader(“Content-dispositation”,”attachment;filename=\”aa.jgp\””);

3. 在下载时解决文件名是中文时的乱码问题

String filename = new String(filename.getBytes(“utf-8”),”iso-8859-1”);

		// 将需要给客户端传送的东西读到程序来
		File file = new File(tarPath);
		InputStream is = new FileInputStream(file);
		byte[] buff = new byte[is.available()];
		is.read(buff);
		// 在相应给客户端之前 必须要设置相应类型
		response.setContentType("bin");
		String fileName = new String(file.getName().getBytes("utf-8"), "iso-8859-1");
		response.addHeader("Content-disposition", "attachment;filename=\"" + fileName + "\"");
		// 把读进来的东西相应给客户端
		OutputStream os = response.getOutputStream();
		os.write(buff);
		os.flush();
		os.close();
		is.close();

二、关于servlet的线程安全问题

1.Servlet是一个线程不安全的技术。我们在servlet中定义成员变量时,需要额外注意,如果非要定义成员变量,那么以读取为主。千万不要又读又写。如果真的有这样的需求。加锁拉解决数据安全性的问题。

2.SingleThreadModel:servlet中提供的一个标识接口,该接口标识实现了该接口的servlet的运行方式会由并行化改为串行化执行。效率及其低下。所以该接口解决线程安全的方式已经过时,不推荐使用了。

3.Servlet在解决线程安全上更推荐我们使用锁来解决。

此外,类似struct2等框架,与servlet,springmvc等的不同点在于,其内部的action(类似于servlet)是线程安全的,每次给action传值的时候 ,不需要像servlet一样用request.getParameter(),而会自动产生表单数据,注入到action对象里面,因为其特点在于 :如果action对象内部的属性的名字和浏览器地址栏里的key相同,并且有get set方法时,它会自动产生表单数据;他是线程安全的,因为每一次请求,都会产生一个独立的action对象,比如两个请求去请求同一个action,会产生两个action的对象,使得对象之间数据分离
,避免了数据重复,因此线程安全

你可能感兴趣的:(Servlet学习D3 --文件下载及servlet线程安全问题)