早期javeweb技术 JSP JDBC JSTJ Servlet BooStrap

你好,我是Qiuner. 为记录自己编程学习过程和帮助别人少走弯路而写博客 这是我的 github gitee

如果本篇文章帮到了你 不妨点个赞吧~ 我会很高兴的 😄 (^ ~ ^)

想看更多 那就点个关注吧 我会尽力带来有趣的内容

  • jar包放在web-web-inf中

Boot strap框架

image-20230925174239682

image-20230926145307531

  • container是两边留白
  • container-fluid是每种设备都100%宽度

image-20230926145639211

  • 剩下的去看开发文档就好

XML

image-20230926150548069

image-20230926150717232

image-20230926151058425

Servlet技术

  • 翻译为 小服务程序
  • 用来处理http请求和生成http相应的一个接口
  • 可以有多个servlet,因为不同的网址需要不同的servlet来处理:比如访问https://www.baidu.com/是一个servlet来处理,访问https://www.baidu.com/11 是另一个来处理
  • 是一个继承了servlet的类

image-20230926152037109

  • 使用servlet来指定要访问继承了Servlet的java类的位置与名字。
  • 使用servlet—mapping指定访问的具体地址

image-20231007110031802

  • 访问demo1时,服务器打印

image-20231007110109022

image-20230926152143052

image-20230926154832431

执行原理与生命周期

  • 可以有多个servlet来处理不同的请求,但同一个请求只会有一个servlet

image-20230926160108423

image-20230926160037232

image-20231007111153054

子类与具体应用

image-20231007112825376 image-20231007112924582

  • 使用Httpservlet的可以对不同的请求方式做出不同的反应,省去了编写判断请求方式来不同响应的步骤
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>使用表单来实现不同的请求方式</title>
</head>
<body>
<form action="demo" method="post"><input name="username"><input type="submit" value="提交">
</form>
</body>
</html>

注解的使用

  • 可以使用 * 来使得无论输入什么都可以访问。
  • *.do表示后缀一定要是do才能访问到

Http

HTTP协议

* 概念:Hyper Text Transfer Protocol 超文本传输协议* 传输协议:定义了,客户端和服务器端通信时,发送数据的格式* 特点:1. 基于TCP/IP的高级协议2. 默认端口号:803. 基于请求/响应模型的:一次请求对应一次响应4. 无状态的:每次请求之间相互独立,不能交互数据* 历史版本:* 1.0:每一次请求响应都会建立新的连接* 1.1:复用连接* 请求消息数据格式1. 请求行请求方式 请求url 请求协议/版本GET /login.html	HTTP/1.1* 请求方式:* HTTP协议有7中请求方式,常用的有2种* GET:1. 请求参数在请求行中,在url后。2. 请求的url长度有限制的3. 不太安全* POST:1. 请求参数在请求体中2. 请求的url长度没有限制的3. 相对安全2. 请求头:客户端浏览器告诉服务器一些信息请求头名称: 请求头值* 常见的请求头:1. User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息* 可以在服务器端获取该头的信息,解决浏览器的兼容性问题2. Referer:http://localhost/login.html* 告诉服务器,我(当前请求)从哪里来?* 作用:1. 防盗链:通过判断请求来源防止盗链2. 统计工作:通过判断实现3. 请求空行空行,就是用于分割POST请求的请求头,和请求体的。4. 请求体(正文):* 封装POST请求消息的请求参数的* 字符串格式:POST /login.html	HTTP/1.1Host: localhostUser-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2Accept-Encoding: gzip, deflateReferer: http://localhost/login.htmlConnection: keep-aliveUpgrade-Insecure-Requests: 1username=zhangsan	

Referer请求头

  • 使用Referer来防止盗链

Request

image-20231007161715711

