java项目实践-jsp-filter-监听器-day19
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的更多相关文章
- 一次从0到1的java项目实践清单
虽说工作就是简单的事情重复做,但不是所有简单的事你都能有机会做的. 我们平日工作里,大部分时候都是在做修修补补的工作,而这也是非常重要的.做好修补工作,做好优化工作,足够让你升职加薪! 但是如果有机会 ...
- 一份从0到1的java项目实践清单
虽说工作就是简单的事情重复做,但不是所有简单的事你都能有机会做的. 我们平日工作里,大部分时候都是在做修修补补的工作,而这也是非常重要的.做好修补工作,做好优化工作,足够让你升职加薪! 但是如果有机会 ...
- Java项目在jsp页面中引入jquery框架的步骤
环境:在Java web项目中引入juqery框架 工具:MyEclipse8.5 [步骤如下] A:新建一个Java web项目TestJquery,在WebRoot目录下创建一个jquery文件 ...
- 【java项目实践】具体解释Ajax工作原理以及实现异步验证username是否存在+源代码下载(java版)
一年前,从不知道Ajax是什么,伴随着不断的积累,到如今常常使用,逐渐有了深入的认识. 今天,假设想开发一个更加人性化,友好,无刷新,交互性更强的网页,那您的目标一定是Ajax. 介绍 在具体讨论Aj ...
- SuperDiamond在JAVA项目中的三种应用方法实践总结
SuperDiamond在JAVA项目中的三种应用方法实践总结 1.直接读取如下: @Test public static void test_simple(){ PropertiesConfigur ...
- java 项目 导入成功后jsp页面报错处理方法
本人新导入一个maven项目可是jsp页面一直报错,我先按照网上的经验操作如下步骤: 在pom.xml配置文件中添加上javax.servlet的相关依赖: <dependency> & ...
- Java项目案例之---登录和修改(JSP)
登录和修改(JSP) 通过案例学习jsp的常用知识点: 1.创建一个Map集合,用于存放学生信息,将学生信息存入Map中 2.通过page将需要的包导入 3.用request.getParameter ...
- Java项目经验
Java项目经验 转自CSDN. Java就是用来做项目的!Java的主要应用领域就是企业级的项目开发!要想从事企业级的项目开发,你必须掌握如下要点:1.掌握项目开发的基本步骤2.具备极强的面向对象的 ...
- 【项目实践】手把手带你搞定SSM
以项目驱动学习,以实践检验真知 前言 现在使用Java后端开发使用的技术栈基本上比较统一:Spring + SpringMVC + Mybatis,即大家常说的SSM.虽然现在流行的做法是使用Spri ...
- Java项目打包方式分析
[TOC] 概述 在项目实践过程中,有个需求需要做一个引擎能执行指定jar包的指定main方法. 起初我们以一个简单的spring-boot项目进行测试,使用spring-boot-maven-plu ...
随机推荐
- MybatisPlus条件查询方法全解
1.是什么? MybatisPlus通过条件构造器可以组装复杂的查询条件,写一些复杂的SQL语句,从而简化我们的开发提升我们的开发效率 # 可以简单的理解为就是我们写SQL语句时where后面的条件 ...
- 数据智慧:C#中编程实现自定义计算的Excel数据透视表
前言 数据透视表(Pivot Table)是一种数据分析工具,通常用于对大量数据进行汇总.分析和展示.它可以帮助用户从原始数据中提取关键信息.发现模式和趋势,并以可视化的方式呈现. 在数据透视表中,数 ...
- Chrome扩展程序是如何进行消息传递的
大家好,我是 dom 哥.这是我关于 Chrome 扩展开发的系列文章,感兴趣的可以 点个小星星. 一个复杂的 Chrome 扩展程序通常由 content_scripts,background,ac ...
- ASR项目实战-交付过程中遇到的内核崩溃问题
当前参与交付的语音识别产品服务,算法模块基于经典的Kaldi,算法中的一部分运行在GPU之上. 算法团队采用的是声学模型+语言模型的1-pass方案.这个方案的特点在于,语言模型数据文件(HCLG文件 ...
- 基于Docker 部署 Seafile+OnlyOffice+Wiki插件
原文:基于 Docker 部署 SeafilePro + OnlyOffice(CentOS版) 官方文档:用 Docker 部署 Seafile 服务 CentOS 服务器 基于 Docker 部署 ...
- Win10 SFC& Dism修复系统
在Win10开始按钮上点击右键(或按Win + X快捷键),在弹出的系统快捷菜单中点击 Windows PowerShell(管理员)或者 命令提示符CMD (管理员) 方法 1 SFC输入&qu ...
- Java并发(二十二)----wait notify的正确姿势
开始之前先看看,sleep(long n) 和 wait(long n) 的区别: 1) sleep 是 Thread 的静态方法,而 wait 是 Object 的方法 2) sleep 不需要强制 ...
- Triple DES 加密解密技术解析
摘要:本文介绍了Triple DES加密解密技术,通过实例演示了加密和解密过程,并对算法原理进行了简要分析.同时,探讨了Triple DES在现代信息安全领域的应用和局限性. 3DES(Triple ...
- vscode搜索卡顿
解决vscode搜索,编辑器卡死问题
- 面向对象的Python编程,你需要知道这些!
摘要:Python 没有像 java 中的"private"这样的访问说明符.除了强封装外,它支持大多数与"面向对象"编程语言相关的术语.因此它不是完全面向对象 ...