JAVA语言之Servlet案例:用户注册[Java代码]
龚超 2018-07-20 来源 : 阅读 1715 评论 0

摘要:本文主要向大家介绍了JAVA语言的Servlet案例:用户注册,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

本文主要向大家介绍了JAVA语言的Servlet案例:用户注册,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

数据库准备:

CREATE DATABASE web;

USE web;

CREATE TABLE `user` (

`uid` VARCHAR(64) NOT NULL,

`username` VARCHAR(20) DEFAULT NULL,

`password` VARCHAR(20) DEFAULT NULL,

`name` VARCHAR(20) DEFAULT NULL,

`email` VARCHAR(30) DEFAULT NULL,

`telephone` VARCHAR(20) DEFAULT NULL,

`birthday` VARCHAR(20) DEFAULT NULL,

`sex` VARCHAR(10) DEFAULT NULL,

`state` INT(11) DEFAULT NULL,

`code` VARCHAR(64) DEFAULT NULL,

PRIMARY KEY (`uid`)

)

复制代码

View Code


对应的类:

package register;


public class User {

private String uid;

private String username;

private String password;

private String name;

private String email;

private String sex;

private String birthday;


public String getUid() {

return uid;

}


public void setUid(String uid) {

this.uid = uid;

}


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;

}


public String getName() {

return name;

}


public void setName(String name) {

this.name = name;

}


public String getEmail() {

return email;

}


public void setEmail(String email) {

this.email = email;

}


public String getSex() {

return sex;

}


public void setSex(String sex) {

this.sex = sex;

}


public String getBirthday() {

return birthday;

}


public void setBirthday(String birthday) {

this.birthday = birthday;

}


@Override

public String toString() {

return "User [uid=" + uid + ", username=" + username + ", password=" + password + ", name=" + name + ", email="

+ email + ", sex=" + sex + ", birthday=" + birthday + "]";

}


}

复制代码

View Code



注册登录页面很简单,一个表单即可,这里省略


servlet:

package register;


import java.io.IOException;

import java.lang.reflect.InvocationTargetException;

import java.sql.SQLException;

import java.util.Map;

import java.util.UUID;


import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;


import org.apache.commons.beanutils.BeanUtils;

import org.apache.commons.dbutils.QueryRunner;


public class RegisterServlet extends HttpServlet {


public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

//中文乱码的解决

request.setCharacterEncoding("UTF-8");


//中文乱码的解决原理

/*

String username = request.getParameter("username");

username = new String(username.getBytes("iso8859-1"),"UTF-8");

*/



// 获取数据

// 将数据封装(使用BeanUtils自动封装)

Mapproperties = request.getParameterMap();

User user = new User();

try {

BeanUtils.populate(user, properties);

} catch (IllegalAccessException | InvocationTargetException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

// users对象封装完毕,手动封装主键uid(使用uuid)

user.setUid(UUID.randomUUID().toString());

// 注册的方法

regist(user);

}


public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}


public void regist(User user) {

QueryRunner runner = new QueryRunner(DataSourceUtils.getDataSource());

String sql = "insert into user values(?,?,?,?,?,?,?,?,?,?)";

try {

runner.update(sql, user.getUid(), user.getUsername(), user.getPassword(), user.getName(), user.getEmail(),

null, user.getBirthday(), user.getSex(), null, null);

} catch (SQLException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

复制代码

View Code


抽取的连接池工具类:

package register;


import java.sql.Connection;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;


import javax.sql.DataSource;


import com.mchange.v2.c3p0.ComboPooledDataSource;


public class DataSourceUtils {


private static DataSource dataSource = new ComboPooledDataSource();


private static ThreadLocaltl = new ThreadLocal();


// 直接可以获取一个连接池

public static DataSource getDataSource() {

return dataSource;

}


// 获取连接对象

public static Connection getConnection() throws SQLException {


Connection con = tl.get();

if (con == null) {

con = dataSource.getConnection();

tl.set(con);

}

return con;

}


// 开启事务

public static void startTransaction() throws SQLException {

Connection con = getConnection();

if (con != null) {

con.setAutoCommit(false);

}

}


// 事务回滚

public static void rollback() throws SQLException {

Connection con = getConnection();

if (con != null) {

con.rollback();

}

}


// 提交并且 关闭资源及从ThreadLocall中释放

public static void commitAndRelease() throws SQLException {

Connection con = getConnection();

if (con != null) {

con.commit(); // 事务提交

con.close();// 关闭资源

tl.remove();// 从线程绑定中移除

}

}


// 关闭资源方法

public static void closeConnection() throws SQLException {

Connection con = getConnection();

if (con != null) {

con.close();

}

}


public static void closeStatement(Statement st) throws SQLException {

if (st != null) {

st.close();

}

}


public static void closeResultSet(ResultSet rs) throws SQLException {

if (rs != null) {

rs.close();

}

}


}

复制代码

View Code


c3p0-config.xml配置文件:

root

xuyiqing

com.mysql.jdbc.Driver

jdbc:mysql:///web



复制代码

View Code


注意导入相关jar包



web.xml配置文件:

WEB5

index.html

index.htm

index.jsp

default.html

default.htm

default.jsp


RegisterServlet

RegisterServlet

register.RegisterServlet


RegisterServlet

/register



复制代码

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注编程语言JAVA频道!

本文由 @职坐标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论
本文作者 联系TA

擅长针对企业软件开发的产品设计及开发的细节与流程设计课程内容。座右铭:大道至简!

  • 370
    文章
  • 23048
    人气
  • 87%
    受欢迎度

已有23人表明态度,87%喜欢该老师!

进入TA的空间
求职秘籍 直通车
  • 索取资料 索取资料 索取资料
  • 答疑解惑 答疑解惑 答疑解惑
  • 技术交流 技术交流 技术交流
  • 职业测评 职业测评 职业测评
  • 面试技巧 面试技巧 面试技巧
  • 高薪秘笈 高薪秘笈 高薪秘笈
TA的其他文章 更多>>
WEB前端必须会的基本知识题目
经验技巧 93% 的用户喜欢
Java语言中四种遍历List的方法总结(推荐)
经验技巧 91% 的用户喜欢
Java语言之SHA-256加密的两种实现方法详解
经验技巧 75% 的用户喜欢
java语言实现把两个有序数组合并到一个数组的实例
经验技巧 75% 的用户喜欢
通过Java语言代码来创建view的方法
经验技巧 80% 的用户喜欢
其他海同师资 更多>>
吕益平
吕益平 联系TA
熟悉企业软件开发的产品设计及开发
孔庆琦
孔庆琦 联系TA
对MVC模式和三层架构有深入的研究
周鸣君
周鸣君 联系TA
擅长Hadoop/Spark大数据技术
范佺菁
范佺菁 联系TA
擅长Java语言,只有合理的安排和管理时间你才能做得更多,行得更远!
金延鑫
金延鑫 联系TA
擅长与学生或家长及时有效沟通
经验技巧30天热搜词 更多>>

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程