1. jsp

servle逻辑处理方便 html页面表现麻烦

jsp 页面表现方便 但是逻辑处理麻烦

JSP

是一种页面技术 JSP本质上是servlet类 通过JSP引擎翻译成servlet

jsp 约等于 java+html

注意:jsp不是访问静态的html文件

index.jsp修改成如下代码:

<%--
Created by IntelliJ IDEA.
User: chenw
Date: 2023/10/19
Time: 22:27
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" import="java.util.*,java.lang.*" pageEncoding="utf-8" %> <html>
<head>
<title>$Title$</title>
</head>
<body> <%
int i = new Random().nextInt(10);
if(i>5){
%>
<b>今天天气很好 !</b>
<%}else{
%>
<b>今天天气不好~~</b>
<%}%>
</body>
</html>

2. 过滤器



作用:

分析请求 对请求的数据进行预处理

阻止请求的进行

web资源的协作

修改请求他的内容

servlet1

response.getWriter().write("学习 filter1");

servlet2

response.getWriter().write("学习 filter2");

启服务 访问

http://localhost:8080/learningfilter/serv1

http://localhost:8080/learningfilter/serv2

都会有乱码

如何用filter解决

new filter

web.xml增加如下配置

    <filter>
<filter-name>SetEncodingFilter</filter-name>
<filter-class>com.msb.filter.SetEncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>SetEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

所有的请求都需要经过 SetEncodingFilter处理

public class SetEncodingFilter implements Filter {
public void destroy() {
} public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
req.setCharacterEncoding("utf-8");
resp.setContentType("text/html;charset=utf-8");
chain.doFilter(req, resp);
} public void init(FilterConfig config) throws ServletException { } }

没有中文乱码了

用过滤启 来做一个登录拦截 条件是session里面含有user

LoginFilter

package com.msb.filter;

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException; /**
* @Auther: jack.chen
* @Date: 2023/10/21 - 10 - 21 - 10:36
* @Description: ${PACKAGE_NAME}
* @version: 1.0
*/
public class LoginFilter implements Filter {
public void destroy() {
} public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
HttpSession session = ((HttpServletRequest)req).getSession(); if(session.getAttribute("user") == null){
((HttpServletResponse)resp).sendRedirect("login.jsp"); }else{
chain.doFilter(req, resp);
}
} public void init(FilterConfig config) throws ServletException { } }

web.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<filter>
<filter-name>SetEncodingFilter</filter-name>
<filter-class>com.msb.filter.SetEncodingFilter</filter-class>
</filter>
<filter>
<filter-name>LoginFilter</filter-name>
<filter-class>com.msb.filter.LoginFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LoginFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>SetEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping> <servlet>
<servlet-name>LearningServlet1</servlet-name>
<servlet-class>com.msb.servlet.LearningServlet1</servlet-class>
</servlet>
<servlet>
<servlet-name>LearningServlet2</servlet-name>
<servlet-class>com.msb.servlet.LearningServlet2</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LearningServlet1</servlet-name>
<url-pattern>/serv1</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>LearningServlet2</servlet-name>
<url-pattern>/serv2.do</url-pattern>
</servlet-mapping>
</web-app>

登录 http://localhost:8080/learningfilter/serv2.do 则调到 login.jsp

再次登录

http://localhost:8080/learningfilter/serv2.do

响应正常

3. listener 监听器

监听器的作用:

监听一些共享对象属性值的变化 或者事件的发生前后 做出响应的响应 类似 触发器

这些共享对象有:

ServletContext 对象 全局唯一的tomcat启动时创建 停止时销毁

HttpSession对象

ServletRequest 对象

servlet

package com.msb.servlet;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException; /**
* @Auther: jack.chen
* @Date: 2023/10/21 - 10 - 21 - 11:40
* @Description: ${PACKAGE_NAME}
* @version: 1.0
*/
public class ListenerServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=utf-8"); // request对象设置属性
request.setAttribute("learning", "listener"); //servletContext对象添加属性
ServletContext context = this.getServletContext();
context.setAttribute("servlet_key", "servlet_value"); // 设置session
HttpSession session = request.getSession();
session.setAttribute("sess_key", "sess_value"); response.getWriter().write("Learning Listener !"); }
}

listener

