*************************** BookShop 电子书店 * ****************************** 以我现在的水平也只能分出这几个功能。如果以后我学的更多了,我会及时的给大家补充的。 那个写的可能还不够详细,嘿嘿,不懂的记得问我哦。 1 . 功能分析 > 网站首页index.jsp,index.jsp 向顾客展示出所有书籍的封面图片及图书名字。然后顾客通过点击图片连接到图书具体的信息页面bookshop.jsp,或者通过点击图书名字链接到 Bookshop.jsp 页面。然后将所要购买的书放入购物车,然后跳到显示购买的所有图书的bookList.jsp 页面。 2. 代码结构: 1> 数据库连接类(要实现从数据库里读取数据必须要有数据库连接类): DBConnection.java 2>数据操作类(它用来实现对数据库中所有数据的操作,例如增、删、改、查): CURD.java 3>控制处理类(它主要用来处理业务,利用数据操作类处理来自 jsp 页面的数据,然后完成页面之间的跳转),就是所谓的servlet DoAllServlet.java 4>实体类(与数据库中的表一一对应,实体类的每一个属性就是表中的每一列) BookInfo.java 3. 代码编写 数据库操作类:DBConnection.java public class DBConnection { private Connection con=null; private static final String driver="com.mysql.jdbc.Driver"; private static final String url="jdbc:mysql://localhost:3306/bookshop?useUnicode=true&characterEncoding=gbk"; //一行放不开,就占了两行 // ?useUnicode=true&characterEncoding=gbk,这句话是处理数据库乱码问题 private static final String user="root"; private static final String password="123456"; // 这句话下面的是构造方法,我把数据库连接语句放在里面初始化了,其实也可以放在 //具体的得到连接的方法中。 //所谓构造方法,就是与类名字相同,且没有返回类型的方法(例如void 是无任何返回类型 //,String 返回的是字符串类型的,等等,如int,boolean。记住只要是有返回类型必须return // 最后的结果) public DBConnection(){ try { Class.forName(driver); con=DriverManager.getConnection(url,user,password); } catch (ClassNotFoundException e) { System.out.println("数据库加载失败"); e.printStackTrace(); }catch(SQLException e){ System.out.println("连接数据库失败"); e.printStackTrace(); } } ...