当前位置:Gxlcms > 数据库问题 > JSP、servlet、SQL三者之间的数据传递

JSP、servlet、SQL三者之间的数据传递

时间:2021-07-01 10:21:17 帮助过:25人阅读

  •   
  •         <input type="text" name="文本框名字"  /><!--一个文本输入框-->  
  •   
  • </form>  
  •  

    定义一个函数来处理表单文本框检查非空并提交表单事件

    Html代码  技术分享
    1. <script>  
    2. $(document).ready(function(){  
    3.             $("#被单击按钮的ID").click(function(){  
    4.             if(document.all.文本框名字.value.length==0){  
    5.                 alert("输入不能为空");  
    6.                 return false;  
    7.             }  
    8.             document.all.表单名字submit();  
    9.             return true;});  
    10. });  
    11. </script>  

     

    2、收信息来到表单提交时URL所指向的servlet文件,获取传递过来的参数值

    Java代码  技术分享
    1. String search = java.net.URLDecoder.decode(request.getParameter("文本框名字"),"utf-8");  
    2. System.out.println("在search的servlet中接收到的search参数为-->"+search);      

     

    ok,完成

     

    (二)从servlet到数据库

    1、获得数据(MySql为例)

    ①创建数据库连接池

    创建一个配置文件,如图

    技术分享

    确保名字一致,

    Xml代码  技术分享
    1. <?xml version="1.0" encoding="UTF-8"?>  
    2. <Context>  
    3.     <Resource name="jdbc/LeLe"    
    4.         auth="Container"  
    5.         type="javax.sql.DataSource"  
    6.         maxActive="50"  
    7.         maxIdle="5"  
    8.         maxWait="10000"  
    9.         logAbandoned="true"  
    10.         username=""  
    11.         password=""  
    12.         driverClassName="com.mysql.jdbc.Driver"  
    13.         url="jdbc:mysql://localhost:3306/lele" />  
    14. </Context>  
    15. <!-- jdbc/LeLe为项目名 -->  

     

    ②获取链接

    Java代码  技术分享
    1. public static Connection getConnection() {  
    2.   
    3.     Connection con = null;    //创建用于连接数据库的Connection对象  
    4.     DataSource ds = null;  
    5.     try {  
    6.   
    7.         Context initContext = new InitialContext();  
    8.         Context envContext = (Context)initContext.lookup("java:/comp/env");  
    9.         ds = (DataSource)envContext.lookup("jdbc/LeLe");  
    10.         System.out.println(ds.getConnection());  
    11.     } catch (Exception e1) {  
    12.         System.out.println("加载数据库驱动失败"+e1);     
    13.         return null;  
    14.     }// 加载Mysql数据驱动  
    15.     try {  
    16.         con = ds.getConnection();// 创建数据连接  
    17.         System.out.println("数据库连接成功了");     
    18.         return con;    //返回所建立的数据库连接  
    19.              
    20.     } catch (Exception e) {  
    21.         System.out.println("数据库连接失败" + e.getMessage());  
    22.         return null;  
    23.     }  
    24. }  

     

    ③执行SQL语句,并返回结果

    Java代码  技术分享
    1. /* 查询数据库,输出符合要求的记录的情况*/  
    2.     private static Connection conn;  
    3.     private static Statement st;  
    4.     private static ResultSet rs;  
    5. //    public static void main(String [] args){  
    6. //        query("select * from agreement");  
    7. //    }  
    8.     public static ResultSet query(String sql ) {  
    9.         System.out.println("函数DBQuery日志");  
    10.         if(conn == null){  
    11.             conn = DBConnection.getConnection();    //同样先要获取连接,即连接到数据库  
    12.             if(conn == null){  
    13.                 System.out.println("数据库连接失败" );  
    14.                 return null;  
    15.             }  
    16.         }  
    17.         System.out.println("查询函数中连接到数据库数据成功"+conn);  
    18.   
    19.         try {  
    20.             st = (Statement) conn.createStatement();    //创建用于执行静态sql语句的Statement对象,st属局部变量     
    21.             rs = (ResultSet)st.executeQuery(sql);    //执行sql查询语句,返回查询数据的结果集  
    22.             if(!rs.next()){  
    23.                 System.out.println("数据库中未查询到数据");  
    24.                 return null;  
    25.             }         
    26.             System.out.println("数据库中已经查询到数据");  
    27. //            String agreement_id = rs.getString(1);     
    28. //            String agreement_content = rs.getString(2);  
    29. //            System.out.println("已经查询到数据的数据为----agreement_id:"+agreement_id+"\tagreement_content:"+agreement_content);  
    30.             return rs;  
    31.         } catch (SQLException e) {  
    32.             System.out.println("数据库中查数据失败");  
    33.             return null;  
    34.         }  
    35.          
    36.     }  
    37.   
    38.     public static void closeDB() throws SQLException{  
    39.         if(null != rs)  
    40.             rs.close();  
    41.         if(null != st)  
    42.             st.close();  
    43.         if(null != conn)  
    44.             conn.close();    //关闭数据库连接  
    45.     }  

     

    2、处理数据(使用javaBean保存数据)

    Java代码  技术分享
    1. if(rs != null){  
    2.     do{  
    3.         User user0=new User();//一个javaBean的实例化对象  
    4.         user0.setUser_id(rs.getString("user_id"));  
    5.         user0.setUser_name(rs.getString("user_name"));  
    6.         user0.setUser_email(rs.getString("user_email"));  
    7.         user0.setUser_password(rs.getString("user_password"));  
    8.         collection.add(user0);  
    9.         System.out.println(rs.getString("user_id"));  
    10.         System.out.println(rs.getString("user_name"));  
    11.         System.out.println(rs.getString("user_email"));  
    12.         System.out.println(rs.getString("user_password"));  
    13.     }while(rs.next());  
    14. }  

     

    Java代码  技术分享
    1. public class User {  
    2.     private String user_id;//用户编号  
    3.     private String user_email;//用户邮编  
    4.     private String user_name;//用户名  
    5.     private String user_password;//用户密码  
    6.      
    7.     public String getUser_id() {  
    8.         return user_id;  
    9.     }  
    10.     public void setUser_id(String userId) {  
    11.         user_id = userId;  
    12.     }  
    13.     public String getUser_email() {  
    14.         return user_email;  
    15.     }  
    16.     public void setUser_email(String userEmail) {  
    17.         user_email = userEmail;  
    18.     }  
    19.     public String getUser_name() {  
    20.         return user_name;  
    21.     }  
    22.     public void setUser_name(String userName) {  
    23.         user_name = userName;  
    24.     }  
    25.     public String getUser_password() {  
    26.         return user_password;  
    27.     }  
    28.     public void setUser_password(String userPassword) {  
    29.         user_password = userPassword;  
    30.     }  
    31. }  

     

    ok,完成

     

    (三)从servlet到JSP

    1、发数据

    使用重定向将request和response转发给一个JSP

    Java代码  技术分享
    1. //将数据发到JSP  
    2. RequestDispatcher rd = request.getRequestDispatcher("index_search.jsp");  
    3. request.setAttribute("test",collection);//存值  
    4. rd.forward(request,response);//开始跳转  

     

    2、接收数据

    来到重定向指向的URL中获取刚才发送过来的数据,并显示在网页上

    Java代码  技术分享
    1. Collection<User> collectionUser=(Collection<User>)request.getAttribute("test");  
    2. Iterator it=collectionUser.iterator();  
    3. while(it.hasNext())  
    4. {  
    5.     User user=(User)it.next();  
    6.     out.println("<td ><div align=‘center‘>"+user.getUser_name()+"</td>");         
    7.     out.println("<td ><div align=‘center‘><a href=‘#‘ onclick=window.open(‘MyJsp.jsp?usid="+user.getUser_id().trim()+"‘,‘newwindow‘,‘width=600,height=350,top=300,left=300‘)>管理</a></td>");  
    8.     out.println("</tr>");  
    9. }  

     ok,完成

     

    结束语:

               推荐一本JavaScript进阶读物--------《JavaScript修炼之道》

               推荐一本项目开发实录书籍----------《Java项目开发案例全程实录》

    JSP、servlet、SQL三者之间的数据传递

    标签:时代   页面   driver   文本   tle   attr   war   onclick   set   

    人气教程排行