案例:用户登录

用户登录案例需求

  1. 编写login.html登录页面

    username & password 两个输入框
  2. 使用Druid数据库连接池技术,操作mysql,day14数据库中user表
  3. 使用JdbcTemplate技术封装JDBC
  4. 登录成功跳转到SuccessServlet展示:登录成功!用户名,欢迎您
  5. 登录失败跳转到FailServlet展示:登陆失败!用户名或密码错误

分析

开发步骤

创建项目

创建JavaEE项目,导入 login.html 页面,druid.properties 配置文件,导入依赖 jar 包

  • login.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Login</title>
</head>
<body>
<form action="/day14_test/loginServlet" method="post">
用户名 <input type="text" name="username"><br/>
密码 <input type="password" name="password"><br/>
<input type="submit" value="登录">
</form>
</body>
</html>
  • druid.properties
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:///db3
username=root
password=root
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大等待时间
maxWait=3000
maxIdle=8
minIdle=3

创建数据库环境

CREATE DATABASE day14;

USE day14;

CREATE TABLE USER (
id INT PRIMARY KEY AUTO_INCREMENT, -- 编号
username VARCHAR(32) NOT NULL UNIQUE, -- 用户名
PASSWORD VARCHAR(32) NOT NULL -- 密码
);
DROP DATABASE IF EXISTS day14; SELECT * FROM USER;
INSERT INTO USER(id,username,PASSWORD) VALUES(NULL, 'superbaby','123');

创建包 com.my.domain,创建类User

package com.my.domain;

/**
* 用户的实体类
*/
public class User {
private int id;
private String username;
private String password; @Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
'}';
} public int getId() {
return id;
} public void setId(int id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
}
}

创建包 com.my.dao,创建类UsesrDao,提供login方法

package com.my.dao;

import com.my.domain.User;
import com.my.util.JDBCUtils;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate; /**
* 操作数据库中 User表的类
*/
public class UserDao { // 声明JDBCTemplate对象共用
private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource()); /**
* 登录方法
*
* @param loginUser 只有用户名和密码
* @return user包含用户全部数据,没有查询到,返回 null
*/
public User login(User loginUser) {
User user = null;
try {
// 1.编写sql
String sql = "select * from User where username = ? and password = ?";
// 2.调用query方法
user = template.queryForObject(sql,
new BeanPropertyRowMapper<User>(User.class),
loginUser.getUsername(), loginUser.getPassword());
return user;
} catch (DataAccessException e) {
e.printStackTrace(); // 后期会记录在日志
return null;
}
}
}

编写 com.my.web.servlet.LoginServlet类

package com.my.web.servlet;

import com.my.dao.UserDao;
import com.my.domain.User; import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException; @WebServlet("/loginServlet")
public class LoginServlet extends HttpServlet { @Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 1.设置编码,防止中文乱码
req.setCharacterEncoding("utf-8");
// 2.获取请求参数
String username = req.getParameter("username");
String password = req.getParameter("password");
// 3.封装User对象
User loginUser = new User();
loginUser.setUsername(username);
loginUser.setPassword(password); // 4.调用UserDao的login方法
UserDao dao = new UserDao();
User user = dao.login(loginUser); // 5.判断user
if (null == user) {
// 登录失败 // 转发
req.getRequestDispatcher("/failServlet").forward(req, resp);
} else {
// 登录成功 // 存储数据
req.setAttribute("user", user);
// 转发
req.getRequestDispatcher("/successServlet").forward(req, resp);
}
} @Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req, resp);
}
}

login.html中的form表单的action路径的写法

虚拟路径+Servlet资源路径

BeanUtils工具类,简化数据封装

  • 用于封装JavaBean的
  1. JavaBean:标准的Java类

    1. 要求:

      1. 类必须被public修饰
      2. 必须提供空参的构造器
      3. 一对getter和setter方法
      4. 成员变量必须使用private修饰
    2. 概念:
      1. 成员变量
      2. 属性:setter和getter方法截取后的产物
        • 例如:getUsername() --> Username --> username
  2. 方法
    1. setProperties():
    2. getProperties():
    3. populate(Object obj,Map map):将map集合的键值对信息,封装到对应的JavaBean对象中,把键当作属性名称,把值当作JavaBean对应的属性的值

案例:文件下载

  1. 文件下载需求

    1. 页面显示超链接
    2. 点击超链接后弹出下载提示框
    3. 完成图片文件下载
  • 分析

    1. 超链接指向的资源如果能被浏览器解析,则在浏览器中展示,如果不能解析,则弹出下载提示框。不满足需求
    2. 任何资源的下载都必须弹出下载提示框
    3. 使用响应头设置资源的打开方式:
      • content-disposition:attachment;filename=xxx
  • 步骤

    1. 定义页面,编辑超链接href属性,指向Servlet,传递资源名称filename
    2. 定义Servlet
      1. 获取文件名称(获取request参数)
      2. 使用字节输入流加载文件进内存
      3. 指定response的响应头:content-disposition:attachment;filename=xxx
      4. 将数据写出到response输出流
  • 问题:

    • 中文文件问题

      • 解决思路:

        1. 获取客户端使用的浏览器版本信息
        2. 根据不同的版本信息,设置filename的编码方式不同

