韩顺平jsp学习笔记

时间:2022-10-17 21:04:41

jsp

u  j2ee核心13种技术:

程序员必须掌握的技术:java,servlet,jsp。

13种技术规范.

u  j2ee程序员修炼成精法门

u  jsp 版本的用户管理系统:将servlet版本改为jsp版本,只使用jsp技术完成(modle1模式开发)

并且在后面可通过jsp版的用户管理系统的改写,非常自然过渡到mv设计模式,更进一步到mvc设计模式

开发工具:myeclipse

u  jsp概述:

jspservlet技术的补充,访问jsp的过程:如果是第一次访问,jsp文件被服务器翻译成一个对应的java文件(servlet),然后,再被编译成.class文件并加载到内存中。如果是以后访问jsp,那就直接调用内存中的jsp实例,所以,第一次访问jsp慢,后面访问jsp的速度就会变快了。(hello.jsp来说明运行原理:tomcat下的work下有将jsp转换为servlet的代码)

 

1.      为什么出现:程序员在开发过程中,发现servlet做界面非常不好,jsp对servlet的补充(对界 面的补充,jsp界面好做)

2.      jsp=html+java片段+jsp标签(语法)+javascript(css):综合

3.      jsp功能的强大是因为可以与javabean结合使用(即:jsp作前台(界面),javabean作后台(逻辑层))。

4.      Jsp是什么:1.jsp运行在服务器,2.jsp(java server page)3。Jsp基础是servlet(相当于对servlet的包装)4.jsp是综合技术:一个公式:jsp=html+java代码+jsp标签+javascript(css) 比较综合 5.jsp无需配置,直接使用,如果你修改了jsp文件,不需要重新reload web应用 6.jsp如何访问:http://ip:8088/web应用名.jsp路径

u  jsp的概述:元素

1.      指令元素

2.      脚本元素

3.      动作元素

u  jsp与servlet的关系:

1.      jsp与servlet是对应关系

2.      jsp是以servlet为基础的

u  编写一个计算器的实例:

1.      表单提交处理的jsp页面为:<form action=”chuli.jsp”>

2.      接受用户传来的数据的函数为request函数,方法为getParameter(“name”),返回类型为String

3.      对于jsp页面报错的行数为tomcat中work里的对应的java代码中的错误行数

4.      jsp可以通过javascript代码,对数据合法性进行验证, 防止用户空提交

5.      可以通过Math.round(num) != num判断一个变量是否是一个数,当经过math.round处理后不相等,则num不是一个数

u  在同一jsp页面提交和接受数据

1.jsp中表达式标签:<%=  %>

u  迅速上手myeclipse工具-----》完成一个小案例:建立一个web工程(站点),创建一个jsp文件myHello.jsp,文件输出hello,配置tomcat,jdk,并发布工程(将站点放在tomcat上),在浏览器中访问myHello.jsp

u  Model1模式

1.      javaee开发有几个重要模式:Model1模式,Model2模式,mvc模式

2.      model1模式基础是jsp文件,由一些相互独立的jsp文件,和其他的一些java class组成(不是必须的),jsp从httprequest中获得所需要数据,处理业务逻辑,然后通过response返回前段浏览器

3.      model1模式可分为model1(纯jsp)和model1(jsp+java class)

4.      model1缺点:表现层和业务逻辑层混合在一起(乱);开发中不利于多人开发协同;不利于后期维护,不好查看。

model模式优点:简单,开发速度快;适合开发小项目。轻巧*。

 

u  简单的用户登录界面:迅速掌握eclipse开发工具,使用纯jsp技术的model1

学习到:如何在jsp页面间跳转,如何操作数据库,如何在jsp中显示数据/分页

1. 通过response.sendRedirect来实现多个页面信息共享,注意在loginCl页面中的response.sendRedirect("wel.jsp?user="+u)与wel页面中的<%=request.getParameter("user") %>一定要相同

2. 加载数据库:

a. 加载sql server:

//1.加载驱动

Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”);

//2.创建连接

