1.图片验证码的实现
2行
注册、下单、支付
目的:
1) 验证操作者是否是人
2) 防止表单重复提交
生成验证码的要点:
1) 使用java代码生成图片对象
BufferedImage
2) 使用Random生成随机字符串
3) 将图片对象用
ImageIO.write(图片对象, "jpeg|png", 响应字节输出流)
返回给客户端浏览器
验证验证码:
要点:
1) 将验证码文字存入session作用域
2) 表单提交时,对比session中的验证码和表单中的验证码
2. 短信验证码
调用第三方的短信服务
阿里云的短信服务使用方法:
https://www.aliyun.com/ 官方网站
产品和服务=> 云通信=> 短信服务
- 充值
- 下载短信的sdk (软件开发包)
- 生成开发者的id 和 secret
管理控制台=>用户信息管理=>创建AccessKEY - 设置短信模板和短信签名
短信服务=>国内消息
短信签名:发送者是谁
短信模板:规定了短信的内容
3. 动态include和静态include
静态include
<%@ include file="目标文件" %> 1.jsp+2.jsp 合并在一起 => 一个servlet
动态include
<jsp:include page="目标文件" /> 1.jsp 生成servlet1, 2.jsp 生成servlet2
把servlet1生成的结果和servlet2的结果合并在一起
另外注意page和file的区别
file后只能是jsp(实际存在的文件)
page除了可以是一个jsp以外,还可以是一个servlet的地址
4. jsp动作
java 15行
<!-- 等价于 request.setAttribute("stu", new Student()); -->
<jsp:useBean id="stu" class="entity.Student" scope="request"/>
<!-- stu.setName("张三"); -->
<jsp:setProperty name="stu" property="name" value="张三"/>
<!-- stu.getName(); -->
<jsp:getProperty name="stu" property="name"/>
<!-- 动态include -->
<%--<jsp:include page="2.jsp"/>--%>
<!-- 转发 -->
<%--<jsp:forward page="1.jsp"/>--%>
4. 文件上传
注意: 1) method必须是post 2) 必须采用复杂的格式,不能是name=value的参数格式, 必须是multipart/form-data的格式
apache提供了 commons-fileupload.jar 专门用来解析multipart/form-data的格式
commons-io.jar
// 通过程序创建目录
new File("e:\images").mkdirs()
5.文件下载
// 2) 如果要把图片进行下载操作
resp.setContentType("application/octet-stream");
resp.addHeader("content-disposition","attachment;filename=1.jpg");
// 把【浏览器的路径】 转换为 【服务器的磁盘路径】
String uri = req.getRequestURI(); // 获取浏览器实际输入路径
System.out.println(uri);
String path = "e:\\" + uri;// 图片的磁盘路径
// 如果文件不存在,返回404
if( !new File(path).exists() ) {
resp.sendError(404);
return ;
}
// 如果存在,从文件输入流读取,向响应的输出流写
FileInputStream is = new FileInputStream(path);
OutputStream os = resp.getOutputStream();
IOUtils.copy(is, os);
IOUtils.closeQuietly(is);
}
}