MIKU MOE

JavaWeb_Filter_JDBC

Java_Web


1. JavaBeen

实体类

  • JavaBean有特定的写法:

    • 必须要有一个无参构造

    • 属性必须私有化

    • 必须有对应的get/set方法

    • 一般用来和数据库的字段做映射

  • ORM : 对象关系映射

    • 表--->类

    • 字段--->属性

    • 行记录--->对象

 <%
     //PeopLe people = new People();
     //people.setId();
     //people.setName();
 %><%--People是定义的实体类,上面的Java代码等价于下面的jsp--%><jsp:useBean id="people" class="com.study.pojo.People" scope="page"/>
 <jsp:setProperty name="people" property="id" value="01" />
 <jsp:setProperty name="people" property="name" value="xx" />
 <jsp:getProperty name="people" property="id"/>
 <jsp:getProperty name="people" property="name"/>

 


 

2. MVC

Model view Controller 模型、视图、控制器

早些年架构 :

image-20210827225813069

用户直接访问控制层,控制层就可以直接操作数据库

servlet --> CRUD --> 数据库

弊端 : 程序十分臃肿,不利于维护

servlet的代码中 : 处理请求、响应、视图跳转、处理JDBC、处理业务代码、处理逻辑代码

架构 : 没有什么是加一层解决不了的!

MVC三层架构:

image-20210827230407734

Model

  • 业务处理:业务逻辑(Service)

  • 数据持久层:CRUD(Dao)

view

  • 展示数据

  • 提供链接发起Servlet请求

Controller

  • 接收用户请求 (req:请求参数,Session信息)

  • 交给业务层处理对应代码

  • 控制视图的跳转

    登录 --> 接收用户的登录请求 --> 处理用户的请求(获取用户登录的参数,username,password)

    --> 交给业务层处理登录业务(判断用户名密码是否正确:事务) --> Dao层查询用户名和密码是否正确

    --> 数据库


 

3. Filter ***

Filter:过滤器,用来过滤网站的数据

  • 处理乱码

  • 登录

image-20210827231033289

开发过程:

在web.xml中配置Filter

 <filter>
     <filter-name>FilterT</filter-name>
     <filter-class>com.study.FilterT</filter-class>
 </filter>
  <filter-mapping>
     <filter-name>FilterT</filter-name>
     <!--只要是/servLet的任何请求,全经过这个过滤器-->
     <url-pattern>/servlet/*</url-pattern>
 </filter-mapping>

 

实现Filter接口,重写对应的方法

 public class FilterT implements Filter {
     //初始化 web服务器启动就已经初始化
     @Override
     public void init(FilterConfig filterConfig) throws ServletException { }
     //chain : 链
     /*
     1.过滤中的所有代码,在过滤特定请求的时候都会执行
     2.必须要让过滤器继续通行 chain.doFiLter(request, response);
     * */
     @Override
     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
         request.setCharacterEncoding("utf-8");
         response.setCharacterEncoding("utf-8");
         response.setContentType("text/html");
         System.out.println("FliterT执行前...");
         chain.doFilter(request, response); //让我们的请求继续走,如果不写,程序被拦截
         System.out.println("FliterT执行后...");
     }
     //销毁 web服务器关闭的时候销毁
     @Override
     public void destroy() { }
 }

 


 

4. 监听器

 /*******统计网站在线人数:统计session********/
 public class onlineCountListener implements HttpSessionListener {
 //创建session 监听:看你的一毕一动
 //一旦创建session就会触发一次这个事件!
 public void sessionCreated(HttpSessionEvent se) {
     Servletcontext ctx = se.getSession().getServletContext();
     Integer onlineCount = (Integer)ctx.getAttribute("onlineCount");
     if (onlineCount==null){
         onlineCount = new Integer(1);
     }else{
         int count = onlineCount.intValue();
         onlineCount = new Integer(count+1);
         ctx.setAttribute("OnlineCount",onlineCount);
     }
 }
 //销毁session监听
 //一旦销毁session就会触发一次这个事件!
 public void sessionDestroyed(HttpSessionEvent se) {
     Servletcontext ctx = se.getSession().getServletContext();
     Integer onlineCount = (Integer) ctx.getAttribute("onlineCount");
     if (onlineCount==nul1){
         onlineCount = new Integer(0);
     }else{
         int count = onlineCount.intValue();
         onlineCount = new Integer(count-1);
         ctx.setAttribute("onlineCount" ,onlineCount);
     }
 }
 /*销毁操作
 手动销毁: getsession().invalidate();
 自动销毁: 
     配置Seesion过期时间
     <session-config>
         <session-timeout>1</session-timeout>
     </session-config>
 */
 }
 /*******JSP********/
 <h1>当前有<span><%=this.getServletConfig().getServletContext()%></span>人在线</h1>
 /*******注册监听器 web.xml********/
 <listener>
     <listener-class>com.study.listener.onlineCountListener</listener-class>
 </listener>

 


 

5. 过滤器监听器常见应用