package com.msb.listener; /**
* @Auther: jack.chen
* @Date: 2023/10/21 - 10 - 21 - 11:45
* @Description: ${PACKAGE_NAME}
* @version: 1.0
*/ import javax.servlet.*;
import javax.servlet.http.HttpSessionAttributeListener;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import javax.servlet.http.HttpSessionBindingEvent; public class MyListener1 implements ServletRequestListener, ServletRequestAttributeListener,
ServletContextListener, ServletContextAttributeListener,
HttpSessionListener, HttpSessionAttributeListener { @Override
public void attributeAdded(ServletRequestAttributeEvent servletRequestAttributeEvent) {
// request对象 属性增加 // 将设置的属性打印
System.out.println(servletRequestAttributeEvent.getName());
System.out.println(servletRequestAttributeEvent.getValue());
} @Override
public void attributeRemoved(ServletRequestAttributeEvent servletRequestAttributeEvent) {
// request对象 属性移除
} @Override
public void attributeReplaced(ServletRequestAttributeEvent servletRequestAttributeEvent) {
// request对象 属性重新设置
// 将设置的属性打印
System.out.println(servletRequestAttributeEvent.getName());
System.out.println(servletRequestAttributeEvent.getValue());
} @Override
public void requestDestroyed(ServletRequestEvent servletRequestEvent) {
// request对象 创建 } @Override
public void requestInitialized(ServletRequestEvent servletRequestEvent) {
// request对象 销毁
} @Override
public void attributeAdded(ServletContextAttributeEvent servletContextAttributeEvent) {
// servletContext 对象添加属性
} @Override
public void attributeRemoved(ServletContextAttributeEvent servletContextAttributeEvent) {
// servletContext 对象移除属性
} @Override
public void attributeReplaced(ServletContextAttributeEvent servletContextAttributeEvent) {
// servletContext 对象 替换属性
} @Override
public void contextInitialized(ServletContextEvent servletContextEvent) {
// servletContext 对象创建 tomcat启动时创建一次 全局共享
} @Override
public void contextDestroyed(ServletContextEvent servletContextEvent) {
// servletContext 停止时销毁
} @Override
public void attributeAdded(HttpSessionBindingEvent httpSessionBindingEvent) {
// session 对象 添加属性
} @Override
public void attributeRemoved(HttpSessionBindingEvent httpSessionBindingEvent) {
// session 对象 移除属性
} @Override
public void attributeReplaced(HttpSessionBindingEvent httpSessionBindingEvent) {
// session 对象 修改属性 } @Override
public void sessionCreated(HttpSessionEvent httpSessionEvent) {
// session 对象被创建
} @Override
public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
// session 对象销毁
}
}

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<listener>
<listener-class>com.msb.listener.MyListener1</listener-class>
</listener>
<servlet>
<servlet-name>ListenerServlet</servlet-name>
<servlet-class>com.msb.servlet.ListenerServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ListenerServlet</servlet-name>
<url-pattern>/serv1</url-pattern>
</servlet-mapping>
</web-app>

用listener实现在线人数的统计

不同的浏览器分别访问



page.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
当前在线人数:${applicationScope.count}
</body>
</html>

listener

package com.msb.listener; /**
* @Auther: jack.chen
* @Date: 2023/10/21 - 10 - 21 - 12:07
* @Description: ${PACKAGE_NAME}
* @version: 1.0
*/ import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.http.HttpSessionAttributeListener;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import javax.servlet.http.HttpSessionBindingEvent; public class CountListener implements ServletContextListener,
HttpSessionListener, HttpSessionAttributeListener { // Public constructor is required by servlet spec
public CountListener() {
} // -------------------------------------------------------
// ServletContextListener implementation
// -------------------------------------------------------
public void contextInitialized(ServletContextEvent sce) {
/* This method is called when the servlet context is
initialized(when the Web application is deployed).
You can initialize servlet context related data here.
*/
ServletContext servletContext = sce.getServletContext();
// 设置初始值
servletContext.setAttribute("count", 0);
} public void contextDestroyed(ServletContextEvent sce) {
/* This method is invoked when the Servlet Context
(the Web application) is undeployed or
Application Server shuts down.
*/
} // -------------------------------------------------------
// HttpSessionListener implementation
// -------------------------------------------------------
public void sessionCreated(HttpSessionEvent se) {
/* Session is created. */
ServletContext servletContext = se.getSession().getServletContext();
// 获取servletContext对象count属性
int count = (int)servletContext.getAttribute("count");
// +1之后设置回去
servletContext.setAttribute("count", ++count);
} public void sessionDestroyed(HttpSessionEvent se) {
/* Session is destroyed. */
ServletContext servletContext = se.getSession().getServletContext();
// 获取servletContext对象count属性
int count = (int)servletContext.getAttribute("count");
// -1之后设置回去
servletContext.setAttribute("count", --count);
} // -------------------------------------------------------
// HttpSessionAttributeListener implementation
// ------------------------------------------------------- public void attributeAdded(HttpSessionBindingEvent sbe) {
/* This method is called when an attribute
is added to a session.
*/
} public void attributeRemoved(HttpSessionBindingEvent sbe) {
/* This method is called when an attribute
is removed from a session.
*/
} public void attributeReplaced(HttpSessionBindingEvent sbe) {
/* This method is invoked when an attibute
is replaced in a session.
*/
}
}

