jsp第十周
数据库test 中建个表 stu(stuid 主键 自动增长 ,用户名,密码,年龄)
1.设计一个注册页面,实现用户注册功能
2.设计一个登陆页面,实现用户名密码登陆
3.两个页面可以互相超链接
BaseDao.java
package dao; import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; public class BaseDao { // 获取连接
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName("com.mysql.jdbc.Driver");
// 2.建立连接
conn = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/test", "root", "root");
} catch (Exception e) {
e.printStackTrace();
}
return conn;
} // 关闭连接
public static void closeAll(Connection con, PreparedStatement ps, ResultSet rs) {
try {
if (rs != null)
rs.close();
if (ps != null)
ps.close();
if (con != null)
con.close(); } catch (SQLException e) {
e.printStackTrace();
}
} }
stuDao.java
package dao; import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; public class stuDao { public static void main(String[] args) {
stuDao s=new stuDao();
String sname="张三";
int pwd=12;
System.out.println(s.login(sname, pwd));
}
public student login(String sname, int pwd) {
Connection conn = BaseDao.getConnection();
student s=null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
String sql = "select * from stu where sname=? and pwd=?";
ps = conn.prepareStatement(sql);
ps.setString(1, sname);
ps.setInt(2, pwd);
rs = ps.executeQuery();
if (rs.next()) {
s=new student();
String name=rs.getString("sname");
s.setSname(name);
return s;
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
BaseDao.closeAll(conn, ps, rs);
}
return s;
} public int reg(String sname, int pwd, int age) {
Connection conn = BaseDao.getConnection();
PreparedStatement ps = null;
int r = -1;
try {
String sql = "insert into stu(sname,pwd,age) values(?,?,?)"; // 2个占位符
// 4.执行SQL语句
ps = conn.prepareStatement(sql);
ps.setString(1, sname);
ps.setInt(2, pwd);
ps.setInt(3, age);
r = ps.executeUpdate();// 增删改都用这个
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
BaseDao.closeAll(conn, ps, null);
}
return r; } }
student.java
package dao;
public class student {
String sname;
int pwd;
int age;
public String getSname() {
return sname;
}
public void setSname(String sname) {
this.sname = sname;
}
public int getPwd() {
return pwd;
}
public void setPwd(int pwd) {
this.pwd = pwd;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "student [sname=" + sname + ", pwd=" + pwd + ", age=" + age
+ "]";
}
}
student.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <html>
<head> <title>My JSP 'student.jsp' starting page</title> </head>
<% %>
<body>
<form action="slogin.jsp">
学生姓名:<input type="text" name="sname" /> 账号密码:<input type="password"
name="spwd" /> <input type="submit" value="登录" />
</form>
<form action="slogon.jsp">
<input type="submit" value="注册" />
</form>
</body>
</html>
slogin.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <html>
<head> <title></title> </head>
<%@ page import="dao.stuDao"%>
<%
String name = request.getParameter("sname");
String spwd = request.getParameter("spwd");
String sname = new String(name.getBytes("ISO-8859-1"), "utf-8");
try {
int pwd = Integer.parseInt(spwd);
stuDao studao = new stuDao();
if (studao.login(sname, pwd) != null) {
out.println("登录成功!");
} else {
out.println("登陆失败!");
out.println("三秒后跳转到主页面...");
response.setHeader("refresh", "3;url=student.jsp");
}
} catch (Exception e) {
out.println("异常!!");
out.println("三秒后跳转到主页面...");
response.setHeader("refresh", "3;url=student.jsp");
}
%>
<body>
<a href="student.jsp">返回</a>
</body>
</html>
slogon.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <html>
<head> <title>My JSP 'slogon.jsp' starting page</title> </head>
<% %>
<body>
<h3>请输入信息来完成注册...</h3>
<form action="slogon_link.jsp">
用户名:<input type="text" name="sname" /> 密码:<input type="password"
name="spwd" /> 年龄:<input type="text" name="sage" /> <input
type="submit" value="注册" />
</form>
<a href="student.jsp">返回</a>
</body>
</html>
slogon_link.jsp
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <html>
<head> <title>My JSP 'slogon_link.jsp' starting page</title> </head>
<%@ page import="dao.stuDao"%>
<%
String sname = request.getParameter("sname");
String spwd = request.getParameter("spwd");
String sage = request.getParameter("sage");
String name=new String(sname.getBytes("ISO-8859-1"),"utf-8");
int pwd = Integer.parseInt(spwd);
int age = Integer.parseInt(sage);
stuDao s = new stuDao();
if (s.reg(sname, pwd, age) != -1) {
out.println("注册成功!");
out.println("三秒后跳转到主页...");
response.setHeader("refresh", "3;url=student.jsp");
} else {
out.println("注册失败!");
out.println("三秒后跳转到主页...");
response.setHeader("refresh", "3;url=student.jsp");
}
%>
<body>
</body>
</html>