获取请求传递的参数
request对象和response对象的原理
request和response对象是由服务器创建的。我们来使用它们
request对象是来获取请求消息,response对象是来设置响应消息
request对象继承体系结构:	ServletRequest		--	接口|	继承HttpServletRequest	-- 接口|	实现org.apache.catalina.connector.RequestFacade(tomcat编写)
request功能:1. 获取请求消息数据1. 获取请求行数据//以下是一个请求* GET /day14/demo1?name=zhangsan HTTP/1.1* 方法:1. 获取请求方式 :GET* String getMethod()  2. (*)获取虚拟目录:/day14(重要)* String getContextPath()3. 获取Servlet路径: /demo1* String getServletPath()4. 获取get方式请求参数:name=zhangsan* String getQueryString()5. (*)获取请求URI/day14/demo1(重要)* String getRequestURI():		/day14/demo1* StringBuffer getRequestURL()  :http://localhost/day14/demo1* URL:统一资源定位符 : http://localhost/day14/demo1	中华人民共和国* URI:统一资源标识符 : /day14/demo1					共和国6. 获取协议及版本:HTTP/1.1* String getProtocol()7. 获取客户机的IP地址:* String getRemoteAddr()2. 获取请求头数据* 方法:* (*)String getHeader(String name):通过请求头的名称获取请求头的值(重要)* Enumeration<String> getHeaderNames():获取所有的请求头名称3. 获取请求体数据:* 请求体:只有POST请求方式,才有请求体,在请求体中封装了POST请求的请求参数* 步骤:1. 获取流对象*  BufferedReader getReader():获取字符输入流,只能操作字符数据*  ServletInputStream getInputStream():获取字节输入流,可以操作所有类型数据* 在文件上传知识点后讲解2. 再从流对象中拿数据
解决编码
2. 其他功能:1. 获取请求参数通用方式:不论get还是post请求方式都可以使用下列方法来获取请求参数1. String getParameter(String name):根据参数名称获取参数值    username=zs&password=1232. String[] getParameterValues(String name):根据参数名称获取参数值的数组  hobby=xx&hobby=game//用于复选框3. Enumeration<String> getParameterNames():获取所有请求的参数名称4. Map<String,String[]> getParameterMap():获取所有参数的map集合//把对应的键和值都拿到* 中文乱码问题:* get方式:tomcat 8 已经将get方式乱码问题解决了* post方式:会乱码//在方法执行的时,先设置编码格式* 解决:在获取参数前,设置request的编码request.setCharacterEncoding("utf-8");
//解决编码格式
package demo;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;public class Test2 extends HttpServlet {@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//设置编码格式req.setCharacterEncoding("utf-8");//使用req对象获取请求参数String username= req.getParameter("username");System.out.println();}@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {super.doGet(req, resp);}
}
请求转发
	2. 请求转发:一种在服务器内部的资源跳转方式1. 步骤:1. 通过request对象获取请求转发器对象:RequestDispatcher getRequestDispatcher(String path)2. 使用RequestDispatcher对象来进行转发:forward(ServletRequest request, ServletResponse response) 2. 特点:1. 浏览器地址栏路径不发生变化2. 只能转发到当前服务器内部资源中。3. 转发是一次请求

image-20231107105044955

image-20231107110855880

数据共享

image-20231107112539934

image-20231107112749762

image-20231107113312515

Resopnse

image-20231107145528930

重定向

两种方式

image-20231107145912202

重定向和请求转发的区别

image-20231107150114480

  • 不能数据共享

image-20231107150655597

路径写法

image-20231107151533892

统一字符编码的方式

image-20231107151959162

验证码

image-20231107152844489

image-20231107152934949

image-20231107153058879

  • 验证码切换
servletContext对象

image-20231107153805944

image-20231107161253490

image-20231107161330597

idea

image-20231112173207704

  • 当你修改了这里的webservlet时候,需要重新部署才能生效

会话技术

cookie

在两个servlet中传输的方法,保存在请求对象中,可以有多个cookie

Cookie的原理