java项目实践-jsp-filter-监听器-day19的更多相关文章

  1. 一次从0到1的java项目实践清单

    虽说工作就是简单的事情重复做,但不是所有简单的事你都能有机会做的. 我们平日工作里,大部分时候都是在做修修补补的工作,而这也是非常重要的.做好修补工作,做好优化工作,足够让你升职加薪! 但是如果有机会 ...

  2. 一份从0到1的java项目实践清单

    虽说工作就是简单的事情重复做,但不是所有简单的事你都能有机会做的. 我们平日工作里,大部分时候都是在做修修补补的工作,而这也是非常重要的.做好修补工作,做好优化工作,足够让你升职加薪! 但是如果有机会 ...

  3. Java项目在jsp页面中引入jquery框架的步骤

    环境:在Java  web项目中引入juqery框架 工具:MyEclipse8.5 [步骤如下] A:新建一个Java web项目TestJquery,在WebRoot目录下创建一个jquery文件 ...

  4. 【java项目实践】具体解释Ajax工作原理以及实现异步验证username是否存在+源代码下载(java版)

    一年前,从不知道Ajax是什么,伴随着不断的积累,到如今常常使用,逐渐有了深入的认识. 今天,假设想开发一个更加人性化,友好,无刷新,交互性更强的网页,那您的目标一定是Ajax. 介绍 在具体讨论Aj ...

  5. SuperDiamond在JAVA项目中的三种应用方法实践总结

    SuperDiamond在JAVA项目中的三种应用方法实践总结 1.直接读取如下: @Test public static void test_simple(){ PropertiesConfigur ...

  6. java 项目 导入成功后jsp页面报错处理方法

    本人新导入一个maven项目可是jsp页面一直报错,我先按照网上的经验操作如下步骤: 在pom.xml配置文件中添加上javax.servlet的相关依赖: <dependency>  & ...

  7. Java项目案例之---登录和修改(JSP)

    登录和修改(JSP) 通过案例学习jsp的常用知识点: 1.创建一个Map集合,用于存放学生信息,将学生信息存入Map中 2.通过page将需要的包导入 3.用request.getParameter ...

  8. Java项目经验

    Java项目经验 转自CSDN. Java就是用来做项目的!Java的主要应用领域就是企业级的项目开发!要想从事企业级的项目开发,你必须掌握如下要点:1.掌握项目开发的基本步骤2.具备极强的面向对象的 ...

  9. 【项目实践】手把手带你搞定SSM

    以项目驱动学习,以实践检验真知 前言 现在使用Java后端开发使用的技术栈基本上比较统一:Spring + SpringMVC + Mybatis,即大家常说的SSM.虽然现在流行的做法是使用Spri ...

  10. Java项目打包方式分析

    [TOC] 概述 在项目实践过程中,有个需求需要做一个引擎能执行指定jar包的指定main方法. 起初我们以一个简单的spring-boot项目进行测试,使用spring-boot-maven-plu ...

随机推荐

  1. MybatisPlus条件查询方法全解

    1.是什么? MybatisPlus通过条件构造器可以组装复杂的查询条件,写一些复杂的SQL语句,从而简化我们的开发提升我们的开发效率 # 可以简单的理解为就是我们写SQL语句时where后面的条件 ...

  2. 数据智慧:C#中编程实现自定义计算的Excel数据透视表

    前言 数据透视表(Pivot Table)是一种数据分析工具,通常用于对大量数据进行汇总.分析和展示.它可以帮助用户从原始数据中提取关键信息.发现模式和趋势,并以可视化的方式呈现. 在数据透视表中,数 ...

  3. Chrome扩展程序是如何进行消息传递的

    大家好,我是 dom 哥.这是我关于 Chrome 扩展开发的系列文章,感兴趣的可以 点个小星星. 一个复杂的 Chrome 扩展程序通常由 content_scripts,background,ac ...

  4. ASR项目实战-交付过程中遇到的内核崩溃问题

    当前参与交付的语音识别产品服务,算法模块基于经典的Kaldi,算法中的一部分运行在GPU之上. 算法团队采用的是声学模型+语言模型的1-pass方案.这个方案的特点在于,语言模型数据文件(HCLG文件 ...

  5. 基于Docker 部署 Seafile+OnlyOffice+Wiki插件

    原文:基于 Docker 部署 SeafilePro + OnlyOffice(CentOS版) 官方文档:用 Docker 部署 Seafile 服务 CentOS 服务器 基于 Docker 部署 ...

  6. Win10 SFC& Dism修复系统

    在Win10开始按钮上点击右键(或按Win + X快捷键),在弹出的系统快捷菜单中点击  Windows PowerShell(管理员)或者  命令提示符CMD (管理员) 方法 1 SFC输入&qu ...

  7. Java并发(二十二)----wait notify的正确姿势

    开始之前先看看,sleep(long n) 和 wait(long n) 的区别: 1) sleep 是 Thread 的静态方法,而 wait 是 Object 的方法 2) sleep 不需要强制 ...

  8. Triple DES 加密解密技术解析

    摘要:本文介绍了Triple DES加密解密技术,通过实例演示了加密和解密过程,并对算法原理进行了简要分析.同时,探讨了Triple DES在现代信息安全领域的应用和局限性. 3DES(Triple ...

  9. vscode搜索卡顿

    解决vscode搜索,编辑器卡死问题

  10. 面向对象的Python编程,你需要知道这些!

    摘要:Python 没有像 java 中的"private"这样的访问说明符.除了强封装外,它支持大多数与"面向对象"编程语言相关的术语.因此它不是完全面向对象 ...