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 字段名="新值" ...
随机推荐
- Codeforces Edu Round 61 A-C + F
A. Regular Bracket Sequence 显然,"\(()\)"不影响结果它是自我匹配的,可以把所有的\(((\)和\())\)都放在左边/右边,这样只要检查它们的数 ...
- AcWing 392. 会合
一个思路不难,但是实现起来有点毒瘤的题. 显然题目给出的是基环树(内向树)森林. 把每一个基环抠出来. 大力分类讨论: 若 \(a, b\) 不在一个联通量里,显然是 \(-1, -1\) 若 \(a ...
- 廖雪峰官网学习js 数组
indexOf( ) 某字符的位置 slice 相当于string 的substring 切片 a = ['a','b',1,2,3] (5) ["a", "b&q ...
- Ionic学习记录
1.跨域问题 浏览器中的运行 当你运行 ionic serve 时发生了什么呢? 启动了一个本地 web 服务器 你的浏览器打开并定位到本地服务器地址 这让你看着你的应用加载到你电脑上一个浏览器里,地 ...
- IE各版本和Windows的关系
- Git:git常用命令
1.版本控制工具 一个可以管理和追踪软件代码的工具. 分类: 集中式版本控制工具:SVN 分布式版本控制工具:Git 2.Git 的概念: 工作区:就是 ...
- 某宝的微信小程序源码合集
这是我在某宝买的小程序源码合集.能用的我用不到.. 我用的到的有的有没后端.仅供个人参考,严禁侵权或商业用途! 下载地址:https://pan.baidu.com/s/1cQEQ17LdN-7hxD ...
- Vue-组件化,父组件传子组件常见传值方式
前言 我们都知道vue核心之一:组件化,vue中万物皆组件,组件化我认为应该来至于模块化的设计思想,比如在模块化开发中,一个模块就是一个实现特定功能的独立的文件,有了模块我们就更方便去阅读代码,更方便 ...
- linux下postgresql安装
1.下载地址 https://www.enterprisedb.com/download-postgresql-binaries 2.创建用户并修改密码 [root@node01 ~]# userad ...
- 第 16 章 【硬核!】 垃圾回收相关 GC细讲
第 16 章 垃圾回收相关概念 1.System.gc() 的理解 1.1.System.gc() 方法 System.gc() 方法 在默认情况下,通过System.gc()者Runtime.get ...