java web 学习笔记 - servlet02

1.servlet的跳转

   客户端跳转: 通过doget函数中的response参数调用resp.sendRedirect(url);

   代码如下

  protected void doGet(HttpServletRequest req,HttpServletResponse resp)
  throws ServletException,IOException{
  req.getSession().setAttribute("sessionid", "123456");
  req.setAttribute("reqid", "123456");
  resp. sendRedirect("redirect.jsp");
  }

   服务器跳转:  通过doget函数中的request参数获取RequestDispatcher()对象,然后再调用forward函数

   代码如下:

   

  protected void doGet(HttpServletRequest req,HttpServletResponse resp)
  throws ServletException,IOException{
    req.getSession().setAttribute("sessionid", "123456");
    req.setAttribute("reqid", "123456");
    req.getRequestDispatcher("redirect.jsp").forward(req,resp); //从HttpServletRequest的父类ServletRequest中找该函数
  }

2.Web开发模式

  Mode I : jsp + javabean 模式,DAO技术实现,一个Connection类, 一个DAO接口,一个impl实现类,一个代理类负责调用connection impl实现类,打开关闭数据库连接。

               还有一个javabean类。 Mode I目前项目中不怎么使用,一般是写一些接单的示例程序用。

 

  Mode II : jsp + servlet +javabean模式,简称MVC模式。

  

 

通过Servlet(C) 获取客户端的请求,调用javabean访问数据库,然后将取得的数据返回到jsp来显示。

 

   MVC设计模式主要采用request的属性范围!!!!

 

3.MVC模式的设计与应用

 需要编写的代码:

M javabean: vo 类,dbc类, IDAO接口  impl实现类 proxy代理类  Factory工厂类

C servlet:  servlet类  ,web.xml中配置i相应的映射

V  jsp : 表单.jsp

 

