Servlet实例专题

添加注册数据到数据库

2018-08-21  本文已影响0人  神坛下的我

UseServlet.java

@WebServlet("/user.do")
public class UseServlet extends HttpServlet{
    
    /*
     * 在Servlet中使用JDBC访问数据库,可以将数据库连接的代码单独写成一个类,
     * 这样其他的功能模块也可以实现代码的复用。
     * 建立数据库连接:
     * */
    private static Connection conn=null;
    public static Connection getConn(){
        try {
            Class.forName("com.mysql.jdbc.Driver");
            String user = "root";
            String pwd = "123456";
            String url = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8";
            conn=DriverManager.getConnection(url,user,pwd);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return conn;
    }
    
    /*
     * 该方法同样可以单独设置成类。
     * 保存用户注册信息到数据库和一个获得本类实例:
     * */
    private static UseServlet instance=null;
    public static UseServlet getInstance(){
        if(instance==null)
            instance = new UseServlet();
        return instance;
    }
    //保存用户注册信息
    public boolean saveUser(InfoBean user){
        Connection conn=null;
        try {
            conn=UseServlet.getConn();//建立数据库连接
            String sql="insert into test(name,pwd,sex,age,email) values(?,?,?,?,?)";
            PreparedStatement pstmt=conn.prepareStatement(sql);
            pstmt.setString(1, user.getName());         //为SQL语句第一个参数赋值
            pstmt.setString(2, user.getPwd());
            pstmt.setString(3, user.getSex());
            pstmt.setInt(4, user.getAge());
            pstmt.setString(5, user.getEmail());
            pstmt.executeUpdate();      //执行INSERT语句
            return true;
        } catch (Exception e) {
            e.printStackTrace();
        }finally{
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        return false;
    }
    
    
    private static final long serialVersionUID = 1L;
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        //设置字符集格式为utf-8
        resp.setContentType("text/html;charset=utf-8");
        req.setCharacterEncoding("UTF-8");
    
        String name = new String(req.getParameter("name").getBytes("utf-8"),"utf-8");
        String pwd=new String(req.getParameter("pwd").getBytes("utf-8"),"utf-8");
        String sex=new String(req.getParameter("sex").getBytes("utf-8"),"utf-8");
        String age=new String(req.getParameter("age").getBytes("utf-8"),"utf-8");
        int userAge =0;
        if(age!=null&&!age.equals(""))
            userAge = Integer.parseInt(age);
        String email=new String(req.getParameter("email").getBytes("utf-8"),"utf-8");
        
        /*将获得表单值封装到用户信息对象中*/
        InfoBean user=new InfoBean();
        user.setName(name);
        user.setPwd(pwd);
        user.setSex(sex);
        user.setAge(userAge);
        user.setEmail(email);
        boolean res=UseServlet.getInstance().saveUser(user);//将用户注册信息保存到数据库
        if (res) {
            req.getRequestDispatcher("success.jsp").forward(req, resp);
        }
    }
    
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws ServletException, IOException {
        doPost(req, resp);
    }
}

InfoBean.java

public class InfoBean {
    private int id;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    private String name;
    private String pwd;
    private String sex;
    private  int age;
    private String email;
    public InfoBean(){}
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPwd() {
        return pwd;
    }
    public void setPwd(String pwd) {
        this.pwd = pwd;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    
}

index.jsp

<form action="user.do" method="post">
        <table align="center">
            <tr>
                <td>用户名:</td>
                <td><input type="text" name="name"/></td>
            </tr>
            <tr>
                <td>密码:</td>
                <td><input type="password" name="pwd"/></td>
            </tr>
            <tr>
                <td>性别:</td>
                <td>
                    <input type="radio" name="sex" value="男"/>男
                    <input type="radio" name="sex" value="女"/>女
                </td>
            </tr>
            <tr>
                <td>年龄:</td>
                <td><input type="text" name="age"/></td>
            </tr>
            <tr>
                <td>Email:</td>
                <td><input type="text" name="email"/></td>
            </tr>
            <tr>
                <td colspan="2" align="center">
                <input type="submit" value="注册"/>
                <input type="reset" value="重置"/>
                </td>
            </tr>
        </table>
    </form>

success.jsp

<b>注册成功!</b><br>
    您的注册信息为:<br/>
    <table align="center">
            <tr>
                <td>用户名:</td>
                <td><%=request.getParameter("name") %></td>
            </tr>
            <tr>
                <td>密码:</td>
                <td><%=request.getParameter("pwd") %></td>
            </tr>
            <tr>
                <td>性别:</td>
                <td><%=request.getParameter("sex") %></td>
            </tr>
            <tr>
                <td>年龄:</td>
                <td><%=request.getParameter("age") %></td>
            </tr>
            <tr>
                <td>Email:</td>
                <td><%=request.getParameter("email") %></td>
            </tr>
            <tr>
            <td><a href="index.jsp">【回到主页】</a></td></tr>
    </table>
捕获.PNG
上一篇下一篇

猜你喜欢

热点阅读