Cookie是一种在客户端(浏览器)和服务器之间存储和传递信息的小型文本文件。其原理如下:

  1. 服务器端创建Cookie: 当用户访问一个网站时,服务器可以向用户的浏览器发送一个包含信息的HTTP响应头,其中包括一个Set-Cookie字段。这个字段会包含一个唯一的Cookie标识符以及要存储在Cookie中的数据。
  2. 浏览器存储Cookie: 浏览器接收到Cookie后,将其存储在用户的本地计算机上,通常存储在特定的Cookie文件中。
  3. 浏览器发送Cookie: 每次用户再次访问同一网站时,浏览器都会自动将该网站的Cookie信息包含在HTTP请求头中,发送给服务器。
  4. 服务器读取Cookie: 服务器在接收到HTTP请求时,会读取请求头中的Cookie信息,从中提取出所需的数据。
  5. 服务器响应: 服务器可以根据Cookie中的信息来识别用户或存储用户的状态信息。然后,服务器可以在HTTP响应中使用Set-Cookie字段来更新或创建新的Cookie,以便在以后的请求中使用。

Cookie的用途包括会话管理、用户跟踪、个性化体验等。然而,需要注意的是,Cookie可能引发隐私和安全问题,因此通常会受到浏览器的限制,例如同源策略、Cookie生存期和安全标志等。

image-20231107200622905

image-20231107201040768

image-20231107201409869

image-20231107201430018

  • cookie可以是会话cookie或持久性cookie

image-20231224143406052

  • 和jwt的异同

image-20231224143458878

session

image-20231224151212443

  • 原理:基于cookie实现

image-20231224151555968

  • 细节

    image-20231224152803879

image-20231224152842094

image-20231224153029778

验证码案例

image-20231224171647709

jsp技术

image-20231218215244966

执行的原理与基础标签的使用

image-20231218221724419

当然,下面是用 Markdown 格式解释这三个 JSP 元素的含义:

<% %> - Scriptlet 标签
  • <% %> 用于将 Java 代码片段嵌入到 JSP 文件中。

  • 它允许直接在 JSP 文件中插入 Java 代码,实现诸如循环、条件语句、方法调用等任务。

  • 示例:

    <% String message = "Hello, JSP!";//此处定义的变量是方法变量,可以理解为该标签作用是变成一个方法out.println(message);
    %>
    
<%! %> - 声明标记
  • <%! %> 用于在 servlet 类的主体中定义变量或方法。

  • <%! %> 用于定义在 Servlet 类中的成员变量或方法。在 JSP 被翻译为 Servlet 时,声明部分的内容会放在 Servlet 类的类体中。

  • 声明的变量和方法在整个 JSP 页面的 Servlet 类中都是可见的,可以在其他部分(比如 <% %><%= %>)中使用。

  • 声明的是成员变量

    jspCopy code<%! private int count = 0;public void incrementCount() {count++;}
    %>
    
<%= %> - 表达式标记
  • <%= %> 用于直接将表达式的结果输出到 HTML 响应中。

  • 它直接将表达式的结果输出到客户端的浏览器中。

  • 示例:

    jspCopy code<% String name = "Alice"; %>
    <%= "Hello, " + name %>
    

优先级

image-20231224111850047

指令

image-20231226103411090

image-20231226103520365

  • 这一行里有很多属性,其中就包括errorpage啥的。

image-20231226104003704

image-20231226104233134

MVC开发模式

  • 是开发模式不是设计模式,设计模式只解决一些小的问题

image-20231226105606001

image-20231226105505730

  • javabean是指java类中的get等方法

image-20231226105917743

EL表达式

  • 使用这个表达式是为了更加符合mac开发规范

image-20231226112055852

image-20231226112151018

## 获取字符串

  • 获取存储的值

image-20231226112712182

  • 相当于把代码变成以上形式

image-20231226112724202

image-20231226112822306

  • 按照PageContextRequestSessionApplication

获取对象、集合的值

  • 需要先创建对象

image-20231226164939704

image-20231226164906491

image-20231226165130997

隐式对象

image-20231226165501792

JSTL