Connection ct=DriverMananger.getConnection(“jdbc:Microsoft:sqlserver://127.0.0.1:1433;databaseName=spdb”,”root”,”123”);

b. 加载mysql

    //到数据库中区验证

    //1.加载数据库驱动

    Class.forName("com.mysql.jdbc.Driver");

    //2.得到连接

    Connection ct = DriverManager.getConnection("jdbc:mysql://localhost:3306/spdb","root","123");

    //3.创建statement

    Statement sm = ct.createStatement();

       //4.查询

ResultSet rs=sm.executeQuery("selectpasswd from users where username='"+u+"'");

 

3. 如何在myeclipse中引入jar包:

点击webroot下的web-inf中的lib,右键import,选择file system,选择jar包路径导入,成功后 会在referenced libraries中出现一个jar包的小奶瓶。

u  分页技术

1.      分页算法:

四个变量:int pageSize:每页显示几条记录(程序指定的);int pageNow希望显示第几页(用户指定的)int pageCount:一共多少页(是计算出来的一共多少页) int rowCount:一共多少记录(一共有多少条记录 从表中查询得到的)

if(rowCount%pageSize==0){

           pageCount=rowCount/pageSize;

}else{

           pageCount=rowCount/pageSize+1;

}

2.      为防止因用户删除造成的查询页数缺失,我们不采用:select * from users where userIdbetween 7 and 9, 而是采用:select top pageSize 字段名列表 from 表名 where id not in ( select  top pageSize *(pageNow-1) id from 表名 )

如:select top 3 * from users whereuserId not in ( select top 3 userId from users) 显示第二页

但请注意这是在sql server中可以使用的top查询语句,在mysql中并不可以用

mysql不支持select top n的语法,应该用这个替换:

select * from tablename order by orderfielddesc/asc limit position, counter;

position 指示从哪里开始查询,如果是0则是从头开始,counter 表示查询的个数

取前15条:select * from tablename order by orderfielddesc/asc limit 0,15

mysql中的分页实现:

select *from tableName where 条件 limit (当前页码-1)*页面容量 , 页面容量

如:select * from userswhere userId  limit 3, 3

"select* from users where userId limit " +((pageNow-1)*pageSize)+","+pageSize

3.      请注意,一定要将ResultSet rs.next(),否则rs将指向表头 ,而非第一行数据

4.      请注意,在同一个jsp页面中,java片段中声明的变量可以在下面的片段中使用

5.      当数据表较大时,如何解决分页速度的问题

表数据的自我复制,这个可以去看看你的项目操作表的效率如何

insert into 表名(字段1,2、、、)select字段1,2、、、from表名

如:insert into users(username,passwd,email,grade) select username,passwd,email,grade from users

u  用户登录系统框架改进:通过对model1纯jsp开发模式反思,演变为model1结合javaclass开发模式:

1.      不合理的地方:loginCl与wel页面都用了数据库,有重复代码;整个框架没有清晰的层次关系;代码不优雅,可读性差,可维护差。

2.      改进:

a)        分层:界面层(jsp)与业务逻辑层(java class),即纯jsp转为model1(jsp+java class)

b)        将常用代码封装到类中,使得代码清晰

c)        为什么userbeancl中分页处理返回值为arraylist而不是resultSet

1.如果resultSet,那么使用时,不能关闭与该resultSet相关联的数据库连接等资源而造成资源的浪费

2.如果返回resultSet,我们只能用rs.getint(),rs.getString()来得到结果,代码可读性不好,不方便维护

3.先将rs中每条记录封装成一个userbean对象ub;再将userbean对象ub放入arraylist集合中便于管理

u  用户登录系统再改进 mvc

1.      login.jsp输入数据,logincl.jsp通过调用java class处理数据,wel.jsp显示数据,虽然看起来不错,但有缺点如下:

jsp技术主要用来做界面的,但logincl.jsp用来调用javaclass,完成用户验证,不好;

wel.jsp用于显示用户信息,但还调用了java class,不利于分工开发;servlet技术处理页面跳转方便,不该放弃使用

