开发基于JSPServletJavaBean的网上交易系统_第1页
开发基于JSPServletJavaBean的网上交易系统_第2页
开发基于JSPServletJavaBean的网上交易系统_第3页
开发基于JSPServletJavaBean的网上交易系统_第4页
开发基于JSPServletJavaBean的网上交易系统_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、开发基于jsp servlet javabean的网上交易系统第一章 javaee的概述1 了解性知识(jsp的弊端,什么是javaee,什么是框架,javaee的结构体系) 表示层技术(html javascript ajax) 中间层技术(jsp servlet jstl javabean strusts) 数据库技术(jdbc技术 数据层框架技术hibernate) 系统集成技术(jax-ws技术 jndi)2 http协议 http是一个无状态协议,默认输出端口为803 post与get提交数据方法的差别(get方法是浏览器默认的提交方法) (1)post请求数组在地址栏不可见,相对比

2、较安全 (2)post请求提交的数据在理论上没有长度的限制 (3)get请求将字符串添加到url中,是页面可以被设置成书签或使用电子邮件发送,post请求则不能4 为eclipse添加数据监控工具tcp/ip monitor进行数据监控(1)单击“窗口”-“首选项”命令,弹出“首选项”窗口(2)展开左侧的“运行/调试”节点,选择tcp/ip monitor选项,并选中show the.复选框(3)添加监视窗口,单击add按钮后,弹出对话框,按图添加内容(4)启动监控,运行程序,把地址内的端口号8080改为8088查看监控结果第二章 servlet基础1 servlet是一个java程序,是在服

3、务器端运行以处理客户端请求并作出响应的程序。创建servlet类必须继承httpservlet类,实现doget()或者dopost()方法2 单击右建选择新建servlet命令,在弹出的窗口中输入servlet名称,选择超类为javax.servlet.http.httpservlet,并选中create doget和dopost两个复选框,单击完成按钮3 servlet的生命周期(1)实例化 servlet容器创建servlet的实例(2)初始化 该容器调用init()方法(3)服务 如果请求servlet,则容器调用service()方法(4)销毁 销毁实例之前调用destory()方法

4、4 servlet的部署与配置:web文件 addservletservlet.addservlet addservlet /addservlet 5 servlet处理get/post请求(1)httpservletrequest request对象常用方法 request.getparameter(“param”)获取客户请求的数据 request.setcharacterencoding(“gbk”);将输入内容转化成中文 request.setattribute(“loginname”,user);在request作用域存储数据(2)httpservletresponse respon

5、se对象常用方法 response.setcontenttype(“text/html;charset=gbk”);设置输出中文,解决中文乱码问题 response.sendredirect(“url”);让浏览器重定向到指定的资源(3)转发 requestdispatcher dispatcher=request.getrequestdispatcher(url);首选定义转发器dispatcher.forward(request, response); 然后实现转发的功能第三章 基于servlet的会话跟踪(一) 1 会话的创建 httpsession session = request.

6、getsession(boolean value);httpsession session = request.getsession();在第一种方法中,布尔值为true时,如果存在与当前请求关联的会话,就返回该会话。否则创建一个新会话,并把会话返回。布尔值为false时,如果存在与当前请求关联的会话,就返回该会话。否则返回null,不创建会话。 2 会话的使用 session.setattribute(string name,object value); session.getattribute(string name); 值得注意的是:session.getattribute(string

7、 name);方法返回的是object对象,所以在取出数据是需要进行数据类型转化,是与存入的一致。 3 httpsession对象的结束 (1)关闭浏览器,关闭session (2)调用httpsession的invalidate()方法,删除httpsession对象和数据。 (3)两次访问的时间间隔大于session定义的非活动时间间隔第四章 基于servlet的会话跟踪(二)1 购物车的设计分析httpsession session = request.getsession(false);requestdispatcher dispatcher;/ 如果session不存在,转向 /ch

8、04/books.jspif (session = null) dispatcher = request.getrequestdispatcher(/cho4/books.jsp);dispatcher.forward(request, response);/ 取出购物车和添加的书籍map cart = (map)session.getattribute(cart);bookbean book = (bookbean) session.getattribute(booktoadd);/ 如果购物车不存在,创建购物车if (cart = null) cart = new hashmap();/