监听器:GUI编程中经常使用

  • 用户登录之后,向Sesison中放入用户的数据

  • 进入主页的时候要判断用户是否已经登录;要求:在过滤器中实现!

/********USER_SESSION设置为常量*******/
 public class Constant {
     public final static String USER_SESSION = "USER_SESSION";
 }
 /********登录*******/
 @Override
 protected void doGet(HttpServletRequest req,HttpServletResponse resp) throws ServletException,I0Exception { 
     //获取前端请求的参数
     String username = req.getParameter("username" );
     if (username.equals("admin")) {//登录成功
         req.getSession().setAttribute("USER_SESSION",req.getSession().getId());
         resp.sendRedirect("/sys/success.jsp");
     }else{//登录失败
         resp.sendRedirect("/error.jsp");
     }
 }
 /********注销*******/
 @Override
 protected void doGet(HttpServletRequest req,HttpServletResponse resp) throws ServletException,I0Exception { 
     Object user_session = req.getSession().getAttribute("USER_SESSION");
     if (user_session ! =nu11){
         req.getSession().removeAttribute("USER_SESSION");
         resp.sendRedirect("/Login.jsp");
     }else{
         resp.sendRedirect("/Login.jsp");
     }
 }
 /********实现注销后进入不了主页 JSP实现*******/
 //主页.jsp
 <%
 Object userSession = request.getSession().getAttribute("USER_SESSION");
 if (userSession==null){
     response.sendRedirect("/Login.jsp");
 }
 %>
 <h1>主页</h1>
 <p><a href="/servlet/logout">注销</a></p>
 /********实现注销后进入不了主页 过滤器实现*******/
 public class FilterT implements Filter {
     public void init(FilterConfig filterConfig) throws ServletException { }
     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
         //ServetRequest   HttpServletRequest
         HttpServletRequest request = (HttpServletRequest) req;
         HttpServletResponse response = (HttpServletResponse) resp;
         
         if (request.getSession().getAttribute("USER_SESSION")==null){
             response.sendRedirect("/error.jsp");
         }
         chain.doFilter(request,response) ;
     }
     public void destroy() { }
 }

 

6. JDBC

  • java.sql

  • javax.sql

  • mysql-connecter-java 连接驱动(必须要导入)

 //配置信息
 private static final String DRIVER="com.mysql.jdbc.Driver";
 private static final String URL="jdbc:mysql://localhost:3306/day715?useUnicode=true&characterEncoding=utf8";
 private static final String USER="root";
 private static final String PASSWORD="root";
 ​
 //1.加载驱动
 Class.forName(DRIVER);
 //2.连接数据库,Connection代表数据库
 Connection conn=DriverManager.getConnection(URL,USER,PASSWORD);
 //3.向数据库发送SQL的对象Statement(PreparedStatement):CRUD
 Statement sta = conn.createStatement();
 //4.编写SQL
 String sql ="select * from user";
 //5.执行SQL,返回一个ResultSet:结果集
 ResultSet rs = sta.executeQuery(sql);
 while (rs.next()){
     System.out.println(rs.getObject("id"));
     System.out.println(rs.getObject("name"));
     System.out.println(rs.getObject("password"));
 }
 //6.关闭连接
 if(rs!=null){
     rs.close();
 }
 if(sta!=null){
     sta.close();
 }
 if(conn!=null){
     conn.close();
 }
 /************PreparedStatement************/
 //4.预编译
 String sql = "insert into users(id,name,password,birthday) values(?,?,?,?);";
 PreparedStatement preparedStatement = connection.prepareStatement(sql);
 preparedStatement.setInt(1,001);
 preparedStatement.setString(2,"name");
 preparedStatement.setString(3,"123456");
 preparedStatement.setString(4,newDate(new java.util.Date()));
 //5.执行SQL
 int i = preparedStatement.executeUpdate();
 if (i>0) {
     System.out.print1n("插入成功");
 }

 

  事务

要么都成功,要么都失败!

ACID原则:保证数据的安全。

Junit : 单元测试 (@Test:加了此注解的方法可以直接运行)

 #转账测试
 start transaction;#开启事务
 update account set money = money-100 where name = 'A';
 update account set money = money+100 where name = 'B';
 commit;#提交
 rollback;#回滚

 try {
     /*****连接数据库*****/
     //通知数库库开启事务,false开启
     connection.setAutoCommit(false);
     String sql1 = "update account set money = money-100 where name = 'A'";
     connection.preparestatement(sql1).executeUpdate(); 
     int i = 1/0; //制造错误
     String sql2 = "update account set money = money+100 where name = 'B'";
     connection.preparestatement(sql2).executeUpdate(); 
     connection.commit(); //如果以上代码全部成功执行,则
 } catch(Exception e) {
     try {
         connection.rollback(); //如果出现异常,回滚
     } catch(SQLException e1) {
         e1.printStackTrace();
     }
     e.printStackTrace();
 }

 

posted @ 2021-08-30 15:04  miku_moe  阅读(51)  评论(0)    收藏  举报