2.      mvc模型:mmodel模型),v(view视图)ccontrol控制器),mvc强制性地使用应用程序的输入,处理和输出分开,使用mvc ,应用程序被分成三个核心部件:模型(java class来做,或java bean,ejb)视图(jsp来做)控制器(servlet来做),各自处理自己的任务,利于分工开发。

3.       mvc下的用户管理开发:

a)        增加控制器(servlet)即将logincl.jsp用servlet代替,发挥servlet充当控制中转的优势

b)        在控制器servlet中调用model去完成用户验证,并准备要显示的用户信息数据

4.      注意:页面跳转有两种方式:

转向:response.sendRedirect(“wel.jsp” ) 效率较慢 公司常常不用

转发:request.getRequestDispatcher(“wel.jsp”).forward(request,response);效率高,同时request中的对象还可以在下 一页面使用,公司常用这种方法

5.      mvc提倡界面和业务完全分离,对wel页面进行改进。添加另一个控制器userclservlet.java验证用户,分页,删除用户

6.      mvc开发模式的总结—》mvc处理过程:首先控制器接受用户的请求,并决定应该调用哪个模型来进行处理,然后调用模型来处理用户的请求,并返回数据,最后控制器用相应的视图显示模型返回的数据,并通过浏览器呈现给用户。

7.      mvc的缺点:

a)        工作量增加了。由于开发者将一个应用程序分成了三个部分,所以使用mvc的同时也意味着你将要管理更多的文件,这点显而易见,这好像我们的工作量增加了,但是比起带来的好处不值得一提

b)        不适用与小项目,否则就是机关枪打蚊子

c)        调试应用程序的难度加大mvc提倡模型与视图分离,这样也给调试应用程序带来了一定困难,每个构建在使用之前都需要经过彻底的测试,一旦构建经过了测试,就可以毫无顾忌的重用它们了。

u  session技术讲解(针对浏览器实例而言)

1.      什么是session:当用户打开浏览器,访问某个网站时,服务器就会在服务器的内存为浏览器实例分配一个空间,该空间会被这个浏览器独占,这个空间就是session,该空间中的数据默认存在时间30min

2.      session可以做:网上商城购物车;保存用户信息;同一用户不用页面信息共享;防止用户非法登录到某个页面、、、吧

3.      如何理解session:可将session看做一张表,表有两列,每一行是session的一个属性,每个属性有两部分,一个是属性的名字(string),一个是属性的值(object)

4.      如何使用session:

a)        得到session:servlet中 HttpSession hs=request.getSession(true);

jsp中 session是一个内置对象(9大内置对象之一)可以直接使用

b)        向session中添加属性

servlet: hs.setAttribute(String name,Object val);

jsp : session.setAttribulte(Stringname,Object val);

c)        从session中得到属性

servlet:hs.getAttribute(String name);

jsp:session.getAttribute(String name);

d)        从session中删除属性

servlet:hs.removeAttribute(String name);

jsp:session.removeAttribute(String name);

5.      从session中得到某个属性的值时,返回值为object类型,必须强转后才能使用:

String s_name =(String)session.getAttribute(String name);

6.      session中的注意事项:

a)        session中属性存在的默认时间为30min,可以修改:第一,可以在web.xml中修改,第二可以在程序中修改 setMatInactiveInterval();

b)        上面说的时间是指用户发呆的时间,不是累计时间

c)        当某个浏览器访问网站时,服务器会给浏览器分配唯一的一个session id,并以此区分不同的浏览器(客户端)在

d)        因为session的各个属性要占用服务器的内存,因此软件公司都是在迫不得已的情况下才使用

7.      jsp内置对象:out 、 resquest、response、session

u  数据库中的用户名是中文名字

数据库中用户名为中文名字时会产生乱码,因为iso-8859-1,解决方法为:1).重新转码,2).使用过滤器来解决,3).通过配置server.xml文件(不太稳定):

<Connector port="8080" maxThread="150"minSpareThreads="25" maxSpareThreads="75"enableLookups="false" redirectPort="8443"acceptCount="100" debug = "0" connectionTimeout="20000"disableUploadTimeout="true" URIEncoding="GB2312" />