9、将购物车存入session之中session.setattribute(cart, cart);/ 判断书籍是否在购物车中cartitembean cartitem = (cartitembean) cart.get(book.getisbn();/ 如果书籍在购物车中,更新其数量./ 否则,创建一个条目到map中.if (cartitem != null)cartitem.setquantity(cartitem.getquantity() + 1);elsecart.put(book.getisbn(), new cartitembean(book, 1);/ 转向viewcart.jsp

10、显示购物车response.sendredirect(/y2javaee/cho4/viewcart.jsp); 实现购物车列表 % map cart = (map) session.getattribute(cart);double total = 0;if (cart = null | cart.size() = 0)out.println(购物车当前为空。);out.println(继续购物 ); else / 创建用于显示内容的变量set cartitems = cart.keyset();object isbn = cartitems.toarray();bookbean book;

11、cartitembean cartitem;int quantity;double price, subtotal;% / continue scriptlet int i = 0;while (i 我们通过map接口的keyset()方法,可以把map中的key建以set形式返回,在通过toarray()方法,将set对象转换为object类型数组,之后我们遍历数组,以数组元素为key值,取出map中所存储的数据 2 格式化问题 在处理数字格式方面,java api为我们提供了decimalformat类,为我们解决十进制数字的格式化问题。 3 常用集合类,接口 (1)list接口(list

12、接口与set接口都继承自collection接口) arraylist是以array方式实现的list,允许快速随机存取,相对与linkedlist不适合进行插入和移除元素操作 linkedlist提供最佳顺序存取,适合插入和移除元素(2)set接口(set是一种不包含重复元素的collection,也就是说在set中最多只能有一个null元素) hashset能够快速定位一个元素,但是它要存入hashset的对象必须实现hashcode()方法 treeset将放入其中的元素按顺序存取(3)map接口(map是一种把键对象与值对象进行关联的容器,像set一样,一个map容器中的键对象不允许重

13、复,这是保证查找结果的一致性) hashmap类是map类的实现类,实现一个键到值映射的哈希表,通过键取得值对象。 properties类一般是把属性文件读入流中后,以键-值的形式进行保存,以方便程序员读取其中的数据第五章 基于servlet的mvc设计模式 mvc是一种流行的软件设计模式 (1)模型(modle):对应的组件是javabean(java类)(2)视图(view):对应的组件是jsp或html文件(3)控制器(controller):对应的组件是servletmvc设计模式的好处1各司其职,互不干涉2有利于开发中的分工3有利于组建的重用第六章 model层开发:高级jdbc 1

14、 数据库连池 (1)数据连接池 在jdbc 2.0 中提供了javax.sql.datesoure(数据源)接口,它负责建立与数据库的连接,在应用程序中访问数据据库不必编写连接数据库的代码,可直接从数据源获得数据库连接。 数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不再重新建立一个;释放空闲时间超过最大空闲时间的数据库连接,以避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术明显的提高了对数据库的操作性能。 数据库连接池在初始时将创建一定的数据库连接放到连接池中,这些数据库连接的数量是有最小数据库连接数来确定的。无论这些数据库连接是否被使用

15、,连接都一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个链接池能占用的最大连接数量,当应用程序向连接池请求的连接数量超过最大连接数量时,这些请求将被加入到等待列中。 (2)数据源与jndi资源 datasoure对象是由web容器(tomcat)提供的,因此不能在程序中采用创建一个实例的方法来生成datasource对象,而需要采用java的另一个技术jndi,来获得datasource对象 可以简单的把jndi理解为一种将对象和名字绑定的技术,容器产生出对象,这些对象都和唯一的名字绑定。外部程序可以通过名字来访问该对象。 javax.naming,context提供了查

16、找jndi resource的接口,例如,可以通过以下的代码获得jdbc/books的数据源的引用:context ic = new initialcontext();datasource source = (datasource)ic.lookup(java:comp/env/jdbc/books);conn=source.getconnection(); /获取数据库连接当程序结束数据库访问后,应该调用connection的close()方法,及时将connection返回给数据库连接,是connection恢复空闲状态。context接口的lookup()方法方法说明lookup(str

17、ing name)返回与指定的名字绑定的对象tomcat把datasource作为一种可配置的jndi资源来处理。生成datasource对象的工厂为mons.dbcp.basicdatasourcefactory.配置多个datasource,可以通过lookup(string name)自动查找连接。 (3)jndi的配置 context.xml文件的配置 在tomcat根目录confcontext.xml文件中节点中添加信息,内容添加如下:的属性属性说明name指定resource的jndi名字auth指定管理resource的manager,他有两个值可选:container和appl

18、ication.container表示有容器来创建resource,application表示有web来创建和管理resourcetype指定resource所属的java类名maxactive指定数据库连接池中的数据库连接处于活动状态的最大数目,取值为0表示不受限制maxidle指定数据库连接池中的数据库连接处于空闲状态的最大数目,取值为0表示不受限制maxwait指定数据库连接池中的数据库连接处于空闲状态的最长时间(以毫秒为单位),超出这一时间会抛出异常。取值为-1可以无限制等待username制定连接数据库的用户名password指定连接数据库的口令driverclassname指定连接

19、数据库的jdbc驱动程序url指定连接数据库的urlweb.xml文件的配置 e-books datasource jdbc/books javax.sql.datasource container的属性属性说明description对所引用资源的说明res-ref-name指定所引用资源的jndi名字,与元素中的name属性对应res-type指定所引用资源的类名字,与元素中的type属性对应res-auth指定管理所引用资源的manager,与元素中的auth属性对应3 基于数据库文件的数据库配置(1)数据配置信息private static final string driver_cla

20、ss=com.microsoft.sqlserver.jdbc.sqlserverdriver;private static final string database_url=jdbc:sqlserver:/localhost:1433;databasename=news;private static final string driver_user=hafei;private static final string driver_password=513810;(2)属性文件driver=com.microsoft.sqlserver.jdbc.sqlserverdriverurl=jdb

21、c:sqlserver:/localhost:1433;databasename=ownhomeuser=hafeipassword=513810在java中提供了properties类,来读取.properties(属性)文件。在程序调用properties类的load()方法时,系统把perties文件的内容加载到内存中。因为properties继承类hashtable, properties类把“=”之前的内容添加到hashtable对象的key值,并同时添加key值对应的value.所以在编写.properties文件时一定要使用=号把名称与值分隔开(3)读取属性文件imp

22、ort java.io.inputstream;import java.util.properties;public class proreader extends properties/定义静态对象private static proreader instance;/* * 公有的获取实例的方法 * return env 实例 */public static proreader getinstance() if (instance != null) return instance; else makeinstance();return instance;/* * 同步的创建实例方法 * */

23、private static synchronized void makeinstance() if (instance = null) instance = new proreader();/* * 私有的构造方法,确保实例的唯一性 * */private proreader() inputstream is = (inputstream) getclass().getresourceasstream(/common/dbiperties);try load(is); catch (exception e) system.err.println(错误:没有读取属性文件,请确认d

24、perty文件是否存在。);return;读取配置信息string driverclassname = proreader.getinstance().getproperty(driver);string url = proreader.getinstance().getproperty(url);string user = proreader.getinstance().getproperty(user);string password = proreader.getinstance().getproperty(password);在读取配置信息时,使用单列模型创建,获得对象实例,

25、并调用properties类提供的方法getproperty(“key”)方法获得hashtable的value值,进行创建数据库连接类的操作。4 class与object小结(1)class类 class.forname(string classname):该方法生成以一个string类型参数指定的classname的class对象,如class.forname(“sun.jdbc.odbc.jdbcodbcdriver”); inputstrean getresourceasstream(string name):该方法是打开并读取一个string类型参数指定的文件到系统内存中,以方便获得

26、系统信息,如inputstream is = (inputstream) getclass().getresourceasstream(/common/dbiperties);properties p = new properties();p.load(in);(2)object类 object类是所有类的根类,我们自定义的类都默认的继承于这个类,所以所有的类包括数组都具有这个类的方法。 getclass():返回一个对象的运行时类 tostring():返回该对象的字符串表示,在object类中是返回对象的地址信息 equals(object obj):判断obj与当前对象是否

27、相等。5 自定义异常(1)定义异常类public class dbaccessexception extends exception private static final long serialversionuid = 1l;protected throwable throwable;/* * 构造方法 * * param message */public dbaccessexception(string message) super(message);/* * 构造方法 * * param message * param throwable */public dbaccessexcept

28、ion(string message, throwable throwable) super(message);this.throwable = throwable;/* * 返回底层异常原因 * * return throwable */public throwable getcause() return throwable;用户自定义异常类要继承exception类,虽然exception类中没有定义自己的任何方法,但从throwable类继承了所有的方法。创建的用户自定义异常类都将具有throwable类的所有方法。(2)使用自定义异常类/数据库连接public static synch

29、ronized connection getconn() throws dbaccessexception / 读出配置信息string driverclassname = env.getinstance().getproperty(driver);string url = env.getinstance().getproperty(url);string user = env.getinstance().getproperty(user);string password = env.getinstance().getproperty(password);connection conn=nul

30、l;try class.forname(driverclassname); conn = drivermanager.getconnection(url,user,password);catch(exception ex)throw new dbaccessexception(不能获得数据库连接!);return conn;6通用的dao类(1)通用的dao类的实现package dao.impl;import java.sql.connection;import java.sql.drivermanager;import java.sql.preparedstatement;import j

31、ava.sql.resultset;import java.sql.sqlexception;import java.sql.statement;import java.util.list;import javax.servlet.jsp.jstl.sql.result;import javax.servlet.jsp.jstl.sql.resultsupport;public class dbconnection private static final string driver_class=com.microsoft.sqlserver.jdbc.sqlserverdriver;priv

32、ate static final string database_url=jdbc:sqlserver:/localhost:1433;databasename=e_pai;private static final string driver_user=hafei;private static final string driver_password=513810;private connection conn;private string sqlvalue;private list values; /设定数据库连接public void setconn() throws classnotfo

33、undexception, sqlexception class.forname(driver_class); conn = drivermanager.getconnection(database_url,driver_user,driver_password);/设定sql语句public void setsqlvalue(string sqlvalue) this.sqlvalue = sqlvalue;/设定语句参数public void setvalues(list values) this.values = values;/数据库连接public static connection

34、 getconn() throws classnotfoundexception,sqlexception class.forname(driver_class);connection conn = drivermanager.getconnection(database_url,driver_user,driver_password);return conn;/释放资源 一个方法关闭三个public static void closeall(connection conn,preparedstatement pstatement,resultset res)tryif(res !=null)

35、res.close();res=null;catch(sqlexception ex)ex.printstacktrace();tryif(pstatement !=null)pstatement.close();pstatement=null;catch(sqlexception ex)ex.printstacktrace();tryif(conn!=null &(!conn.isclosed()conn.close();catch(sqlexception ex)ex.printstacktrace();/设定语句的参数private void setvalues(preparedstat

36、ement pstmt,list values)throws sqlexception/循环将sql语句参数列表中 的值一次付给执行语句for(int i=0;i0)/使用预处理语句,并设定所有的sql语句的所有参数值pstmt=conn.preparestatement(sqlvalue);setvalues(pstmt,values);/执行查询返回查询结果集rs =pstmt.executequery();elsestmt=conn.createstatement();rs=stmt.executequery(sqlvalue);/将resultset转化为resultresult=re

37、sultsupport.toresult(rs);finallythis.closeall(conn, pstmt, rs);return result;/执行sql语句实现增删改但 不能执行查询public int executeupdate() throws sqlexception int noofrows=0;preparedstatement pstmt=null;statement stmt =null;/*处理sql执行sql*/tryif(values!=null & values.size()0)/使用预处理语句,并设定所有的sql语句的所有参数值pstmt=conn.pre

38、parestatement(sqlvalue);setvalues(pstmt,values);/执行更新语句,返回受影响的行数noofrows =pstmt.executeupdate();elsestmt=conn.createstatement();noofrows=stmt.executeupdate(sqlvalue);finallythis.closeall(conn, pstmt, null);return noofrows;(2)通用dao类的使用public list search(users condition) list list =new arraylist();str

39、ing sql= select * from users where 1=1;if(condition!=null)if(condition.getuserid()!=0)sql+=and userid=+condition.getuserid();if(condition.getusername()!=null & !condition.getusername().trim().equals()sql+=and username like %+condition.getusername()+%;try dbconnection dbconnection = new dbconnection(

40、);dbconnection.setconn();dbconnection.setsqlvalue(sql);result result = dbconnection.executequery();if (result = null | result.getrowcount() = 0) / 没有查出booksystem.out.println(没有用户!); else int rowcount = result.getrowcount();/ 读取行数据for (int i = 0; i rowcount; i+) map row = result.getrows()i;users item

41、 = new users();item.setuserid(integer) row.get(userid);item.setusername(string) row.get(username);item.setpassword(string) row.get(password);item.setusercode(string) row.get(usercode);item.setusertel(string) row.get(usertel);item.setuseraddr(string) row.get(useraddr);item.setuserzip(string) row.get(

42、userzip);item.setuserstatus(integer) row.get(userstatus);list.add(item); catch (classnotfoundexception e) / todo auto-generated catch blocke.printstacktrace(); catch (sqlexception e) / todo auto-generated catch blocke.printstacktrace();return list;第七章 view层开发:javabean在jsp中的使用 1 什么是javabean javabean实

43、际上就是一个java类,这个类可以重用。从javabean的功能上可以分为两类 (1)封装数据(2)封装业务javabean一般情况下满足一下要求是一个公有类,并提供无参的公有的构造方法属性私有具有公有的访问属性的getter和setter方法2 jsp与javabean jsp标准动作在浏览器请求jsp页面时执行,jsp标准动作可使用现有的javabean组件和属性,以及用户请求转发到另一个页面 jsp标准动作使用作为前缀,jsp标准动作中的属性区分大小写,属性中的值必须至于双引号内。jsp标准的语法如下:其中,action_name是要执行的动作;attribute将被指定动作的属性所替换(1)(2)setproperty动作用于设置usebean中指定的javabean的属性值。setproperty动作指定名,称属性,值和参数,用于赋给javabean的属性。name指定userbean中使用的javabean的id;property指定要获取javabean的属性名称,value指定要为属性设置值;para

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论