image-20231226171653560

image-20231226171341209

image-20231226171539170

image-20231226171744876

image-20231226171813732

三层架构

image-20231226171935408

JDBC

image-20231226210128749

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/1642.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Go语言快速上手(三)】数组, 切片与映射

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:Go语言专栏⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习更多Go语言知识   &#x1f51d;&#x1f51d; GO快速上手 1. 前言2. 数组详解3. 切…

平面设计简介:快速了解

在互联网飞速发展的时代&#xff0c;平面设计仍然是很多设计师的职业选择&#xff0c;平面设计也被称为设计的启蒙星。平面设计是什么&#xff0c;无论是想转行进入平面设计行业还是平面设计新秀&#xff1f;什么是平面设计&#xff1f;只有了解这一点&#xff0c;我们才能在未…

制造业信息安全实践——企业信息安全运营规划

前言 制造业作为一个庞大的传统产业&#xff0c;涵盖了汽车、船舶、飞机、家电、新能源等众多领域。当前&#xff0c;无论是国内还是国外的制造业都面临着一个共同的挑战&#xff1a;在计算机和信息时代的背景下&#xff0c;如何跟上IT技术的发展步伐&#xff1f;如何让传统产…

4月21日Linux运维用户相关的添加,分组,修改权限等shell脚本开发第一天

4月21日运维用户相关的添加&#xff0c;分组&#xff0c;修改权限等shell脚本开发第一天 第一天主要实现前2个功能 ​ 主要卡在了&#xff1a; 正确的写法如下&#xff0c;注意[]中的空格&#xff0c;要求很严格&#xff01;&#xff01;&#xff01; #!/bin/bash # 先查看已…

抖音ip地址怎么换位置

抖音&#xff0c;作为一款短视频分享平台&#xff0c;已经成为了许多人展示生活、分享才艺的重要舞台。然而&#xff0c;在抖音的使用过程中&#xff0c;你是否想过更换自己的IP地址位置呢&#xff1f;更换IP地址不仅可以帮助你访问一些地域限制的内容&#xff0c;还可以为你的…

micro-app的css样式隔离

手写微前端micro-app-CSS隔离 子应用的CSS可能会对基座应用或者其他子应用产生的影响 首先现在我们把react页面放入到vue2的页面大家也能看到一些问题了&#xff0c;在react中的index.css中对body的一些css样式&#xff0c;已经影响了基座应用的css。 为了看的更明显&#x…

RabbitMQ学习记录

核心概念 Brocker&#xff1a;消息队列服务器实体 Exchange(消息交换机)&#xff1a;它指定消息按什么规则&#xff0c;路由到哪个队列。 Queue(消息队列载体)&#xff1a;每个消息都会被投入到一个或多个队列。 Binding(绑定)&#xff1a;它的作用就是把exchange和queue按…

提示框增加HTML效果

预期效果&#xff1a;this.$modal.confirm(是否确认删除该条基础设施数据项&#xff1f;请注意删除该路口基础设施点位将并带删除点位下的所有设施)将两句话换行显示且第二句话字体变为红色 官方案例&#xff1a; this.$alert(<strong>这是 <i>HTML</i> 片段…

【团体程序设计天梯赛】L2-052 吉利矩阵

思路&#xff1a; 直接回溯枚举每一个位置填的数&#xff0c;二维肯定是不方便的&#xff0c;我们转成一维&#xff0c;下标x从0到n*n-1。二维数组下标从0到n-1&#xff0c;在一维中下标为x的点在二维中对应行是x/n&#xff0c;列是x%n。 每个数最小能填的是0&#xff0c;最大…

Allegro 导入 EMN 文件,报错“WARNING(SPMHXL-48)”

问题描述&#xff1a; Allegro–> Import–> IDF 导入ME 生成的emn文件&#xff0c;总是出现如下警告&#xff1a; “WARNING(SPMHXL-48): There is existing geometry on Board Geometry / Outline.This geometry may conflict with the IDF data.Review the board out…

