小菜鸟之servlet


  1 # Servlet课程-1和2和3
  2 
容
  4 
  5 Web项目
  6     项目代码部署在服务器上,
  7     一般分为c\s(客户端\服务器端)和b\s(浏览器/服务器)
  8  服务器
  9     常用的服务器(tomcat服务器)
 10     tomcat的目录结构
 11         bin tomcat脚本
 12         conf 配置文件
 13         lib  一些依赖的包
 14         logs  日志文件
 15         webapps  部署的项目
 16         work    部署的项目java转成.class 文件
 17     项目部署到服务器上
 18         maven项目finance1103部署到服务器tomcat
 19 Maven项目的创建好处
 20     maven项目帮助程序员对jar包进行统一管理管理,
 21     方便团队统一jar包的版本
 22     库的网站
 23         https://mvnrepository.com/
 24 
 25 MVC思想(构建项目)
 26     view视图层: 负责model层处理结果的响应,输出给用户
 27                         将处理结果返回给网民,让其知道
 28                         jsp的形式呈现给用户
 29     control控制器层 :负责请求的派发和处理,针对请求进行处理。
 30                         谁处理该请求?通过servlet类实现
 31 
 32 ```
 33 model模型层: 负责和数据库进行交互,根据制定的请求处理数据
 34                     对请求进行处理中
 35 ```
 36 
 37 JSP
 38   jsp  java server page 运行在服务端的程序,是由html中嵌套java代码形式实现的。
 39   1.声明该文件为jsp文件
 40    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
 41   2.每次修改都要重新运行一下服务器,才能输出
 42   3.jsp的内置对象(系统帮忙创建好)
 43     out对象:向页面输出信息
 44     request:
 45     response
 46     session
 47     config
 48     application
 49     page
 50     pageContext
 51     exception
 52   4、简单的登陆功能实现步骤?
 53     1、编写jsp文件中的form表单
 54     2、web.xml中配置servlet和servlet-mapping标签
 55     3、创建servlet类,在类中doget方法中进行参数传递的处理
 56   5、get请求方式下,参数传递出现中文乱码解决方案
 57     第一种,通过字符转码的方式
 58         new String(user1.getBytes("ISO-8859-1"),"utf-8");
 59         缺点:每个参数都需要这样操作
 60     第二种,通过设置tomcat的server.xml文件,在69行,中添加 URIEncoding="utf-8"
 61             <Connector port="8080" protocol="HTTP/1.1"
 62                        connectionTimeout="20000"
 63                        redirectPort="8443" />
 64          优点:所有参数一次性设置
 65   6、post请求下,参数传递出现中文乱码解决方案
 66                 request.setCharacterEncoding("utf-8");
 67                 response.setCharacterEncoding("utf-8");
 68   7、如何不分post和get请求进行中文乱码的处理?
 69      通过过滤器的方式实现
 70         1、创建过滤器,在doFilter方法中编写
 71                     request.setCharacterEncoding("utf-8");
 72                     chain.doFilter(request, response);
 73                     response.setCharacterEncoding("utf-8");
 74         2、在web.xml文件中,编写filter和filter-mapping标签
 75                     <filter>
 76                         <filter-name>CharacterEncoding</filter-name>
 77                         <filter-class>com.baidu.filter.CharacterEncodingFilter</filter-class>
 78                     </filter>
 79                     <filter-mapping>
 80                         <filter-name>CharacterEncoding</filter-name>
 81                         <!--/* 表示url项目名下所有的字段都需要经过此过滤器-->
 82                         <url-pattern>/*</url-pattern>
 83                     </filter-mapping>
 84   8、如何servlet中的验证结果信息返回到页面上?
 85             //响应的时候出现中文乱码的处理方式
 86             response.setCharacterEncoding("utf-8");
 87             response.setHeader("Content-Type", "text/html;charset=UTF-8");
 88              response.setContentType("text/html;charset=UTF-8");
 89             PrintWriter writer=response.getWriter();
 90              writer.print("该用户存在");
 91   9、从servlet类跳转到jsp文件?
 92         //请求转发:将请求转发出去
 93         request.getRequestDispatcher("jsp/success.jsp").forward(request,response);
 94         注意点:url路径从webapp目录下开始
 95 
 96   10、将servlet中的提示信息,传递到jsp文件中?
 97        servlet中编写:
 98        request.setAttribute("success","来自servlet中提示:登陆成功");
 99        jsp中编写:
100        <%--将servlet中的提示信息传递到jsp文件中--%>
101        <%
102            String success1 = (String)request.getAttribute("success");
103            out.print(success1);
104        %>
105        简写方式:
106            ·在web.xml中检查webapp标签是否含有如下属性
107                 <web-app
108                         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
109                         xmlns="http://java.sun.com/xml/ns/javaee"
110                         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
111                         id="WebApp_ID" version="3.0"
112                 >
113            ·在jsp中编写
114                   ${success}
115 
116 11、通过响应重定向方式从servlet类跳转到jsp文件
117       response.sendRedirect(request.getContextPath()+"/jsp/success.jsp");
118 12、请求转发和响应重定向2种方式的区别
119     ·请求转发方式url是原来的url,响应重定向方式的url是重新定向的url(新的url)
120     ·通过setAttribute()方法保存在request容器中的key-value不能实现传递
121 13、request\session\application\page等对象是一个容器?
122     request:setAttribute方法  key-value success  登陆成功
123             作用域和生命周期是一次请求:
124             请求转发是一次请求;甲-》乙-》丙
125             响应重定向是2次请求;甲-》乙
126                                  甲-》丙
127     session:作用域和生命周期:一次会话(多次请求,肯定超过2次)
128             setAttribute() setAttribute();
129              HttpSession session = request.getSession();
130               session.setAttribute("success","来自servlet中提示:登陆成功");
131               session.getAttribute("success");
132      session是一次会话,多次请求??
133             自然生命周期:两次请求的时间间隔在30分钟之内,session中的key-value一直有效;
134      人工方式使session中数据失效
135             session.invalidate(): 是session容器中的所有key-value 数据失效;应用场景:退出功能的实现
136             session.removeAttribute(key):是session容器中的某key对应的数据失效;
137 
138 174 
175 
176 # Servlet课程-4
177 
178 ## 九大内置对象
179 
180 | 名称        | 功能           | 类型                                | 作用域             |
181 | ----------- | -------------- | ----------------------------------- | ------------------ |
182 | request     | 请求对象       | 类型 javax.servlet.ServletRequest   | 作用域 Request     |
183 | response    | 响应对象       | 类型 javax.servlet.SrvletResponse   | 作用域 Page        |
184 | pageContext | 页面上下文对象 | 类型 javax.servlet.jsp.PageContext  | 作用域 Page        |
185 | session     | 会话对象       | 类型 javax.servlet.http.HttpSession | 作用域 Session     |
186 | application | 应用程序对象   | 类型 javax.servlet.ServletContext   | 作用域 Application |
187 | out         | 输出对象       | 类型 javax.servlet.jsp.JspWriter    | 作用域 Page        |
188 | config      | 配置对象       | 类型 javax.servlet.ServletConfig    | 作用域 Page        |
189 | page        | 页面对象       | 类型 javax.lang.Object              | 作用域 Page        |
190 | exception   | 例外对象       | 类型 javax.lang.Throwable           | 作用域 page        |
191 
192 ## request常用的方法
193 
194 getContextPath()
195 
196 getParameter()
197 
198 getParameters()
199 
200 setAttribute()
201 
202 getAttribute()
203 
204 setCharacterCoding()
205 
206 getRequestDispatcher()
207 
208 ## response常用的方法
209 
210 sendRedirect()
211 
212 setCharacterEncoding()
213 
214 setHeader()
215 
216 ## session常用的方法
217 
218 set Attribute(key,value)
219 
220 getAttribue(key)
221 
222 removeAttribute(key)
223 
224 invalidate()
225 
226 getMaxInactiveInterval()
227 
228 ## session和cookie之间的区别
229 
230 · session是容器,在服务器端创建,并保存在服务器
231 
232 · cookie也是一个容器,在服务器端创建,保存在客户端/浏览器
233 
234 · cookie中的数据在浏览器之间是不共享的,session中保存的数据在不同浏览器中可以共享访问
235 
236 · 从安全性角度来看,session更安全
237 
238 ## cookie的使用实现用户名保存
239 
240 **思路**
241 
242 1、在Servlet中创建cookie实例
243 
244 2、设置路径
245 
246 3、设置cookie的失效时间
247 
248 4、将cookie发送到浏览器
249 
250 5、在jsp文件中接受cookie
251 
252 6、在指定位置输出cookie中保存的value值
253 
254 **实现**
255 
256 1、servlet类中
257 
258 ```java
259                 //登陆成功,使用cookie将huangwei保存进来
260                 Cookie cookie=new Cookie("username","huangwei");
261                 //设置路径
262                 cookie.setPath("/");
263                 //设置cookie的过期时间
264               //  cookie.setMaxAge(0);//不记录,此cookie是不起作用的,无效
265               //  cookie.setMaxAge(-1);//会话级cookie,关闭浏览器就消失,保存在内存中
266                 //持久化cookie,以文件的形式保存在硬盘里,时间可以自定义,单位秒
267                 cookie.setMaxAge(60*60);//持久化1小时
268                 //发送到浏览器中
269                 response.addCookie(cookie);
270 ```
271 
272 2、jsp中
273 
274 ```java
275 <%--java脚本--%>
276 <%
277     String username="";
278  //取到存放在cookie中的值
279     Cookie[] cookies = request.getCookies();
280     //进行非空判断
281     if(cookies!=null && cookies.length!=0){
282         // 遍历数组
283         for(Cookie c:cookies){
284             if(c.getName().equals("userCookie")){
285                 username = c.getValue();
286             }else {
287                 System.out.println("cookie的name值不等于userCookie");
288             }
289         }
290     }else{
291         System.out.println("数组为空");
292     }
293 
294 %>
295 <form method="post" action="<%=request.getContextPath() %>/nankeyuan">
296     姓名:<input type="text" name="xiaogou" value="huangwei ">
297     密码:<input type="password" name="xiaomao" value="">
298     ............
299     <input type="submit" value="登陆">
300 </form>
301 
302 ```
303 
304 ## Cookie的生命周期
305 
306 Cookie不只有name和value两个属性
307 
308 - Cookie的maxAge(掌握):Cookie的最大生命,即Cookie可保存的最大时长。以秒为单位. 例如:cookie.setMaxAge(60)表示这个Cookie会被浏览器保存到硬盘缓存上60秒
309 
310   - maxAge>0:浏览器会把Cookie保存到客户机硬盘上,有效时长为maxAge的值决定。
311   - maxAge<0:Cookie只在浏览器内存中存在,当用户关闭浏览器时,浏览器进程结束,同时Cookie也就死亡了.
312 
313 - maxAge=0:浏览器会马上删除这个Cookie!
314 
315 
316 
317 ## Application
318 
319   application表示的整个项目,也是一个容器,放在服务器中。
320 
321   application对象由多个客户端用户共享,它的应用范围是所有的客户,服务器启动后,新建一个application对象,该对象一旦建立,就一直保持到服务器关闭。当有客户访问服务器上的一个JSP页面时,JSP引擎为该客户分配已建立的application对象;当客户在所访问站点的不同页面浏览时,其application是同一个,直到服务器关闭。
322 
323 ## 统计页面被访问次数
324 
325 ```java
326   <%--java 脚本--%>
327   <%
328       //key-value 对应 key是总数代号,value表示总数  count-100 count-1  count-0
329       Object count = application.getAttribute("count");
330       if(count ==null){
331           application.setAttribute("count",1);
332       }else{
333           application.setAttribute("count",(int)count+1);
334       }
335       int count1 = (int)application.getAttribute("count");
336       System.out.println("该页面被访问"+count1);
337       out.print("该页面被访问"+count1);
338   %>
339 ```
340 
341 ## servlet
342 
343   在mvc思想中servlet类充当与哪一层?
344 
345   **补充**
346 
347   m:model模型层,负责业务逻辑处理和数据库的交互。通过创建service包实现业务逻辑        的处理。通过常见dao包实现数据库的交互。
348 
349   v: view 视图层 ,负责 向用户展示页面和表单的编写等,通过jsp文件实现的
350 
351   c: controller  控制器层,负责请求的派发和处理等,通过servlet文件实现
352 
353   servlet类,充当controller控制器层,是运行在服务器端的程序,相当于一个容器。也具有生命周期。
354 
355   **运行原理**
356 
357   <img src="C:\Users\ww\Desktop\南科院-web-1108\images\wps90AB.tmp.jpg" alt="img" style="zoom:33%;" />
358 
359   **Servlet类的创建**
360 
361   通过继承HttpServlet接口实现Servlet类的创建。
362 
363   **生命周期**
364 
365   init() 初始化,启动服务器后,先执行init()方法,只初始化执行一次。
366 
367   service()提供服务,对请求方式的处理过程。每请求1次,该方法执行一次。
368 
369   destory()销毁死亡,只有在服务器停止的时候才执行。
370 
371 387 ## mySql学习
388 
389 ```mysql
390 #  数据库  表   表中记录
391 #查询数据库
392 SHOW DATABASES;
393 #创建数据库
394 CREATE DATABASE	school;
395 #不修改
396 #删除
397 DROP DATABASE school;
398 #制定选择某数据库
399 USE school;
400 #####################
401 #创建表
402 CREATE TABLE student(
403 `id` INT(10) PRIMARY KEY AUTO_INCREMENT COMMENT '编号id',
404 `name`VARCHAR(40) COMMENT'学生姓名',
405 `studentNo` INT(10) COMMENT'学号',
406 `birthday` DATETIME COMMENT'生日',
407 `createdBy` INT(10) COMMENT'创建人',
408 `creationDate` DATETIME COMMENT'创建时间',
409 `modifyBy` INT(10) COMMENT'修改人',
410 `modifyDate` DATETIME COMMENT'修改时间'
411 );
412 #查询表
413 SHOW TABLES;
414 DESCRIBE student1;
415 #删除表
416 DROP TABLE student1;
417 #修改表
418 #1、修改表的名字
419 ALTER TABLE student RENAME student1;
420 #2、添加字段
421 ALTER TABLE student1 ADD sex VARCHAR(2);
422 #3、删除字段
423 ALTER TABLE student1 DROP sex;
424 #4、sex改成gender
425 ALTER TABLE student1 CHANGE sex gender VARCHAR(10);
426 #################################
427 #处理表中的记录
428 #添加数据
429 INSERT INTO student1(
430 id,`name`,studentNo,
431 birthday,createdBy,
432 creationDate,modifyBy,modifyDate,gender
433 )VALUES
434 ('1','张三1','1','2019-1-1',
435 '1','2019-11-8','1','2019-11-8','男'),
436 ('2','张三2','1','2019-1-1',
437 '1','2019-11-8','1','2019-11-8','男'),
438 ('3','张三3','1','2019-1-1',
439 '1','2019-11-8','1','2019-11-8','男'),
440 ('4','张三4','1','2019-1-1',
441 '1','2019-11-8','1','2019-11-8','男')
442 ;
443 #查询表中记录
444 SELECT * FROM student1;
445 SELECT * FROM student1 WHERE id=1;
446 #删除表中记录
447 DELETE FROM student1 WHERE id=4;
448 DELETE FROM student1;
449 #修改某一个字段的赋值
450 UPDATE student1 SET `name`='李四' WHERE id=1;
451 
452 
453 ```
454 
455 
456 
457 499 # Servlet课程-5
500 
501 ## 如何使MySQL和Java连接
502 
503 ### **jdbc技术**
504 
505 Java database connection :Java和数据库连接技术,实现对数据库的增删改查功能(交互)。
506 
507 数据库是一个服务器,连接服务器需要知道:url 、用户名、密码、驱动加载。
508 
509 ### 准备工作
510 
511 1、创建util包,util工具包,存放工具性质的类。
512 
513 <img src="C:\Users\ww\Desktop\南科院-web-1108\images\1573259997992.png" alt="1573259997992" style="zoom:50%;" />
514 
515 2、在util中创建JdbcUtil类,该类中编写和数据库进行交互的方法。
516 
517 3、需要驱动,该驱动来源一个依赖jar包:mysql-connector-java.jar
518 
519 ```java
520     <dependency>
521       <groupId>mysql</groupId>
522       <artifactId>mysql-connector-java</artifactId>
523       <version>8.0.18</version>
524     </dependency>
525 ```
526 
527 <img src="C:\Users\ww\Desktop\南科院-web-1108\images\1573260450582.png" alt="1573260450582" style="zoom:80%;" />
528 
529 ### 编写连接数据库方法
530 
531 ```java
532     //连接数据库mysql :url 用户名 密码  驱动
533     public boolean getConnection(){
534 
535         try {
536             //添加驱动
537             Class.forName("com.mysql.jdbc.Driver");
538             //编写url路径 jdbc:mysql://localhost:3306/数据库名
539             String url="jdbc:mysql://localhost:3306/school?serverTimezone=UTC&useUnicode=true$characterEncoding=utf8";
540 
541             //获得connection数据库连接器
542             connection = DriverManager.getConnection(url, "root", "root");
543 
544         } catch (Exception e) {
545             e.printStackTrace();
546         }
547         return true;
548     }
549 ```
550 
551 ### 编写增删改方法
552 
553 ```java
554 //增删改功能
555     public int executeUpdate(String sql,Object[] params){
556         int updateRows=0;
557         try {
558             if (this.getConnection()){
559                 //获得预编译对象,提高查询速度
560                 preparedStatement = connection.prepareStatement(sql);
561 
562                 //遍历params数组,将占位符中填充数组中的元素
563                 for(int i=0;i<params.length;i++){
564                     preparedStatement.setObject(i+1,params[i]);
565                 }
566                 //执行增删改功能,返回值大于0,表示 执行成功
567                 updateRows= preparedStatement.executeUpdate();
568 
569             }
570         } catch (Exception e) {
571             e.printStackTrace();
572         }
573         return updateRows;
574     }
575 
576 ```
577 
578 **思路**
579 
580 ```java
581 **     1  在sql客户端编写的增加sql语句
582      * INSERT INTO student1(
583      * id,
584      * `name`,studentNo,birthday,createdBy,creationDate,
585      * modifyBy,modifyDate
586      *
587      *
588      * )VALUES(
589      * 5,'王五','5','2019-11-11','2','2011-1-1','2','2011-1-1'
590      * );
591      *2-1  在java类中编写
592      * 在java的sql表现形式  String sql=
593      * INSERT INTO student1(
594      * id,
595      * `name`,studentNo,birthday,createdBy,creationDate,
596      * modifyBy,modifyDate
597      *
598      * )VALUES(
599      * ?,?,?,?,?,?,?,?
600      * );
601     *  2-2  String sql=INSERT INTO student1(id,`name`,studentNo,birthday,createdBy,creationDate,modifyBy,modifyDate)VALUES(?,?,?,?,?,?,?,?);
602     *  2-3  Object[] params 是一个数组,
603      *    Object[] params={5,'王五','5','2019-11-11','2','2011-1-1','2','2011-1-1'};
604      *
605      * */
606         3  将占位符?中填充数组中的数组元素
607 
608 ```
609 
610 ### 编写查询功能
611 
612 ```java
613 //查询功能(全部查询和条件查询)
614     public ResultSet executeQuery(String sql,Object[] params){
615 
616         try{
617             //获得预编译对象
618             if(this.getConnection()){
619                 preparedStatement = connection.prepareStatement(sql);
620             }
621 
622             if(params!=null){
623                 //将占位符填充数组元素
624                 for (int i=0;i<params.length;i++){
625                     preparedStatement.setObject(i+1,params[i]);
626                 }
627             }
628             //执行查询功能
629           resultSet = preparedStatement.executeQuery();
630 
631         }catch (Exception e){
632             e.printStackTrace();
633         }
634         return resultSet;
635     }
636 ```
637 
638 ### 关闭资源
639 
640 ```java
641 //关闭资源
642     public boolean closeResource(){
643 
644         try{
645             //关闭resultSet
646             if(resultSet!=null){
647                 resultSet.close();
648             }
649             //关闭preparedStatement
650             if(preparedStatement!=null){
651                 preparedStatement.close();
652             }
653             //关闭connection
654             if(connection!=null){
655                 connection.close();
656             }
657 
658         }catch (Exception e){
659             e.printStackTrace();
660         }
661 
662         return true;
663     }
664 
665 ```
666 
667 ### 使用junit测试
668 
669 #### 1、添加junit依赖(jar)
670 
671 ```
672 <dependency>
673       <groupId>junit</groupId>
674       <artifactId>junit</artifactId>
675       <version>4.11</version>
676       <scope>test</scope>//将此句删除
677     </dependency>
678 ```
679 
680 
681 
682 #### 2、创建test包,包内创建测试类
683 
684 <img src="C:\Users\ww\Desktop\南科院-web-1108\images\1573267253146.png" alt="1573267253146" style="zoom:67%;" />
685 
686 
687 
688 #### 3、进行测试
689 
690 ##### **查询所有记录**
691 
692 ```java
693 @Test
694     public void test1(){
695         //查询表中的所有数据记录
696         String sql="select * from student1";
697         //Object[] params=null;
698         ResultSet resultSet = jdbcUtil.executeQuery(sql, null);
699         try{
700             while(resultSet.next()){
701                 //获得记录中的列信息
702                 int  idValue = (int)resultSet.getObject(1);
703                 String nameValue= (String) resultSet.getObject(2);
704                 //int studentNo=(int)resultSet.getObject(3);
705                 int studentNoValue=resultSet.getInt(3);
706                 Date birthdayValue=resultSet.getDate(4);
707                 int createdByValue=(int)resultSet.getObject(5);
708                 Date creationDateValue=resultSet.getDate(6);
709                 int modifyByValue=resultSet.getInt(7);
710                 Date modifyDateValue=resultSet.getDate(8);
711                 String genderValue=resultSet.getString(9);
712                 System.out.println(idValue+nameValue+studentNoValue+
713                         birthdayValue+createdByValue+creationDateValue+
714                         modifyByValue+modifyDateValue+genderValue);
715             }
716         }catch (Exception e){
717 				e.printStackTrace();
718         }
719 		//关闭资源
720         jdbcUtil.closeResource();
721     }
722 ```
723 
724 ##### **查询某个id对应的记录**
725 
726 ```java
727 //查询某个id对应的数据记录
728     @Test
729     public void test2(){
730         String sql="select * from student1 where id=?";
731         Object[] params={2};
732         ResultSet resultSet = jdbcUtil.executeQuery(sql, params);
733         try{
734             while(resultSet.next()){
735                 //获得记录中的列信息
736                 //int  idValue = (int)resultSet.getObject(1);
737                 int idValue=resultSet.getInt("id");
738 
739                 //String nameValue= (String) resultSet.getObject(2);
740                 String nameValue=resultSet.getString("name");
741 
742                // int studentNoValue=resultSet.getInt(3);
743                 int studentNoValue=resultSet.getInt("studentNo");
744 
745                // Date birthdayValue=resultSet.getDate(4);
746                 Date birthdayValue=resultSet.getDate("birthday");
747 
748                // int createdByValue=(int)resultSet.getObject(5);
749                 int createdByValue=(int)resultSet.getObject("createdBy");
750 
751                 //Date creationDateValue=resultSet.getDate(6);
752                 Date creationDateValue=resultSet.getDate("creationDate");
753 
754                System.out.println(idValue+nameValue+studentNoValue+
755                         birthdayValue+createdByValue+creationDateValue);
756             }
757         }catch (Exception e){
758 				e.printStackTrace();
759         }
760         //关闭资源
761         jdbcUtil.closeResource();
762     }
763 ```
764 
765 ### 备份JdbcUtil工具类
766 
767 ```java
768 package com.baidu.util;
769 
770 import java.sql.*;
771 
772
775 public class JdbcUtil {
776     private Connection connection=null;
777     private PreparedStatement preparedStatement=null;
778     private ResultSet resultSet=null;
779 
780     //连接数据库mysql :url 用户名 密码  驱动
781     private boolean getConnection(){
782         try {
783             //添加驱动
784             Class.forName("com.mysql.jdbc.Driver");
785             //编写url路径 jdbc:mysql://localhost:3306/数据库名
786             String url="jdbc:mysql://localhost:3306/school?serverTimezone=UTC&useUnicode=true$characterEncoding=utf8";
787             //获得connection数据库连接器
788             connection = DriverManager.getConnection(url, "root", "root");
789 
790         } catch (Exception e) {
791             e.printStackTrace();
792         }
793         return true;
794     }
795 
796     //增删改功能
797     public int executeUpdate(String sql,Object[] params){
798         int updateRows=0;
799         try {
800             if (this.getConnection()){
801                 //获得预编译对象,提高查询速度
802                 preparedStatement = connection.prepareStatement(sql);
803 
804                 //遍历params数组,将占位符中填充数组中的元素
805                 for(int i=0;i<params.length;i++){
806                     preparedStatement.setObject(i+1,params[i]);
807                 }
808                 //执行增删改功能,返回值大于0,表示 执行成功
809                 updateRows= preparedStatement.executeUpdate();
810 
811             }
812         } catch (Exception e) {
813             e.printStackTrace();
814         }
815         return updateRows;
816     }
817 
818     //查询功能(全部查询和条件查询)
819     public ResultSet executeQuery(String sql,Object[] params){
820         try{
821             //获得预编译对象
822             if(this.getConnection()){
823                 preparedStatement = connection.prepareStatement(sql);
824             }
825             if(params!=null){
826                 //将占位符填充数组元素
827                 for (int i=0;i<params.length;i++){
828                     preparedStatement.setObject(i+1,params[i]);
829                 }
830             }
831             //执行查询功能
832             resultSet = preparedStatement.executeQuery();
833 
834         }catch (Exception e){
835             e.printStackTrace();
836         }
837         return resultSet;
838     }
839     //关闭资源
840     public boolean closeResource(){
841         try{
842             //关闭resultSet
843             if(resultSet!=null){
844                 resultSet.close();
845             }
846             //关闭preparedStatement
847             if(preparedStatement!=null){
848                 preparedStatement.close();
849             }
850             //关闭connection
851             if(connection!=null){
852                 connection.close();
853             }
854 
855         }catch (Exception e){
856             e.printStackTrace();
857         }
858         return true;
859     }
860 
861 }
862 
863 ```
864 
865874 
875 ##### 1、配置tomcat中context.xml文件
876 
877 配置Tomcat的conf/context.xml(将下面代码复制粘贴到context.xml中的context标签中)
878 
879 ```xml
880 <Resource name="jdbc/news"  881               auth="Container"  type="javax.sql.DataSource"  maxActive="100"  882               maxIdle="30" maxWait="10000" username="root"  password="root"  883               driverClassName="com.mysql.jdbc.Driver"  884               url="jdbc:mysql://127.0.0.1:3306/数据库名"/>
885 
886 ```
887 
888 ![1573282989441](C:\Users\ww\Desktop\南科院-web-1108\images\1573282989441.png)
889 
890 ##### 2、编写连接功能
891 
892 ```java
893 //通过连接池实现连接
894     public boolean getConnection1() {
895         try {
896             //初始化上下文
897             Context ct = new InitialContext();
898             //获取与逻辑名相关联的数据源对象
899             DataSource ds = (DataSource) ct.lookup("java:comp/env/jdbc/xiaogou");//为<Resource>中的name的值
900             cnt = ds.getConnection();
901         } catch (NamingException e) {
902             // TODO Auto-generated catch block
903             e.printStackTrace();
904         } catch (SQLException e) {
905             // TODO Auto-generated catch block
906             e.printStackTrace();
907         }
908         return true;
909 
910     }
911 ```
912 
913 ## 通过model层实现三层架构
914 
915 1、在项目中创建2个包:service包和dao包
916 
917 ​	service包:存放业务逻辑的处理代码
918 
919 ​	dao包:database access 存放连接数据库的代码
920 
921 <img src="C:\Users\ww\Desktop\南科院-web-1108\images\1573347905837.png" alt="1573347905837" style="zoom:67%;" />
922 
923 2、编写dao包中的代码
924 
925 ​		a 在此包中创建接口和实现类(注意:命名要规范)
926 
927 ​		<img src="C:\Users\ww\Desktop\南科院-web-1108\images\1573348188546.png" alt="1573348188546" style="zoom:50%;" />
928 
929 ​		b 在接口中编写登陆方法和在实现类中重写该登陆方法
930 
931 ```java
932 public interface UserDao {
933     //登陆方法
934     public ResultSet login(String username, String password);
935 }
936 ```
937 
938 ```java
939 public class UserDaoImpl implements UserDao {
940     @Override
941     public ResultSet login(String username, String password) {
942         //连接数据库
943         return null;
944     }
945 }
946 ```
947 
948 ​	c  连接数据库操作
949 
950 ```java
951 public class UserDaoImpl implements UserDao {
952 
953     ResultSet resultSet=null;
954     @Override
955     public ResultSet login(String username, String password) {
956         //连接数据库
957         JdbcUtil jdbcUtil = new JdbcUtil();
958         String sql="select count(*) as count from user where " +
959                 "username=? and password=?";
960         Object[] params={username,password};
961         resultSet = jdbcUtil.executeQuery(sql, params);
962         return resultSet;
963     }
964 }
965 ```
966 
967 d  在数据库中创建user表(school库中)
968 
969 ```sql
970 #选择制定库
971 USE school;
972 #在库中创建表
973 CREATE TABLE `user`(
974 id INT(4) PRIMARY KEY AUTO_INCREMENT COMMENT '编码id',
975 username VARCHAR(40) COMMENT '用户名',
976 `password` VARCHAR(40) COMMENT '用户密码'
977 );
978 #查询表结构
979 DESCRIBE USER;
980 #插入表记录2条
981 INSERT INTO `user`(id,username,`password`)
982 VALUES(1,'zhangsan','zhangsan'),(2,'lisi','lisi');
983 #查询表记录
984 SELECT * FROM `user`;
985 #测试是否存在某某人
986 SELECT COUNT(*) AS `count` FROM `user`
987 WHERE username='zhangsan' AND `password`='zhangsan'
988 ```
989 
990 3、在service包中编写代码
991 
992 a 创建接口和对应的实现类(UserService和UserServiceImpl)
993 
994 <img src="C:\Users\ww\Desktop\南科院-web-1108\images\1573350311295.png" alt="1573350311295" style="zoom:67%;" />
995 
996 b  编写接口和实现类中的代码
997 
998 ```java

1001  */
1002 public interface UserService {
1003     //登陆方法
1004     public boolean login(String username,String password);
1005 }
1006 ```
1007 
1008 ```java
1009
1012 public class UserServiceImpl implements UserService {
1013     //引用接口userDao
1014     public UserDao userDao=new UserDaoImpl();
1015     //登陆方法
1016     public boolean login(String username, String password) {
1017         //进行业务逻辑代码的编写
1018         ResultSet resultSet = userDao.login(username, password);
1019         boolean flag=false;
1020         if(resultSet!=null){
1021             flag=true;
1022         }
1023         return flag;
1024     }
1025 }
1026 ```
1027 
1028 
上一篇:转换SQLCEResultSet结果视图到数据表


下一篇:有办法避免wasNull()方法吗?