jsp第十周的更多相关文章
- 第十周PSP&进度条
PSP 一.表格: D日期 C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(mins) 11月17号 站立会议 分配任务 13:00 13:30 0 3 ...
- 第十周 11.28 psp0
课堂测试总结 学生:马小心 日期:2017.11.28 作业号 日期 过程 估计数据 实际数据 累计数据 时间 ...
- 第十周 psp
团队项目PSP 一:表格 C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(mins) 讨论 讨论用户界面 8:45 10:55 40 35 90 分析与 ...
- Java 第十周学习总结
20145113<Java程序设计>第十周学习总结 基础知识 1.网络通讯的方式主要有两种 TCP(传输控制协议)方式:需要建立专用的虚拟连接以及确认传输是否正确 UDP(用户数据报协议) ...
- 第十周PSP
第十周PSP 工作周期:11.17-11.24 本周PSP: C类型 C内容 S开始时间 ST结束时间 I中断时间 T净时间(分) 文档 写随笔(PSP) 16:20min 16:50min 0 ...
- 20145213《Java程序设计》第十周学习总结
20145213<Java程序设计>第十周学习总结 教材学习总结 网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接 ...
- 21045308刘昊阳 《Java程序设计》第十周学习总结
21045308刘昊阳 <Java程序设计>第十周学习总结 教材学习内容总结 网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据. 狭义的网络编程范畴:程序员所作的事情 ...
- 20145330第十周《Java学习笔记》
20145330第十周<Java学习笔记> 网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收到指定的数据,这个就 ...
- 《Java程序设计》第十周学习总结
20145224 <Java程序设计>第十周学习总结 网络编程 ·网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收到指定的 ...
- 20145236 《Java程序设计》 第十周学习总结
20145236 <Java程序设计> 第十周学习总结 Java网络编程 Java网络编程技术 Java语言是在网络环境下诞生的,所以Java语言虽然不能说是对于网络编程的支持最好的语言, ...
随机推荐
- HTML基本介绍与操作
一,HTML介绍 HTML,全称是超文本标记语言(HyperText Markup Language),它是一种用于创建网页的标记语言.标记语言是一种将文本(Text)以及文本相关的其他信息结合起来, ...
- windows server的应用软件限流QoS
原因: 生产环境中程序员写的redis调用方法有逻辑问题, 导致流量高达800~900Mbps导致服务器其它网络服务有丢包现象, 他又有别的项目紧急需要修改,只能通过系统自带的QoS临时限流控制. 1 ...
- vue项目,npm run dev的时候出现:Error: error:0308010C:digital envelope routines::unsupported
vue项目,npm run dev的时候出现:Error: error:0308010C:digital envelope routines::unsupported 这个是node的版本问题.我的n ...
- @EnableAspectJAutoProxy 注解的作用 —— 转载
@EnableAspectJAutoProxy(proxyTargetClass = true, exposeProxy = true)解决同类方法调用时异步和事务不生效:我们在开启springboo ...
- SAP 内外交货单过账
* 交货单过账 DATA: LS_HEADER_DATA TYPE BAPIIBDLVHDRCON, LS_HEADER_CONTROL TYPE ...
- 睿爸信奥-【临阵磨枪】练习赛(第一场)- T3
目录 题面 题目背景 输入格式 输出格式 思路 code 题面 题目背景 徐老师很胖,长宽高比例为1:1:1,他每次走路都要滚来滚去~~现在假设在一个平面上有 n 个没有公共点公共点的圆.徐老师要从点 ...
- yzh 总线选讲
分布式:通过总线,我们可以用"通信""消息"等视角,把各个模块拆成各个小状态机,每个小状态机互相之间独立,通过总线通信 集中式:通过一个大状态机生成所有控制信号 ...
- 网络服务之DHCP与FTP
目录 DHCP 一.DHCP是什么? 二.DHCP的优点 三.DHCP的分配过程 四.DHCP的工作原理 五.DHCP动态获取实验 FTP 一.FTP是什么? 二.FTP的数据连接模式 三.svftp ...
- JS篇(007)-事件委托是什么
答案:利用事件冒泡的原理,让自己的所触发的事件,让他的父元素代替执行! 解析: 1.那什么样的事件可以用事件委托,什么样的事件不可以用呢? 适合用事件委托的事件:click,mousedown,mou ...
- Taro3 扫描不同二维码参数不同,但是热启动之后参数不变 根据环境不同更换域名
热启动:先执行缓存的静态数据,然后再执行页面代码.比如右上角退出或者按home键错误用法:用的Taro3 react function函数,之前用的 Taro.getLaunchOptionsSyn ...