servlet+jsp完成简单登录
将用户在注册界面中的数据填充到数据库相对应的表格中。当用户再次登录时,从数据库中拿到相应的数据查询并与页面的数据做对比,判断是否登陆成功。
需要在HTML文件中将form表单上的action属性值设置为web项目名加处理数据的servlet文件。
1.导入相应的jar包,MySQL,c3p0,BeanUtils,页面的文件和图片等。
2.按照数据库中表单的相应数据创建JavaBean
3.设置相对应的编码格式
4.利用BeanUtils.populate(user,map名称)将注册表单的信息与javaBean对象形成一一对应关系(工作原理:将map中key的名字与实体属性的名字对比user,如果一样就将map的value封装到实体user中去)
5.编写业务将user对象作为参数传给register方法,连接数据库,编写SQL语句,执行update方法。
post提交乱码问题的解决方法:
Request.setCharacterEncoding("UTF-8");
get提交遇到乱码问题
1.拿到乱码的字段
2.将乱码设置成iso8859-1编码格式,
3.在将编码后的用utf-8解码
例如:username输入中文时遇到乱码,将username=new String(username.getBytes("iso8859-1"),"utf-8");
这种解决方式同样适用于post提交。
注册用户核心代码:
有关的servlet核心代码如下:
Protected void doPost(HttpServletRequestrequest,HttpServletResponseresponse)throws ServletException,IOException{
//设置编码格式
response.setContentType("text/html;charset=UTF-8");
request.setCharacterEncoding("UTF-8");
//获得提交的参数返回一个map集合,并通过beanutils.populate方法将参数映射到一个user对象中
Map<String,String[]> map = request.getParameterMap();
User user=new User();
try{
BeanUtils.populate (user,map);
}catch(IllegalAccessExceptione){
e.printStackTrace();
}catch(InvocationTargetExceptione){
e.printStackTrace();
}
//设置随机ID
user.setUID(UUID.randomUUID().toString());
//编写业务代码,用Druid连接数据库,插入数据
Properties properties=new Properties();
properties.load(JdbcUtils.class.getClassLoader().getResourceAsStream("properties.properties"));
DataSource dataSource = null;
try{
dataSource = DruidDataSourceFactory.createDataSource(properties);
}catch(Exceptione){
e.printStackTrace();
}
QueryRunner queryRunner= new QueryRunner(dataSource);
String sql="insert into register_user values(?,?,?,?,?,?,?,?)";
Int i=0;
try{
i=queryRunner.update(sql,user.getUID(),user.getUsername(),user.getPassword()
,user.getEmail(),user.getName(),user.getTelephone(),user.getSex(),user.getBirthday());
}catch(SQLExceptione){
e.printStackTrace();
}
if(i==1){
//注册成功,重定向到登录界面
response.sendRedirect("login.jsp");
}else{
//注册失败,转发并显示错误信息
response.getWriter().println("注册失败!");
}
登录页面:<formaction="LoginServlet"method="POST">
核心代码:
<divclass="lg_m_1">
<fontsize="3px">用户名:</font><inputname="username"value=""type="text"class="ur"placeholder="请输入用户名"/></br>
<fontsize="3px">密码:</font><inputname="password"type="password"value=""class="pw"placeholder="请输入密码"/>
<divstyle="height:20px">
<%-- 错误信息显示 --% >
<%=request.getAttribute("loginError")==null?"":request.getAttribute("loginError")%>
</div>
<label><inputtype="checkbox">自动登录
</label> <label><input
type="checkbox">记住用户名
</label>
loginServlet核心代码:
@WebServlet("/LoginServlet")
Public class LoginServlet extends HttpServlet{
Protected void doPost (HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{
response.setContentType("text/html;charset=UTF-8");
request.setCharacterEncoding("UTF-8");
//1.获取登陆时的参数
String username=request.getParameter("username");
String password=request.getParameter("password");
//2.与数据库的数据对比
//3.如果登陆成功,重定向首页,失败,转发提示登录错误信息
User login=login(username,password);
if(login==null){
request.setAttribute("loginError","用户名或密码错误!");
request.getRequestDispatcher("login.jsp").forward(request,response);
}else{
response.sendRedirect(request.getContextPath());
}
}
Protected void doGet(HttpServletRequest request,HttpServletResponse response)throws ServletException,IOException{
doPost(request,response);
}
Public User login(String username,String password){
Properties properties=new Properties();
try{
properties.load(JdbcUtils.class.getClassLoader().getResourceAsStream("properties.properties"));
}catch(IOExceptione){
e.printStackTrace();
}
DataSource dataSource=null;
try{
dataSource=DruidDataSourceFactory.createDataSource(properties);
}catch(Exceptione){
e.printStackTrace();
}
QueryRunner queryRunner=new QueryRunner(dataSource);
String sql="select*from register_user where username=? And password=?";
User user=null;
try{
user=queryRunner.query(sql,new BeanHandler<User>(User.class),username,password);
}catch(SQLExceptione){
e.printStackTrace();
}
return user;
}
servlet+jsp完成简单登录的更多相关文章
- 纯JSP实现简单登录跳转
1.JSP介绍 JSP即Java Server Pages,JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑.网页还能通过tags和script ...
- 使用Eclipse开发Web项目(JSP)——简单登录、无sql
1.使用Eclipse开发Web项目(JSP) tomcat 2.在Eclipse中创建的Web项目: 浏览器可以直接访问webContent中的文件 例如http://localhost:8080/ ...
- jsp+servlet+mysql 实现简单的银行登录转账功能
jsp+servlet+mysql 实现简单的银行登录转账功能 [前期的准备] html(登录界面),servlet(处理业务逻辑),jsp(主要实现界面),mysql(实现与数据库的简单的交互)先从 ...
- javaweb学习总结(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册
一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...
- JavaWeb学习 (二十一)————基于Servlet+JSP+JavaBean开发模式的用户登录注册
一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...
- 基于Servlet+JSP+JavaBean开发模式的用户登录注册
http://www.cnblogs.com/xdp-gacl/p/3902537.html 一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBea ...
- javaweb(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册
一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...
- JavaWeb实现用户登录注册功能实例代码(基于Servlet+JSP+JavaBean模式)
一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...
- jdbc+servlet+jsp实现登录验证
基础知识准备:sql的增删改查. 新增:insert into 表名称(字段名.....)values(字段名....). 修改:update 表名称 set 字段名="新值" ...
随机推荐
- 转:什么是Shingling算法
shingling算法用于计算两个文档的相似度,例如,用于网页去重.维基百科对w-shingling的定义如下: In natural language processing a w-shinglin ...
- MySQL技术内幕InnoDB存储引擎(一)——MySQL体系结构和存储引擎
1.数据库和实例 数据库(database)和实例(instance)不能混淆. 什么是数据库 数据库是物理操作系统文件或其他文件类型的集合.说白了,就是存储着的文件,不会运行起来,只能被实例增删改查 ...
- 超详细!使用 LVS 实现负载均衡原理及安装配置详解---转
负载均衡集群是 load balance 集群的简写,翻译成中文就是负载均衡集群.常用的负载均衡开源软件有nginx.lvs.haproxy,商业的硬件负载均衡设备F5.Netscale.这里主要是学 ...
- 跨站点脚本编制 - SpringBoot配置XSS过滤器(基于Jsoup)
1. 跨站点脚本编制 风险:可能会窃取或操纵客户会话和 cookie,它们可能用于模仿合法用户,从而使黑客能够以该用户身份查看或变更用户记录以及执行事务. 原因:未对用户输入正确执行危险字符清 ...
- Spark-5-如何定位导致数据倾斜的代码
数据倾斜只会发生在shuffle过程中.这里给大家罗列一些常用的并且可能会触发shuffle操作的算子:distinct.groupByKey.reduceByKey.aggregateByKey.j ...
- Python高级语法-多继承MRO相关-args和kwargs(4.5.2)
@ 目录 1.说明 2.代码 关于作者 1.说明 args数据类型为元组 kwargs数据类型为字典 一般传入方法中使用遍历去得到值 这个传入参数的顺序没有特殊的要求 当你自定义的参数传完以后,写了名 ...
- matplotlib的学习15-次坐标轴
import matplotlib.pyplot as plt import numpy as np x = np.arange(0, 10, 0.1) y1 = 0.05 * x**2 y2 = - ...
- MySQL中函数总结
SQL中提供的函数: version() 查询当前数据库版本 user() 查询当前登录用户 database() 查询当前所在数据库 uuid() 返回uuid的值,分布式情况下数据库 ...
- 简单测试linq to sql性能
前些日子,做了一个物业收费系统,cs模式,用到了linq to sql 技术,这是我第一次使用这个东东写程序存取数据库,迷迷糊糊搞得一塌糊涂,当时有个同学他们找好的分页组件,然后写好了调用方 ...
- 3.自定义view-TextView变色
1.效果 2.实现原理 自定义Textview,重写onDraw方法,将画布分成两部分,用不同颜色的画笔画 核心代码: @Override protected void onDraw(Canvas c ...