没有美化,没有格式,没有样式
1.JSP登陆注册
将用户注册的信息保存在application对象中,用于登录时的验证。
首页如下:
如果未登录,在 session 中找不到 currentUser 的值,则直接跳转到其他页面。
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <!-- 用于验证是否登录,如果没有登陆则不能访问该页面,并跳转到登录页面 --> <% Object obj = session.getAttribute("currentUser"); if (obj == null) { response.sendRedirect("login.jsp"); } %> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Insert title here</title> </head> <body> <h1>这是一个首页 !</h1> </body> </html>
注册页面如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="operation.jsp" method="post"> <input type="hidden" name="sub_type" value="reg" /> <input type="text" name="username" placeholder="输入用户名" /> <input type="password" name="password" placeholder="输入密码" /> <input type="password" name="password1" placeholder="确认密码" /> <input type="submit" value="注册" /><a href="login.jsp">返回登陆</a> </form> </body> </html>
登录页面如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="operation.jsp" method="post"> <input type="hidden" name="sub_type" value="log" /> <input type="text" name="username" placeholder="输入用户名" /> <input type="password" name="password" placeholder="输入密码" /> <input type="submit" value="登录" /><a href="register.jsp">注册新用户</a> </form> </body> </html>
用户类,用于存放用户信息:
仅有用户名和代码两个属性。
package test; public class User { private String username; private String password; 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 [username=" + username + ", password=" + password + "]"; } }
逻辑控制页面如下:
首先根据给登录页面和注册页面设置的隐藏的 sub_type 属性判断是登录还是注册,然后进行相应的判断。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="test.User"%> <% //获取请求的信息 String sub_type = request.getParameter("sub_type"); String username = request.getParameter("username"); String password = request.getParameter("password"); String password1 = request.getParameter("password1"); //判断是登录页面还是注册页面 if("reg".equals(sub_type)) { if (!password.equals(password1)) { out.print("两次输入的密码不一致 !"); } else { Object obj = application.getAttribute(username); if (obj != null) { //用传来的用户名找用户,如果不为空则用户已存在 out.print("用户名已经存在 !"); } else { User user = new User(); //实例化一个用户并设置信息 user.setUsername(username); user.setPassword(password); application.setAttribute(username, user); out.print("注册成功 !"); } } } if("log".equals(sub_type)) { Object obj = application.getAttribute(username); if(obj!=null) { User u = (User)obj;//将获取到的对象强转型,然后获取信息进行判断 if(password.equals(u.getPassword())) { session.setAttribute("currentUser", u); response.sendRedirect("index.jsp"); } else { out.print("密码不对啊 !"); } } else { out.print("用户名不存在 !"); } } out.print("<br>"); out.print("<a href='login.jsp'>跳转登陆</a>"); %>
2.记事本:
在用户登录注册的基础上进行修改,登陆后的用户可以在记事本留言,其他用户登录后可以看到,按照时间倒序排序,可以看到用户名,留言信息,留言时间。
添加一个留言类, Says类,有 用户,留言时间,留言内容三个属性。
主页如下,除了判断登录用户,设置 utf-8 之外,还有注意输出的时候先倒序,遍历输出之后再次倒序。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" import="test.Says,test.User,java.util.*"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <% Object obj1 = session.getAttribute("currentUser"); if (obj1 == null) { response.sendRedirect("denglu.jsp"); } %> <% request.setCharacterEncoding("utf-8"); response.setCharacterEncoding("utf-8"); %> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="chuli.jsp" method="post"> <input type="hidden" name="sub_type" value="tex" /> <textarea rows="4" cols="12" name="text"></textarea> <input type="submit" value="提交"> </form> <% Object obj=application.getAttribute("s"); if(obj!=null){ ArrayList<Says> list=(ArrayList)obj; Collections.reverse(list);//倒序,以保证后写入的内容排在上边 for(Says say : list){ out.print(say.getUname()+" "+"|"+" "); out.print(say.getDate()+"<br>"); out.print(say.getSays()+"<br>"); } Collections.reverse(list);//再次倒序,否则输出的后会出问题 } %> </body> </html>
注册:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="chuli.jsp" method="post"> <input type="hidden" name="sub_type" value="reg" /> <input type="text" name="username" placeholder="输入用户名" /> <input type="password" name="password" placeholder="输入密码" /> <input type="password" name="password1" placeholder="确认密码" /> <input type="submit" value="注册" /><a href="denglu.jsp">返回登陆</a> </form> </body> </html>
登录:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <form action="chuli.jsp" method="post"> <input type="hidden" name="sub_type" value="log" /> <input type="text" name="username" placeholder="输入用户名" /> <input type="password" name="password" placeholder="输入密码" /> <input type="submit" value="登录" /><a href="zhuce.jsp">注册新用户</a> </form> </body> </html>
用户类:
package test; public class User { private String username; private String password; 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; } }
留言类:
package test; import java.util.Date; public class Says { private String uname;//暂无用 private String date; private String says; public String getUname() { return uname; } public void setUname(String uname) { this.uname = uname; } public String getDate() { return date; } public void setDate(String date) { this.date = date; } public String getSays() { return says; } public void setSays(String says) { this.says = says; } @Override public String toString() { return "Says [uname=" + uname + ", date=" + date + ", says=" + says + "]"; } }
逻辑处理:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" import="test.Says,test.User,java.util.*"%> <% request.setCharacterEncoding("utf-8"); response.setCharacterEncoding("utf-8"); %> <% String sub_type = request.getParameter("sub_type"); String password = request.getParameter("password"); String password1 = request.getParameter("password1"); Says says=new Says(); if("reg".equals(sub_type)) { String username = request.getParameter("username"); System.out.println(username); if (!password.equals(password1)) { out.print("两次输入的密码不一致 !"); } else { Object obj = application.getAttribute(username); if (obj != null) { out.print("用户名已经存在 !"); } else { User user = new User(); user.setUsername(username); user.setPassword(password); application.setAttribute(username, user); out.print("注册成功 !"); } } out.print("<br>"); out.print("<a href='denglu.jsp'>跳转登陆</a>"); } if("log".equals(sub_type)) { String username = request.getParameter("username"); System.out.println(username); application.setAttribute("name",username); Object obj = application.getAttribute(username); if(obj!=null) { User u = (User)obj; if(password.equals(u.getPassword())) { session.setAttribute("currentUser", u); //String name=u.getUsername(); //application.setAttribute("name",name); response.sendRedirect("main.jsp"); } else { out.print("密码不对啊 !"); } } else { out.print("用户名不存在 !"); } out.print("<br>"); out.print("<a href='denglu.jsp'>跳转登陆</a>"); } if("tex".equals(sub_type)){ String say = request.getParameter("text"); Date d=new Date(); Object sobj=application.getAttribute("name");//获取用户名 String sname=(String)sobj; System.out.println(sname); says.setUname(sname); says.setSays(say); says.setDate(d.toLocaleString()); Object obj=application.getAttribute("s"); if(obj==null){ List list =new ArrayList(); list.add(says); application.setAttribute("s",list); }else{ List<Says> list=(List)obj; list.add(says); application.setAttribute("s",list); } response.sendRedirect("main.jsp"); } %>
纯JSP实现用户登录注册,记事本的更多相关文章
-
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 ...
-
Java Spring+Mysql+Mybatis 实现用户登录注册功能
前言: 最近在学习Java的编程,前辈让我写一个包含数据库和前端的用户登录功能,通过看博客等我先是写了一个最基础的servlet+jsp,再到后来开始用maven进行编程,最终的完成版是一个 Spri ...
-
使用JSP实现用户登录
本文讲述使用JSP实现用户登录,包括用户登录.注册和退出功能等. 1.系统用例图 2.页面流程图 3.数据库设计 本例使用oracle数据库 创建用户表 包括id,username,password和 ...
-
JavaWeb_(session和application)用户登录注册模板_进阶版
用户登录注册模板_基础版 传送门 用户登录注册模板进阶版 添加了获得获得当前登录用户信息及存储登录人数 用户登录后,在首页.注册页.登录页显示登录用户信息和存储登录人数信息 目录结构 <%@pa ...
-
JavaWeb_(request和response)用户登录注册模板_基础版
用户登录注册模板进阶版 传送门 用户登录注册模板基础版 登录:当用户登录成功时,跳转到personCenter.jsp,当用户登录失败时,跳转到login.jsp并给出提示 注册:当用户注册成功时,跳 ...
随机推荐
-
Android自定义控件4--优酷菜单的菜单键及细节补充
在上篇文章中实现了优酷菜单执行动画,本文接着完善已经实现的动画功能 本文地址:http://www.cnblogs.com/wuyudong/p/5915958.html ,转载请注明源地址. 已经实 ...
-
记录视频“ Why I build Docker";
Why we built Docker ? IT界中云计算革命正在如火如荼的进行着,docker 正在引领着这个潮流. 那么docker 是怎么引进来的呢? Docker的CTO在下面视频里如此清晰的 ...
-
Winform开发框架之插件化应用框架实现
支持插件化应用的开发框架能给程序带来无穷的生命力,也是目前很多系统.程序追求的重要方向之一,插件化的模块,在遵循一定的接口标准的基础上,可以实现快速集成,也就是所谓的热插拔操作,可以无限对已经开发好系 ...
-
MySQL数据库update更新子查询
比如: ? 1 2 3 4 UPDATE test.tb_vobile a set a.name = '111 ' WHERE a.id = (select max(id) id from test. ...
-
【HDOJ】1754 I Hate It
线段树. #include <iostream> #include <cstdio> #include <cstring> using namespace std; ...
-
《photoshop cc 新功能 生成图像资源》智能切图逆天啦!
作为一个前端工程师切图这个步骤是必不可少的,方式多种多样,有和切图工具的,也有是把要切的图层元素或者组直接新建保存成文件的,现在photoshop cc2015,可以让你轻松切图,摆脱繁琐的切图步骤. ...
-
nginx的url重写[rewrite规则和参考]
本日志内容来自互联网和平日使用经验,整理一下方便日后参考. Nginx Rewrite 相关指令有 if.rewrite.set.return 等. if 的语法 应用于 server 和 locat ...
-
duilib进阶教程 -- XML嵌套及自定义控件 (4)
代码下载:http://download.csdn.net/detail/qq316293804/6433937 之前入门教程里已经讲过了自定义控件,这里借着迅雷播放器再次举个例子. 1.我们先给迅雷 ...
-
[UE4]ue4 FString 中文乱码问题
使用FString出现乱码,最简单的情况,FString Str = "你好"; 这时候就会出现乱码,解决方法是改成这样 FString Str = TEXT("你好&q ...
-
SaltStack–Job管理
官方文档:https://docs.saltstack.com/en/2016.11/ref/modules/all/salt.modules.saltutil.html 在SaltStack里面执行 ...