【开发篇】本章包括消息订阅、客服配置与使用实战(小程序之云函数开发入门到使用发布上线实操)

客服回复效果图展示 消息订阅效果图展示 一、客服配置 客服消息使用指南传送门 <button open-type="contact" class="fab" ><view class="item"

文本嵌入新方案:合合信息acge模型荣登C-MTEB榜首

目录 0 写在前面1 文本嵌入&#xff1a;LLM落地的根基2 C-MTEB&#xff1a;acge荣夺榜一2.1 max tokens2.2 文本分类2.3 文本聚类 3 acge demo演示与体验总结 0 写在前面 随着信息技术的发展和应用场景的不断扩大&#xff0c;人们需要处理和利用大量的文档信息。而传统的手动处…

C语言实现贪吃蛇项目(2)

先来看看效果&#xff1a; 20240420_212115 文章目录&#xff1a; 3.项目实现3.0宽字符的打印3.01本地化操作setlocale函数宽字符的打印 3.1贪吃蛇结构的创建和维护3.11贪吃蛇结构的创建3.12贪吃蛇的维护 3.2初始化游戏3.21.打印欢迎界面、隐藏光标和设置窗口大小3.22.绘制地图…

js作业微博发言

微博 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv"X-UA-Compatible" content&q…

《星尘传说》游戏完整源码(源码+引擎+客户端+服务端+教程+工具),云盘下载

《星尘传说》是一款奇幻类大型多人在线角色扮演电脑客户端游戏&#xff0c;该游戏设置有两大阵营&#xff0c;六个国家以及22个职业&#xff0c;采用3D卡通风格&#xff0c; 有兴趣的&#xff0c;可以架设个外网&#xff0c;让大家一起玩。 《星尘传说》游戏完整源码&#xff0…

【JAVA进阶篇教学】第三篇:JDK8中Stream API使用

博主打算从0-1讲解下java进阶篇教学&#xff0c;今天教学第三篇&#xff1a;JDK8中Stream API使用。 Java 8 中的 Stream API 提供了一种便捷、高效的方式来处理集合数据&#xff0c;它支持函数式编程风格的操作&#xff0c;包括过滤、映射、归约等。Stream API 可以大大简化集…

【LAMMPS学习】八、基础知识(3.6)计算热导率

8. 基础知识 此部分描述了如何使用 LAMMPS 为用户和开发人员执行各种任务。术语表页面还列出了 MD 术语&#xff0c;以及相应 LAMMPS 手册页的链接。 LAMMPS 源代码分发的 examples 目录中包含的示例输入脚本以及示例脚本页面上突出显示的示例输入脚本还展示了如何设置和运行各…

c语言利用控制台实现贪吃蛇

使用控制台实现贪吃蛇需要的技能加点&#xff1a; 控制台设置&#xff08;包含于stdlib.h&#xff09;&#xff1a; 定义命令行窗口高/宽&#xff1a; system("mode con cols100 lines30"); system() 函数是一个C标准库函数&#xff0c;它允许程序执行操作系统命令…

(九) 盘古UI,日期和时间选择控件,自定义多种场景!

(九) 盘古UI,日期和时间选择控件,自定义多种场景! 盘古UI,较为全面的自定义UI框架,帮助你绝对的快速开发!(长期维护中) 控件位置: 主要控件: com.smart.pangu_ui_lib.widget.PanguSelectDateView 内部使用的时间弹窗:pop: com.smart.pangu_ui_lib.pop.PopSelectDate demo地址…

nginx反向代理.NetCore开发的基于WebApi创建的gRPC服务

一、本文中使用的工具: Vs2022使用.NET 8.0开发基于ASP.NET Core WebApi的gRPC服务; Nginx:1.25.5,下载地址:http://nginx.org/en/download.html 二、gRPC介绍: 由 google 开发,是一款语言中立、平台中立、开源的远程过程调用(RPC)系统。在vs2022中可以直接创建gRP…