u  美化管理系统界面,完善页面(参考.doc文档进行)

1.      eclipse中提示符:alt+/

2.      主界面 main界面:

3.      增加修改用户,删除用户的功能

更好的一种:

如何判断是哪种操作

4.      mysql操作时,查找使用executeQuery,删除使用executeUpdate。

 

u  管理系统功能改进(增加对用户的查找,增加,删除和修改功能,这样我们这个用户登录系统就形成了一个用户管理系统,并且使用mvc模式开发)

u  时尚购物网

1.      需求分析——》用例图(uml,rose)——》模块功能 ——》实现
【模仿写网站à创新不是容易的

无—》 有

2.      界面设计

a)        div+css

b)        table+css

c)        混合(两种)

3.      数据库设计:

a)        现初步设计,然后完善

b)        一点点加入,容易接受

c)        表的设计【界面à猜出表】做出用户表和商品表,其他表后面设计

4.      建立web工程,testShopping

5.      开始首页面(index.jsp)【界面不再手写,dw来写】

a)        写界面时要:死去活来,先将显示写死,写成静态页面

b)        在dw页面中,我们建html——》在myeclipse中建立jsp

c)        在开发界面时,我们使用table+css

d)        在table+css中常用的一个技巧,在行的某列中嵌入一个表格,可以得到精确的布局

e)        css是什么:

                                      i.             是层叠样式表:控制网页的字体、大小、边框、宽度、高度

f)         怎么把界面引入index中呢?

g)        flash动画技术:先会用再会做,(flash,javascript,ps)

用的过程很简单:1.先将资源拷贝过去,2.在要显示广告的位置加入一句话:<script language=”javascript”src =”banner.jsp”></script>

6.      把静态页面向动态的页面修改,继续开发完善功能:

a)        显示货物的具体信息(jsp中如何使用js技术)

                                      i.             在主页面,用户只要点击了书名超链接,就跳转到显示该书信息的页面

                                    ii.             完成返回大厅按钮功能:javascript代码实现

                                   iii.             为了做成动态就需要mvc,model和servlet开发

b)        将主界面做活:index首页面增加分页功能

                                      i.             ctrl+shift+m(可以自动引入包)

                                    ii.             把每个显示商品的信息table循环起来(算法,在jsp页面中java片段和html页面的标签嵌套混用)

c)        用户登录注册页面设计

d)        购物流程设计mvc(界面、控制器、模型)

                                      i.             hashmap:hashmap就像一张表;key值不能重复;key值和value值,可以是java的object类型

Key值

Value值

 

 

此处用处:hashmap充当购物车很好,key值——》书的id;value——》书的数量

hashmap提供了一堆很好的函数

 

                                    ii.             假设,用户购物车中有1,4,:select * from goods where goodsId in(1,4)

                                   iii.             对购物车可以增加,删除,清空,修改数量

为了让servlet得到一个货物的id和数量,我们使用隐藏表单完成【这里需要好好消化,有一定难度】

7.      项目比较综合 涉及到的技术较多:根据看到的网站运行情况,我猜出来的框架图

练习才是最重要的

a)        用户登录

                                      i.             注意:如果一个servlet()只处理一种业务逻辑,就没有必要加type去确认

b)        显示用户的联系方式,订单情况

c)        订单表的设计、订单的完成

d)        发送电子邮件到用户的信箱

e)        购物流程的设计(mvc【界面、控制器、模型】)

8.      完成生产订单的功能

a)        设计订单表【怎么设计】

但是这种方式有数据冗余

解决方法是:把重复的字段单拿出来做一张表【订单表】,把不重复的单拿出来做一张表【订单信息表】

即:

这里其实涉及到数据库的设计模式问题,表和表(users与goods之间可能互有多个)之间有多对多关系时,就应当使用中间表来解决数据冗余问题

 

通过订单细节表,把订单表和货物表的多对多关系,简化成一对多关系:从而达到解决数据冗余的问题。

b)        我们可以使用批量操作数据库方法,来提高数据库的效率:

9.