代码实现

  • download.html
<a href="/day15/img/1.jpg">图片</a>
<br/>
<a href="/day15/img/2.flv">视频</a>
<hr/>
<!-- get请求在tomcat8中已解决中文乱码问题 -->
<a href="/day15/downloadServlet?filename=1.jpg">图片1</a>
<br/>
<a href="/day15/downloadServlet?filename=九尾.jpg">九尾</a>
<br/>
<a href="/day15/downloadServlet?filename=2.flv">视频</a>
  • DownloadServlet.java
package com.my.web.download;

import com.my.web.utils.DownLoadUtils;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.FileInputStream;
import java.io.IOException; /**
* 附件下载案例
*/
@WebServlet("/downloadServlet")
public class DownloadServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 1.获取请求参数,文件名称
String filename = request.getParameter("filename");
// 2.使用字节输入流加载文件进内存
// 2.1 获取ServletContext对象
ServletContext servletContext = this.getServletContext();
// 2.2 获取文件服务器真实路径
String realPath = servletContext.getRealPath("/img/" + filename); // 2.3 使用字节流关联
FileInputStream fis = new FileInputStream(realPath); // 3. 设置response的响应头
String mimeType = servletContext.getMimeType(filename); // 获取文件扩展名对应的mime类型 // 3.1 设置响应头的类型:content-type
response.setHeader("content-type", mimeType); // 3.2 设置响应头的打开方式:content-disposition // 解决中文文件名问题
// 1.获取user-agent请求头
String agent = request.getHeader("user-agent");
// 2.使用工具类方法编码文件名即可
filename = DownLoadUtils.getFileName(agent, filename); response.setHeader("content-disposition", "attachment;filename=" + filename); /*
// 简单的形式,设置编码,是在获取流之前设置
response.setContentType("text/html;charset=utf-8");
*/
// 4. 将输入流的数据写出到输出流中
ServletOutputStream sos = response.getOutputStream();
byte[] buff = new byte[1024 * 6]; // 缓冲数组
int len = 0; // 读取的有效个数
while ((len = fis.read(buff)) != -1) {
sos.write(buff, 0, len);
}
fis.close(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
}

JavaWebCase的更多相关文章

随机推荐

  1. AJ学IOS(48)多线程网络之多线程简单了解

    AJ分享,必须精品 一:进程和线程 1:什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内. 比如同时打开QQ.Xcode,系统就会分 ...

  2. Web三维编程入门总结之三:3D碰撞检测初探

    自己动手写一个方法比分析他人的写的方法困难很多,由此而来的对程序的进一步理解也是分析别人的代码很难得到的. 一.先来几张效果图: 1.场景中有两个半径为1的球体,蓝色线段从球心出发指向球体的“正向” ...

  3. 如何假装黑客,使用python去批量破解朋友的网站密码

    前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http ...

  4. lua学习之逻辑运算符not,and,or

    根据某度查询,lua中的逻辑运算符和其他高级语言大不相同,balabala.我们来看看 广大网友怎么说吧. 版本1: 版本2: 版本3:  揭晓答案: lua中的逻辑与或非与其他语言无差别,都是正常的 ...

  5. docx4j docx转html

    不好用,转完问题挺多,百度还找不到资料头疼.public static void docxToHtml(String fileUrl) throws Exception { String path = ...

  6. testlink数据表分析

    创建一个项目test node_types: 节点类型,这是一个固定的表 rights: 权限表,用户的操作权限 role_rights: 角色和权限关系表 roles: 角色表 testprojec ...

  7. python第三方库安装与卸载

    一.检查python环境是否正常 python安装完毕并设置环境变量后,可在cmd中运行python查看,显示版本等信息  二.查看已经安装的第三方库 通过pip list可查看已安装的库,以及对应的 ...

  8. JDBC教程——检视阅读

    JDBC教程--检视阅读 参考 JDBC教程--W3Cschool JDBC教程--一点教程,有高级部分 JDBC教程--易百 JDBC入门教程 – 终极指南 略读 三层架构详解,JDBC在数据访问层 ...

  9. Java 反射 -- 获取泛型类型

    先写一个类: public class Demo03 { public void test01(Map<String, User> map, List<User> list) ...

  10. CG-CTF(4)

    CG-CTF https://cgctf.nuptsast.com/challenges#Web 续上~ 第十六题:bypass again 代码分析: 当a不等于b,且a和b的md5值相同时,才会返 ...