- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章JavaWeb Servlet实现网页登录功能由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
上次写了一篇JDBC工具类实现登录功能,但是只能在控制台实现输入用户名密码。这次使用了Servlet来实现登录功能,可以通过在页面上输入账号密码,然后提交表单,查询数据库,从而实现登录功能.
1、配置文件,导入jar包 。
2、创建数据库环境 。
1
2
3
4
5
6
7
8
9
|
use student;
create
table
user
(
id
int
primary
key
auto_increment,
username
varchar
(32),
password
varchar
(32)
);
insert
into
user
values
(
null
,
'zhangsan'
,
'123'
);
insert
into
user
values
(
null
,
'lisi'
,
'234'
);
|
3、在web目录下创建HTML页面 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<!DOCTYPE html>
<
html
lang
=
"en"
>
<
head
>
<
meta
charset
=
"UTF-8"
>
<
title
>登录页面</
title
>
</
head
>
<
body
>
<
form
action
=
"/day14_request/loginServlet"
method
=
"post"
>
用户名:<
input
type
=
"text"
name
=
"username"
><
br
>
密码:<
input
type
=
"password"
name
=
"password"
><
br
>
<
input
type
=
"submit"
value
=
"登录"
>
</
form
>
</
body
>
</
html
>
|
4、在src下编写druid.properties文件 。
1
2
3
4
5
6
|
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:
//localhost:3306/student
username=root
password=root
maxActive=
10
maxWait=
1000
|
5、创建包cn.itcast.domain,创建类User 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
package
cn.itcast.domain;
/*
用户的实体类
*/
public
class
User {
private
int
id;
private
String username;
private
String 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;
}
@Override
public
String toString() {
return
"User{"
+
"id="
+ id +
", username='"
+ username + '\
''
+
", password='"
+ password + '\
''
+
'}'
;
}
}
|
6、创建包cn.itcast.util,编写工具类JDBCUtils 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
package
cn.itcast.util;
import
com.alibaba.druid.pool.DruidDataSourceFactory;
import
javax.sql.DataSource;
import
java.io.IOException;
import
java.io.InputStream;
import
java.sql.Connection;
import
java.sql.SQLException;
import
java.util.Properties;
/*
JDBC工具类,使用Durid连接池
*/
public class JDBCUtils {
private static DataSource dataSource;
static {
try {
//1、加载配置文件
Properties properties = new Properties();
InputStream resourceAsStream = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
properties.load(resourceAsStream);
//2、初始化连接池对象
dataSource = DruidDataSourceFactory.createDataSource(properties);
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 获取连接池对象
*/
public static DataSource getDataSource() {
return dataSource;
}
/**
* 获取连接Connection对象
*/
public
static
Connection getConnection()
throws
SQLException {
return
dataSource.getConnection();
}
}
|
7、创建包cn.itcast.dao,创建类UserDao,提供login方法 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
package
cn.itcast.dao;
import
cn.itcast.domain.User;
import
cn.itcast.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 jdbcTemplate =
new
JdbcTemplate(JDBCUtils.getDataSource());
/**
* 登录方法
* @param loginUser 只有用户和密码
* @return user 包含用户全部信息,没有查询到,返回null
*/
public
User login(User loginUser) {
try
{
//1、编写sql
String sql =
"select * from user where username = ? and password = ?"
;
//2、调用query方法
User user = jdbcTemplate.queryForObject(sql,
new
BeanPropertyRowMapper<User>(User.
class
),
loginUser.getUsername(),loginUser.getPassword());
return
user;
}
catch
(DataAccessException e) {
e.printStackTrace();
//记录日志
return
null
;
}
}
}
|
8、编写cn.itcast.web.servlet.LoginServlet类 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
package
cn.itcast.web.servlet;
import
cn.itcast.dao.UserDao;
import
cn.itcast.domain.User;
import
org.apache.commons.beanutils.BeanUtils;
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;
import
java.lang.reflect.InvocationTargetException;
import
java.util.Map;
@WebServlet
(
"/loginServlet"
)
public
class
LoginServlet
extends
HttpServlet {
protected
void
doPost(HttpServletRequest request, HttpServletResponse response)
throws
ServletException, IOException {
//1、设置编码
request.setCharacterEncoding(
"utf-8"
);
/*//2、获取请求参数
String username = request.getParameter("username");
String password = request.getParameter("password");
//3、封装对象
User loginUser = new User();
loginUser.setUsername(username);
loginUser.setPassword(password);*/
//2、获取所有请求参数(这里使用BeanUtils来简化操作)
Map<String, String[]> parameterMap = request.getParameterMap();
//3.1 创建User对象
User loginUser =
new
User();
//3.2 使用BeanUtils对象
try
{
BeanUtils.populate(loginUser,parameterMap);
}
catch
(IllegalAccessException e) {
e.printStackTrace();
}
catch
(InvocationTargetException e) {
e.printStackTrace();
}
//4、调用UserDao的login方法
UserDao userDao =
new
UserDao();
User user = userDao.login(loginUser);
//5、判断user
if
(user ==
null
) {
//登录失败
request.getRequestDispatcher(
"/failServlet"
).forward(request,response);
}
else
{
//登录成功
//存储数据
request.setAttribute(
"user"
,user);
//转发
request.getRequestDispatcher(
"/successServlet"
).forward(request,response);
}
}
protected
void
doGet(HttpServletRequest request, HttpServletResponse response)
throws
ServletException, IOException {
this
.doPost(request,response);
}
}
|
1、目录结构 。
2、运行界面 。
3、输入用户名密码均正确 。
4、跳转到成功登录界面 。
5、输入用户名或密码错误时 。
6、跳转登录失败界面 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/weixin_44668898/article/details/107542031 。
最后此篇关于JavaWeb Servlet实现网页登录功能的文章就讲到这里了,如果你想了解更多关于JavaWeb Servlet实现网页登录功能的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个关于 Java Servlet 的问题。 假设我在 servlet 网页“somePage”上。我想登录(使用另一个 servlet,“登录”servlet)。所以我点击“somePage”上
如何将变量数组从一个 servlet 传递到另一个 servlet? 最佳答案 如果您要将当前请求传递给另一个servlet,则只需将其设置为请求属性即可。 request.setAttribute(
什么可能导致此错误? Caused by: jakarta.servlet.UnavailableException: Servlet class org.restlet.ext.servle
我的maven依赖树是这样的 我想问我maven如何解决这个冲突,有两个servlet-api.jar?提前谢谢你。 最佳答案 如果您想从 Velocity 工具中删除 servlet-api,您可以
config ProcessReg ProcessReg text HelloWorld1 public class config implements Serv
您好,我有一个关于 servlet 调用另一个 servlet 的问题 我有一个名为 Relay 的主 servlet,它将负责控制其他 servlet 用户将点击并将转发到 Relay servle
在我的 REST API 项目中,我已将 /* 映射到 RESTServlet,并且需要在同一 WAR 中托管静态内容。我更愿意将 /static/* 映射到 WAS liberty 提供的默认 se
响应映射在 Servlet 中如何工作? 每个响应如何知道清除特定 HTML 或 Handlebars 上的输出? 最佳答案 有一个 ember-java带有 Jersey REST 服务 的 git
有一个 @WebServlet(urlPatterns = "/myServlet/") .如果用户转到 myapp/myServlet/other ,我仍然希望我的 servlet 能够捕获。也就是
我正在使用 Filter 在我的所有页面中插入反点击劫持 header - 这工作正常,除了 JBoss EAP 6.3 容器管理的登录页面,这是更重要的页面之一拥有它。 登录页面根本不调用过滤器,登
我正在尝试使用 RequestDispatcher 将数据从一个 servlet 传递到另一个 servlet。这是我的调度程序代码。 String address; address = "/Java
我刚刚开始使用 Servlet,并设法让一些 Servlet 充当单独的 URL,用于填充数据库以进行一些虚拟测试。某种形式: public class Populate_ServletName ex
我是否需要同时配置app.servlet.version 和 grails.servlet.version? 前者在application.properties中,后者在BuildConfig.gro
在Myeclipse中我创建了一个名为web1的Web项目,并添加了一个名为servlet1的servlet,web.xml如下: servlet1 servlet1
这个问题在这里已经有了答案: How to run a background task in a servlet based web application? (5 个回答) 6年前关闭。 是否可以在
在我的 ManagedBean 中,如果我将范围从 @RequestScoped 更改为 @ViewScoped,我将收到以下错误堆栈。我该如何解决这个问题?不过,当我运行应用程序时,我可以在页面中看
这个问题已经有答案了: How do I execute multiple servlets in sequence? (2 个回答) 已关闭 3 年前。 我已经构建了jdbc-Servlet的代码,
我一直在徒劳地尝试实现 tomcat 9 的 jakarta servlet,而不是以前的 javax.servlet 实现(因为我的理解是 jakarta 包是前进的方向)。问题是,当我将浏览器指向
我是 Spring 新手,正在尝试使用 Maven 部署和运行我的第一个 Spring Web 应用程序。有关更多详细信息,请参阅 here (我昨天发布的一个问题): 现在,我遇到的问题是:当我尝试
我正在尝试学习如何使用 JSP。我遇到了一些毫无意义的事情,至少在我看来是这样: 当我尝试运行时: response.getWriter().println(m.getDb().printAll())
我是一名优秀的程序员,十分优秀!