个人心得:

  • vo类没说的,就是一个简单的javabean,包括成员变量,get,set方法。
  • dbc类是数据库连接类,主要实现一个public connection getConnection();  public void close() 两个函数
    • 关键两句话,Class.forName(DBDRIVER);//初始化数据库引擎
    • Connection conn = DriverManager.getConnection(DBURL,DBUSER,DBPASSWD) 

  •  IDAO接口,其实是一个抽象接口类,要实现什么就直接写接单的抽象函数。
    • public boolean findUser(User user) throws Exception; 
  •    impl类 ,其实就是IDAO接口的一个实现类,它不关心异常处理,connection打开或者关闭,它只做具体sql相关的操作

             关键语句有如下几个

             class impl  implements IDAO{

                private Connection conn =null;

                private PreparedStatement pstmt = null;

                public impl(Connection conn){ //构造函数,不关心Connection的打开,直接获取Connection连接

                 this.conn = conn;

     }

                

                 public boolean findUser(User user) throws Exception{  // 不关心异常处理,直接抛出

                  String sql =".......where userid=? and passwd =?"

                  pstmt = conn.prepareStatement(sql);

                  pstmt.setString(1,name);

                  pstmt.setString(2,passwd);

                  ResultSet rs = pstmt.executeQuery();

                   while(rs.next()){

      .....rs.getString(1);

                   }

                   }

    }

  • proxy类 ,其实就是调用impl类,并处理异常的

         关键语句如下

         class proxy  implements IDAO{

    DatabaseConnection dbc = null;

              IDAO dao= null;

             public proxy(){  //构造函数中要生成dao对象

                 this.dbc = new DatabaseConnection();

                 this.dao = new Impl(dbc.getConnection())

             }

              public boolean findUser(User user) throws Exception{

        try{

                   return  this.dao.findUser(user);

                   }catch(Exception e){  

                       throw e;

     }finally{

                       this.dbc.close();

                 }

    }

          }

  • Factory 类,主要是可以调用proxy类

     关键语句  

     pulbic static IDAO getDAOInstance(){

       return new proxy();

    }

   

  •  Servlet类,主要是实现doGet方法,doPost通过调用doGet实现。

    关键语句:

    doGet(request,response){

      List<String> info = new ArrayList<String>()  ;

      userid = request.getParameter("userid");

        passwd = request.getParameter("passwd");

  User user = new User();

        user.setUserid(userid);

        user.setpasswd(passwd);

        if (Factory.getDAOInstance().findUser(user) == true){

           info.add("登陆成功,欢迎 "+username);

        } 

        request.setAttribute("info",info);

        request.getRequestDispatcher(url).forward(request,response);

    } 

 

    jsp文件,就好说了,很简单了

   1.实现标准的html代码,form,input

    2.在jsp代码中,关键语句如下

   <%

  Request.setCharacterEncoding("GBK");

    %>

   <%

  List<String> info = (List<String>)Request.getAttribute("info");

       Iterator<String> itr = info.iterator();

       while(itr.hasNext()){ 

       ..............

             itr.next();

        ...........

 %>

 

 

    

 

 

手写代码如下:

==========================================================================

vo类:

package cn.liys.login.vo;
public class User{
private String userid;
private String username;
private String userpassword;
public void setUserId(String userid){
this.userid = userid;
}
public void setUsername(String username){
this.username=username;
}
public void setUserpassword(String userpassword){
this.userpassword=userpassword;
}

public String getUserid(){
return this.userid;
}

public String getUsername(){
return this.username;
}

public String getUserpassword(){
return this.userpassword;
}
}

 

dbc类:

package cn.liys.login.dbc;
import java.sql.*;
public class UserDBConnection{
private static final String DBDRIVER ="org.gjt.mm.mysql.Driver";
private static final String DBURL ="jdbc:mysql://localhost:3306/mldn";
private static final String DBUSER = "root";
private static final String DBPASSWORD ="123456";
private Connection conn = null;

public UserDBConnection() throws Exception{
Class.forName(DBDRIVER);
conn = DriverManager.getConnection(DBURL,DBUSER,DBPASSWORD);
}

public Connection getConnection(){
return this.conn;
}

public void close()throws Exception{
if(this.conn != null){
try{
this.conn.close() ;
}catch(Exception e){
throw e ;
}
}
}
}

 

IDAO接口类

package cn.liys.login.dao;
import cn.liys.login.vo.*;

public interface IUserDAO{
public boolean findUser(User user) throws Exception;
}

impl实现类

package cn.liys.login.dao.impl;
import cn.liys.login.vo.*;
import cn.liys.login.dao.*;
import cn.liys.login.dbc.*;
import java.sql.*;

public class UserDAOImpl implements IUserDAO{
private Connection conn = null;
private PreparedStatement pstmt = null;

public UserDAOImpl(Connection conn){
this.conn = conn;
}

public boolean findUser(User user) throws Exception{
boolean flag = false;
String sql = "select name from user where userid =? and password=?";
this.pstmt = this.conn.prepareStatement(sql);
this.pstmt.setString(1,user.getUserid()) ;
this.pstmt.setString(2,user.getUserpassword()) ;
ResultSet rs = pstmt.executeQuery();

if(rs.next()){
user.setUsername(rs.getString(1)) ; // 取出一个用户的真实姓名
flag = true;
}else{
flag = false;
}
this.pstmt.close() ;
return flag;
}

}

 

proxy代理类

package cn.liys.login.dao.proxy;
import cn.liys.login.vo.*;
import cn.liys.login.dao.*;
import cn.liys.login.dao.impl.*;
import cn.liys.login.dbc.*;
import java.sql.*;

public class UserDAOProxy implements IUserDAO{
private UserDBConnection dbc = null;
private UserDAOImpl dao = null;

public UserDAOProxy(){
try{
this.dbc = new UserDBConnection();
}catch (Exception e){
e.printStackTrace();
}
this.dao = new UserDAOImpl(dbc.getConnection());
}

public boolean findUser(User user) throws Exception{
try{
return this.dao.findUser(user);
}catch(Exception e){
throw e;
}finally{
this.dbc.close();
}
}

}

 

Factory工厂类

package cn.liys.login.dao.factory;
import cn.liys.login.vo.*;
import cn.liys.login.dao.*;
import cn.liys.login.dao.proxy.*;

public class UserDAOFactory{
public static IUserDAO getUserDAOInstance(){
return new UserDAOProxy();
}

}

===============================================================

 

Servlet类:

package cn.liys.login.servlet;
import cn.liys.login.vo.*;
import cn.liys.login.dao.factory.*;
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;


public class UserServlet extends HttpServlet{
private User user = new User();
List<String> info = new ArrayList<String>();
private String userid = null;
private String passwd = null;

protected void doGet(HttpServletRequest req,HttpServletResponse resp)
throws ServletException,IOException{
boolean flag = false;
userid = req.getParameter("userid");
passwd = req.getParameter("passwd");
if ((userid == null) ||("".equals(userid))){
info.add("用户id不能为空");
}
if ((passwd == null) || ("".equals(passwd))){
info.add("密码不能为空");
}

if (info.size() == 0){
user.setUserId(userid);
user.setUserpassword(passwd);
System.out.println(userid);
System.out.println(passwd);
try{
flag = UserDAOFactory.getUserDAOInstance().findUser(user);
if (flag == true){
info.add("登陆成功!");
}else{
info.add("登陆失败!");
}
}
catch(Exception e){
e.printStackTrace();
}
}


req.setAttribute("info",info);
req.getRequestDispatcher("login.jsp").forward(req,resp);


}

protected void doPost(HttpServletRequest req,HttpServletResponse resp)
throws ServletException,IOException{

this.doGet(req,resp);
}

}

 

====================================================================

 

JSP:

<%@ page contentType="text/html" pageEncoding="GBK"%>
<%@ page import="java.util.*"%>
<%@ page import="java.io.*"%>
<html>
<head>
<title>
mvc的第一个实现用例,登陆窗口
</title>
</head>

<body>
<%
request.setCharacterEncoding("GBK");
%>

<%
List<String> info = (List<String>) request.getAttribute("info");

if (info!=null){
Iterator<String> itr = info.iterator();
while(itr.hasNext()){

%>

<%=itr.next()%>
<%

}

}
%>



<form action="UserServlet" method="post">

用户ID:<input type ="text" name="userid"> <br>
密&nbsp;&nbsp;码:<input type="text" name="passwd">
<br>
<input type="submit" value="提交">
<input type="reset" value="重置">
</form>

</body>


</html>

 

 

 

 

                         

 

   

 

 

 

 

              

 

 

 

 

   

 

转载于:https://www.cnblogs.com/lysforwin/p/7607244.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值