JSP

1、JSP 使用和python的模板语言差不多都是{% %},内部是java语言
{%
out.println("123")
%}
2、
JSP: java语言 开发效率高 MVC架构
PHP: c和perl语言,appache+ php +mysql 效率高 结构上有缺陷
ASP: vb相似 ASP +COM + SQLSERVER 微软自带的
3、配置找不到tomcat
1、打开setting直接搜索tomcat,然后勾选上,apply ok 重启idea
2、然后编辑配置,就可以看见了
配置项目输出目录:
在web-inf下创建classes和lib
File -> Project Structure (快捷键:Ctrl + Shift + Alt + S) -> 选择Module
path配置classes,两个都要配置
依赖depend配置lib,点击+,选1jar,选jar文件夹
配置tomcat和项目:
1-选择项目jave EE 勾选web
2-jsp在index.jsp上写
3-需要先启动tomcat
4-Run -> Edit Configurations,进入"Run/Debug Configurations"窗口 -> 选择刚刚建立的Tomcat容器 -> 选择Deployment -> 点击右边的“+”号 -> 选择Artifact
找不到servlet.http 原因没有引入tomcat的lib下的servlet-api.jar
解决方案:File -> Project Structure->models->dependencies->+->2library->tomcat->"OK"
标红WebServlet
原因,没添加头文件
部署WebServlet
1、写HelloWorld源文件
2、编译,在classes中生成.class
3、在web.xml添加
<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">
<servlet>
<servlet-name>HelloWorld</servlet-name>
<servlet-class>HelloWorld</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>HelloWorld</servlet-name>
<url-pattern>/HelloWorld</url-pattern>
</servlet-mapping>
</web-app>
4、在HelloWorld加上@WebServlet("/HelloWorld"),一定要加上导入WebServlet。。。。。。
5、在浏览器输入http://localhost:8080/hello/HelloWorld
4、JSP代码写在哪里?
JSP代码直接写在index.jsp ....jsp中,jspInit jspDestory 代码写在<%!%> _jspServer 写在<%...%>中 html输出写<%= ....%>
服务器输出写在out.println()
servlet代码卸载哪里
写在src中的类中
5、JSP语法
1、<% 代码片段 %>
2、<jsp:scriptlet>
代码片段
</jsp:scriptlet>
3、任何文本、HTML标签、JSP元素必须写在脚本程序的外面。
JSP声明:
<%!....%> 变量声明,方法
JSP表达式
<%= .... %>会表示出来
JSP注释:
<%--注释--%> jsp注释
<!--注释--> html注释
<\% 就是常量“<%”
\' 单引号
JSP指令
<%@ page ... %> 定义页面的依赖属性,比如脚本语言、error页面、缓存需求等等
<%@ include ... %> 包含其他文件
<%@ taglib ... %> 引入标签库的定义,可以是自定义标签
JSP行为
<jsp:action_name attribute="value" />
jsp:include 用于在当前页面中包含静态或动态资源
jsp:useBean 寻找和初始化一个JavaBean组件
jsp:setProperty 设置 JavaBean组件的值
jsp:getProperty 将 JavaBean组件的值插入到 output中
jsp:forward 从一个JSP文件向另一个文件传递一个包含用户请求的request对象
jsp:plugin 用于在生成的HTML页面中包含Applet和JavaBean对象
jsp:element 动态创建一个XML元素
jsp:attribute 定义动态创建的XML元素的属性
jsp:body 定义动态创建的XML元素的主体
jsp:text 用于封装模板数据
JSP隐含对象
对象 描述
request HttpServletRequest类的实例
response HttpServletResponse类的实例
out PrintWriter类的实例,用于把结果输出至网页上
session HttpSession类的实例
application ServletContext类的实例,与应用上下文有关
config ServletConfig类的实例
pageContext PageContext类的实例,提供对JSP页面所有对象以及命名空间的访问
page 类似于Java类中的this关键字
Exception Exception类的对象,代表发生错误的JSP页面中对应的异常对象
JSP 九大对象、七大动作、三大指令
https://blog.csdn.net/u010897406/article/details/49618413
控制流语句
和Django模板语言一样,只不过Django用的是python,这里用的是java
JSP指令
Page指令
<%@ page attribute="value" %>
<jsp:directive.page attribute="value" />
属性 描述
buffer 指定out对象使用缓冲区的大小
autoFlush 控制out对象的 缓存区
contentType 指定当前JSP页面的MIME类型和字符编码
errorPage 指定当JSP页面发生异常时需要转向的错误处理页面
isErrorPage 指定当前页面是否可以作为另一个JSP页面的错误处理页面
extends 指定servlet从哪一个类继承
import 导入要使用的Java类
info 定义JSP页面的描述信息
isThreadSafe 指定对JSP页面的访问是否为线程安全
language 定义JSP页面所用的脚本语言,默认是Java
session 指定JSP页面是否使用session
isELIgnored 指定是否执行EL表达式
isScriptingEnabled 确定脚本元素能否被使用

JSP 语法
<%@ page
[ language="java" ]
[ extends="package.class" ]
[ import="{package.class | package.*}, ..." ]
[ session="true | false" ]
[ buffer="none | 8kb | sizekb" ]
[ autoFlush="true | false" ]
[ isThreadSafe="true | false" ]
[ info="text" ]
[ errorPage="relativeURL" ]
[ contentType="mimeType [ ;charset=characterSet ]" | "text/html ; charset=ISO-8859-1" ]
[ isErrorPage="true | false" ]
%>
Include指令
<%@ include file="文件相对 url 地址" %>
<jsp:directive.include file="文件相对 url 地址" />
Taglib指令
<%@ taglib uri="uri" prefix="prefixOfTag" %>
<jsp:directive.taglib uri="uri" prefix="prefixOfTag" />
讲解怎么配置标签https://blog.csdn.net/hry1243916844/article/details/70665259
JSP动作
<jsp:include>
<jsp:include page="相对 URL 地址" flush="true" />
page 包含在页面中的相对URL地址。
flush 布尔属性,定义在包含资源前是否刷新缓存区。
<jsp:useBean>动作元素
<jsp:useBean id="name" class="package.class" />
属性 描述
class 指定Bean的完整包名。
type 指定将引用该对象变量的类型。
beanName 通过 java.beans.Beans 的 instantiate() 方法指定Bean的名字。
讲解:https://blog.csdn.net/chickenbro_/article/details/80829343
先把setproperty 赋值,property中指定谁,谁被赋值,如果有value就是赋值value,
然后通过getproperty获取
<jsp:setProperty>动作元素
<jsp:useBean id="myName" ... >
<jsp:setProperty name="myName" property="someProperty" .../>
jsp:getProperty
<jsp:forward> 动作元素
<jsp:forward page="相对 URL 地址" />
<jsp:plugin>动作元素
<jsp:plugin type="applet" codebase="dirname" code="MyApplet.class" width="60" height="80">
<jsp:param name="fontcolor" value="red" />
<jsp:element> 、 <jsp:attribute>、 <jsp:body>动作元素
<jsp:element name="xmlElement">
<jsp:attribute name="xmlElementAttr">
属性值
</jsp:attribute>
<jsp:body>
XML 元素的主体
</jsp:body>
</jsp:element>
<jsp:text>动作元素
<jsp:text>模板数据</jsp:text> 允许在JSP页面和文档中使用写入文本的模板
几个动作:https://blog.csdn.net/qq_29028175/article/details/53729048 ☆☆☆☆☆☆☆☆☆
JSP 客户端请求
信息 描述
Accept 指定浏览器或其他客户端可以处理的MIME类型。它的值通常为 image/png 或 image/jpeg
Accept-Charset 指定浏览器要使用的字符集。比如 ISO-8859-1
Accept-Encoding 指定编码类型。它的值通常为 gzip 或compress
Accept-Language 指定客户端首选语言,servlet会优先返回以当前语言构成的结果集,如果servlet支持这种语言的话。比如 en,en-us,ru等等
Authorization 在访问受密码保护的网页时识别不同的用户
Connection 表明客户端是否可以处理HTTP持久连接。持久连接允许客户端或浏览器在一个请求中获取多个文件。Keep-Alive 表示启用持久连接
Content-Length 仅适用于POST请求,表示 POST 数据的字节数
Cookie 返回先前发送给浏览器的cookies至服务器
Host 指出原始URL中的主机名和端口号
If-Modified-Since 表明只有当网页在指定的日期被修改后客户端才需要这个网页。 服务器发送304码给客户端,表示没有更新的资源
If-Unmodified-Since 与If-Modified-Since相反, 只有文档在指定日期后仍未被修改过,操作才会成功
Referer 标志着所引用页面的URL。比如,如果你在页面1,然后点了个链接至页面2,那么页面1的URL就会包含在浏览器请求页面2的信息头中
User-Agent 用来区分不同浏览器或客户端发送的请求,并对不同类型的浏览器返回不同的内容
HttpServletRequest类
序号 方法& 描述
1 Cookie[] getCookies() 返回客户端所有的Cookie的数组
2 Enumeration getAttributeNames() 返回request对象的所有属性名称的集合
3 Enumeration getHeaderNames() 返回所有HTTP头的名称集合
4 Enumeration getParameterNames() 返回请求中所有参数的集合
5 HttpSession getSession() 返回request对应的session对象,如果没有,则创建一个
6 HttpSession getSession(boolean create) 返回request对应的session对象,如果没有并且参数create为true,则返回一个新的session对象
7 Locale getLocale() 返回当前页的Locale对象,可以在response中设置
8 Object getAttribute(String name) 返回名称为name的属性值,如果不存在则返回null。
9 ServletInputStream getInputStream() 返回请求的输入流
10 String getAuthType() 返回认证方案的名称,用来保护servlet,比如 "BASIC" 或者 "SSL" 或 null 如果 JSP没设置保护措施
11 String getCharacterEncoding() 返回request的字符编码集名称
12 String getContentType() 返回request主体的MIME类型,若未知则返回null
13 String getContextPath() 返回request URI中指明的上下文路径
14 String getHeader(String name) 返回name指定的信息头
15 String getMethod() 返回此request中的HTTP方法,比如 GET,,POST,或PUT
16 String getParameter(String name) 返回此request中name指定的参数,若不存在则返回null
17 String getPathInfo() 返回任何额外的与此request URL相关的路径
18 String getProtocol() 返回此request所使用的协议名和版本
19 String getQueryString() 返回此 request URL包含的查询字符串
20 String getRemoteAddr() 返回客户端的IP地址
21 String getRemoteHost() 返回客户端的完整名称
22 String getRemoteUser() 返回客户端通过登录认证的用户,若用户未认证则返回null
23 String getRequestURI() 返回request的URI
24 String getRequestedSessionId() 返回request指定的session ID
25 String getServletPath() 返回所请求的servlet路径
26 String[] getParameterValues(String name) 返回指定名称的参数的所有值,若不存在则返回null
27 boolean isSecure() 返回request是否使用了加密通道,比如HTTPS
28 int getContentLength() 返回request主体所包含的字节数,若未知的返回-1
29 int getIntHeader(String name) 返回指定名称的request信息头的值
30 int getServerPort() 返回服务器端口号
JSP 服务器响应
响应头 描述
Allow 指定服务器支持的request方法(GET,POST等等)
Cache-Control 指定响应文档能够被安全缓存的情况。通常取值为 public,private 或no-cache 等等。 Public意味着文档可缓存,Private意味着文档只为单用户服务并且只能使用私有缓存。No-cache 意味着文档不被缓存。
Connection 命令浏览器是否要使用持久的HTTP连接。close值 命令浏览器不使用持久HTTP连接,而keep-alive 意味着使用持久化连接。
Content-Disposition 让浏览器要求用户将响应以给定的名称存储在磁盘中
Content-Encoding 指定传输时页面的编码规则
Content-Language 表述文档所使用的语言,比如en, en-us,,ru等等
Content-Length 表明响应的字节数。只有在浏览器使用持久化 (keep-alive) HTTP 连接时才有用
Content-Type 表明文档使用的MIME类型
Expires 指明啥时候过期并从缓存中移除
Last-Modified 指明文档最后修改时间。客户端可以 缓存文档并且在后续的请求中提供一个 If-Modified-Since请求头
Location 在300秒内,包含所有的有一个状态码的响应地址,浏览器会自动重连然后检索新文档
Refresh 指明浏览器每隔多久请求更新一次页面。
Retry-After 与503 (Service Unavailable)一起使用来告诉用户多久后请求将会得到响应
Set-Cookie 指明当前页面对应的cookie

HttpServletResponse类
S.N. 方法 & 描述
1 String encodeRedirectURL(String url) 对sendRedirect()方法使用的URL进行编码
2 String encodeURL(String url) 将URL编码,回传包含Session ID的URL
3 boolean containsHeader(String name) 返回指定的响应头是否存在
4 boolean isCommitted() 返回响应是否已经提交到客户端
5 void addCookie(Cookie cookie) 添加指定的cookie至响应中
6 void addDateHeader(String name, long date) 添加指定名称的响应头和日期值
7 void addHeader(String name, String value) 添加指定名称的响应头和值
8 void addIntHeader(String name, int value) 添加指定名称的响应头和int值
9 void flushBuffer() 将任何缓存中的内容写入客户端
10 void reset() 清除任何缓存中的任何数据,包括状态码和各种响应头
11 void resetBuffer() 清除基本的缓存数据,不包括响应头和状态码
12 void sendError(int sc) 使用指定的状态码向客户端发送一个出错响应,然后清除缓存
13 void sendError(int sc, String msg) 使用指定的状态码和消息向客户端发送一个出错响应
14 void sendRedirect(String location) 使用指定的URL向客户端发送一个临时的间接响应
15 void setBufferSize(int size) 设置响应体的缓存区大小
16 void setCharacterEncoding(String charset) 指定响应的编码集(MIME字符集),例如UTF-8
17 void setContentLength(int len) 指定HTTP servlets中响应的内容的长度,此方法用来设置 HTTP Content-Length 信息头
18 void setContentType(String type) 设置响应的内容的类型,如果响应还未被提交的话
19 void setDateHeader(String name, long date) 使用指定名称和值设置响应头的名称和内容
20 void setHeader(String name, String value) 使用指定名称和值设置响应头的名称和内容
21 void setIntHeader(String name, int value) 指定 int 类型的值到 name 标头
22 void setLocale(Locale loc) 设置响应的语言环境,如果响应尚未被提交的话
23 void setStatus(int sc) 设置响应的状态码
JSP HTTP 状态码
状态码 消息 描述
100 Continue 只有一部分请求被服务器接收,但只要没被服务器拒绝,客户端就会延续这个请求
101 Switching Protocols 服务器交换机协议
200 OK 请求被确认
201 Created 请求时完整的,新的资源被创建
202 Accepted 请求被接受,但未处理完
203 Non-authoritative Information
204 No Content
205 Reset Content
206 Partial Content
300 Multiple Choices 一个超链接表,用户可以选择一个超链接并访问,最大支持5个超链接
301 Moved Permanently 被请求的页面已经移动到了新的URL下
302 Found 被请求的页面暂时性地移动到了新的URL下
303 See Other 被请求的页面可以在一个不同的URL下找到
304 Not Modified
305 Use Proxy
306 Unused 已经不再使用此状态码,但状态码被保留
307 Temporary Redirect 被请求的页面暂时性地移动到了新的URL下
400 Bad Request 服务器无法识别请求
401 Unauthorized 被请求的页面需要用户名和密码
402 Payment Required 目前还不能使用此状态码
403 Forbidden 禁止访问所请求的页面
404 Not Found 服务器无法找到所请求的页面
405 Method Not Allowed 请求中所指定的方法不被允许
406 Not Acceptable 服务器只能创建一个客户端无法接受的响应
407 Proxy Authentication Required 在请求被服务前必须认证一个代理服务器
408 Request Timeout 请求时间超过了服务器所能等待的时间,连接被断开
409 Conflict 请求有矛盾的地方
410 Gone 被请求的页面不再可用
411 Length Required "Content-Length"没有被定义,服务器拒绝接受请求
412 Precondition Failed 请求的前提条件被服务器评估为false
413 Request Entity Too Large 因为请求的实体太大,服务器拒绝接受请求
414 Request-url Too Long 服务器拒绝接受请求,因为URL太长。多出现在把"POST"请求转换为"GET"请求时所附带的大量查询信息
415 Unsupported Media Type 服务器拒绝接受请求,因为媒体类型不被支持
417 Expectation Failed
500 Internal Server Error 请求不完整,服务器遇见了出乎意料的状况
501 Not Implemented 请求不完整,服务器不提供所需要的功能
502 Bad Gateway 请求不完整,服务器从上游服务器接受了一个无效的响应
503 Service Unavailable 请求不完整,服务器暂时重启或关闭
504 Gateway Timeout 网关超时
505 HTTP Version Not Supported 服务器不支持所指定的HTTP版本

S.N. 方法 & 描述
1 public void setStatus ( int statusCode ) 此方法可以设置任意的状态码。如果您的响应包含一个特殊的状态码和一个文档,请确保在用PrintWriter返回任何内容前调用setStatus方法
2 public void sendRedirect(String url) 此方法产生302响应,同时产生一个 Location 头告诉URL 一个新的文档
3 public void sendError(int code, String message) 此方法将一个状态码(通常为 404)和一个短消息,自动插入HTML文档中并发回给客户端
JSP 表单处理
getParameter(): 使用 request.getParameter() 方法来获取表单参数的值。
getParameterValues(): 获得如checkbox类(名字相同,但值有多个)的数据。 接收数组变量 ,如checkbox类型
getParameterNames():该方法可以取得所有变量的名称,该方法返回一个 Enumeration。
getInputStream():调用此方法来读取来自客户端的二进制数据流。
<%= request.getParameter("name")%>
JSP 过滤器
过滤器是可用于 Servlet 编程的 Java 类,可以实现以下目的:
在客户端的请求访问后端资源之前,拦截这些请求。
在服务器的响应发送回客户端之前,处理这些响应。
根据规范建议的各种类型的过滤器:
身份验证过滤器(Authentication Filters)。
数据压缩过滤器(Data compression Filters)。
加密过滤器(Encryption Filters)。
触发资源访问事件过滤器。
图像转换过滤器(Image Conversion Filters)。
日志记录和审核过滤器(Logging and Auditing Filters)。
MIME-TYPE 链过滤器(MIME-TYPE Chain Filters)。
标记化过滤器(Tokenizing Filters)。
XSL/T 过滤器(XSL/T Filters),转换 XML 内容。
Servlet 过滤器方法
序号 方法 & 描述
1 public void doFilter (ServletRequest, ServletResponse, FilterChain)
该方法完成实际的过滤操作,当客户端请求方法与过滤器设置匹配的URL时,Servlet容器将先调用过滤器的doFilter方法。FilterChain用户访问后续过滤器。
2 public void init(FilterConfig filterConfig)
web 应用程序启动时,web 服务器将创建Filter 的实例对象,并调用其init方法,读取web.xml配置,完成对象的初始化功能,从而为后续的用户请求作好拦截的准备工作(filter对象只会创建一次,init方法也只会执行一次)。开发人员通过init方法的参数,可获得代表当前filter配置信息的FilterConfig对象。
3 public void destroy()
Servlet容器在销毁过滤器实例前调用该方法,在该方法中释放Servlet过滤器占用的资源。
如何在doFilter中过滤掉或者通过
if(session.getAttribute("userSession")==null)
{
response.sendRedirect("error/priv_error.jsp");
return;
}
else
{
chain.doFilter(request, response);
}

FilterConfig 使用
<filter>
<filter-name>LoginFilter</filter-name>
<filter-class>com.runoob.test.LogFilter</filter-class>
<init-param>
<param-name>Site</param-name>
<param-value>菜鸟教程</param-value>
</init-param>
</filter>
可以配置多个filter,按照顺序进行过滤
web.xml配置各节点说明
<filter>指定一个过滤器。
<filter-name>用于为过滤器指定一个名字,该元素的内容不能为空。
<filter-class>元素用于指定过滤器的完整的限定类名。
<init-param>元素用于为过滤器指定初始化参数,它的子元素<param-name>指定参数的名字,<param-value>指定参数的值。
在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。
<filter-mapping>元素用于设置一个 Filter 所负责拦截的资源。一个Filter拦截的资源可通过两种方式来指定:Servlet 名称和资源访问的请求路径
<filter-name>子元素用于设置filter的注册名称。该值必须是在<filter>元素中声明过的过滤器的名字
<url-pattern>设置 filter 所拦截的请求路径(过滤器关联的URL样式)
<servlet-name>指定过滤器所拦截的Servlet名称。
<dispatcher>指定过滤器所拦截的资源被 Servlet 容器调用的方式,可以是REQUEST,INCLUDE,FORWARD和ERROR之一,默认REQUEST。用户可以设置多个<dispatcher>子元素用来指定 Filter 对资源的多种调用方式进行拦截。
<dispatcher>子元素可以设置的值及其意义
REQUEST:当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问时,那么该过滤器就不会被调用。
INCLUDE:如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。
FORWARD:如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用,除此之外,该过滤器不会被调用。
ERROR:如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。

servlet和filter顺序:
filter初始化(tomcat初始化时候)----->servlet初始化(tomcat初始化(如果加上load-on-startup)或者请求/hello时候)------>filter处理----->servlet处理DOget DOpost
Servlet Cookie 方法
序号 方法 & 描述
1 public void setDomain(String pattern) 设置cookie的域名,比如 runoob.com
2 public String getDomain() 获取cookie的域名,比如 runoob.com
3 public void setMaxAge(int expiry) 设置cookie有效期,以秒为单位,默认有效期为当前session的存活时间
4 public int getMaxAge() 获取cookie有效期,以秒为单位,默认为-1 ,表明cookie会活到浏览器关闭为止
5 public String getName() 返回 cookie的名称,名称创建后将不能被修改
6 public void setValue(String newValue) 设置 cookie的值
7 public String getValue() 获取cookie的值
8 public void setPath(String uri) 设置cookie 的路径,默认为当前页面目录下的所有URL,还有此目录下的所有子目录
9 public String getPath() 获取cookie 的路径
10 public void setSecure(boolean flag) 指明cookie是否要加密传输
11 public void setComment(String purpose) 设置注释描述 cookie的目的。当浏览器将cookie展现给用户时,注释将会变得非常有用
12 public String getComment() 返回描述cookie目的的注释,若没有则返回null
使用JSP设置Cookie
(1)创建一个Cookie对象:Cookie cookie = new Cookie("key","value");
请务必牢记,名称和值中都不能包含空格或者如下的字符:[ ] ( ) = , " / ? @ : ;
(2) 设置有效期:cookie.setMaxAge(60*60*24);
(3) 将cookie发送至HTTP响应头中:response.addCookie(cookie);
使用 JSP 读取 Cookie
cookies = request.getCookies();
if( cookies != null ){
out.println("<h2> 查找 Cookie 名与值</h2>");
for (int i = 0; i < cookies.length; i++){
cookie = cookies[i];

out.print("参数名 : " + cookie.getName());
out.print("<br>");
out.print("参数值: " + URLDecoder.decode(cookie.getValue(), "utf-8") +" <br>");
out.print("------------------------------------<br>");
}
使用JSP删除Cookie
获取一个已经存在的cookie然后存储在Cookie对象中。
将cookie的有效期设置为0。
将这个cookie重新添加进响应头中。
JSP Session
<%@ page session="false" %>
S.N. 方法 & 描述
1 public Object getAttribute(String name) 返回session对象中与指定名称绑定的对象,如果不存在则返回null
2 public Enumeration getAttributeNames() 返回session对象中所有的对象名称
3 public long getCreationTime() 返回session对象被创建的时间, 以毫秒为单位,从1970年1月1号凌晨开始算起
4 public String getId() 返回session对象的ID
5 public long getLastAccessedTime() 返回客户端最后访问的时间,以毫秒为单位,从1970年1月1号凌晨开始算起
6 public int getMaxInactiveInterval() 返回最大时间间隔,以秒为单位,servlet 容器将会在这段时间内保持会话打开
7 public void invalidate() 将session无效化,解绑任何与该session绑定的对象
8 public boolean isNew() 返回是否为一个新的客户端,或者客户端是否拒绝加入session
9 public void removeAttribute(String name) 移除session中指定名称的对象
10 public void setAttribute(String name, Object value) 使用指定的名称和值来产生一个对象并绑定到session中
11 public void setMaxInactiveInterval(int interval) 用来指定时间,以秒为单位,servlet容器将会在这段时间内保持会话有效
session不用获取,直接内置的
删除Session数据
移除一个特定的属性:
调用public void removeAttribute(String name) 方法来移除指定的属性。
删除整个会话:
调用public void invalidate() 方法来使整个session无效。
设置会话有效期:
调用 public void setMaxInactiveInterval(int interval) 方法来设置session超时。
登出用户:
支持servlet2.4版本的服务器,可以调用 logout()方法来登出用户,并且使所有相关的session无效。
配置web.xml文件:
如果使用的是Tomcat,可以向下面这样配置web.xml文件:
<session-config>
<session-timeout>15</session-timeout>
</session-config>
JSP 文件上传
DiskFileItemFactory factory = new DiskFileItemFactory();
// 设置内存临界值 - 超过后将产生临时文件并存储于临时目录中
factory.setSizeThreshold(MEMORY_THRESHOLD);
// 设置临时存储目录
factory.setRepository(new File(System.getProperty("java.io.tmpdir")));

ServletFileUpload upload = new ServletFileUpload(factory);

// 设置最大文件上传值
upload.setFileSizeMax(MAX_FILE_SIZE);

// 设置最大请求值 (包含文件和表单数据)
upload.setSizeMax(MAX_REQUEST_SIZE);

// 中文处理
upload.setHeaderEncoding("UTF-8");

// 构造临时路径来存储上传的文件
// 这个路径相对当前应用的目录
String uploadPath = getServletContext().getRealPath("/") + File.separator + UPLOAD_DIRECTORY;


// 如果目录不存在则创建
File uploadDir = new File(uploadPath);
if (!uploadDir.exists()) {
uploadDir.mkdir();
}

try {
// 解析请求的内容提取文件数据
@SuppressWarnings("unchecked")
List<FileItem> formItems = upload.parseRequest(request);

if (formItems != null && formItems.size() > 0) {
// 迭代表单数据
for (FileItem item : formItems) {
// 处理不在表单中的字段
if (!item.isFormField()) {
String fileName = new File(item.getName()).getName();
String filePath = uploadPath + File.separator + fileName;
File storeFile = new File(filePath);
// 在控制台输出文件的上传路径
System.out.println(filePath);
// 保存文件到硬盘
item.write(storeFile);
request.setAttribute("message",
"文件上传成功!");
}
}
}
} catch (Exception ex) {
request.setAttribute("message",
"错误信息: " + ex.getMessage());
}
// 跳转到 message.jsp
getServletContext().getRequestDispatcher("/message.jsp").forward(
request, response);
JSP日期处理
获取当前日期和时间
Date date = new Date();
out.print( "<h2 align=\"center\">" +date.toString()+"</h2>");
日期比较
使用getTime()方法得到毫秒数,然后比较毫秒数就行了。
使用before(),after(),equals()方法。比如,new Date(99,2,12).before(new Date(99,2,18))返回true。
使用compareTo()方法,这个方法在Comparable接口中定义,在Date中实现。
日期格式化
Date dNow = new Date( );
SimpleDateFormat ft = new SimpleDateFormat ("yyyy-MM-dd HH:mm:ss");
out.print( "<h2 align=\"center\">" + ft.format(dNow) + "</h2>");
JSP 页面重定向
1、public void response.sendRedirect(String location) throws IOException
2、String site = "http://www.runoob.com" ;
response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", site);
JSP 点击量统计
属性设置和获取
application.setAttribute(String Key, Object Value);
application.getAttribute(String Key);
字符串随便写,自己定义
JSP 自动刷新
public void setIntHeader(String header, int headerValue)
response.setIntHeader("Refresh", 5);
JSP 邮件
html邮件
附件
// 创建一个默认的MimeMessage对象。
MimeMessage message = new MimeMessage(mailSession);

// 设置 From: 头部的header字段
message.setFrom(new InternetAddress(from));

// 设置 To: 头部的header字段
message.addRecipient(Message.RecipientType.TO,
new InternetAddress(to));

// 设置 Subject: header字段
message.setSubject("This is the Subject Line!");

// 创建消息部分
BodyPart messageBodyPart = new MimeBodyPart();

// 填充消息
messageBodyPart.setText("This is message body");

// 创建多媒体消息
Multipart multipart = new MimeMultipart();

// 设置文本消息部分
multipart.addBodyPart(messageBodyPart);

// 附件部分
messageBodyPart = new MimeBodyPart();
String filename = "file.txt";
DataSource source = new FileDataSource(filename);
messageBodyPart.setDataHandler(new DataHandler(source));
messageBodyPart.setFileName(filename);
multipart.addBodyPart(messageBodyPart);

// 发送完整消息
message.setContent(multipart );

// 发送消息
Transport.send(message);
用户认证
props.setProperty("mail.user", "myuser");
props.setProperty("mail.password", "mypwd");
表单发送邮件
标准标签库JSTL
安装:
将 jakarta-taglibs-standard-1.1.2/lib/ 下的两个 jar 文件:standard.jar 和 jstl.jar 文件拷贝到 /WEB-INF/lib/ 下。
<jsp-config>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/fmt</taglib-uri>
<taglib-location>/WEB-INF/fmt.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/fmt-rt</taglib-uri>
<taglib-location>/WEB-INF/fmt-rt.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/core</taglib-uri>
<taglib-location>/WEB-INF/c.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/core-rt</taglib-uri>
<taglib-location>/WEB-INF/c-rt.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/sql</taglib-uri>
<taglib-location>/WEB-INF/sql.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/sql-rt</taglib-uri>
<taglib-location>/WEB-INF/sql-rt.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/x</taglib-uri>
<taglib-location>/WEB-INF/x.tld</taglib-location>
</taglib>
<taglib>
<taglib-uri>http://java.sun.com/jsp/jstl/x-rt</taglib-uri>
<taglib-location>/WEB-INF/x-rt.tld</taglib-location>
</taglib>
</jsp-config>

核心标签
引用:<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<c:out> 用于在JSP中显示数据,就像<%= ... >
<c:set> 用于保存数据
<c:remove> 用于删除数据
<c:catch> 用来处理产生错误的异常状况,并且将错误信息储存起来
<c:if> 与我们在一般程序中用的if一样
<c:choose> 本身只当做<c:when>和<c:otherwise>的父标签
<c:when> <c:choose>的子标签,用来判断条件是否成立
<c:otherwise> <c:choose>的子标签,接在<c:when>标签后,当<c:when>标签判断为false时被执行
<c:import> 检索一个绝对或相对 URL,然后将其内容暴露给页面
<c:forEach> 基础迭代标签,接受多种集合类型
<c:forTokens> 根据指定的分隔符来分隔内容并迭代输出
<c:param> 用来给包含或重定向的页面传递参数
<c:redirect> 重定向至一个新的URL.
<c:url> 使用可选的查询参数来创造一个URL

格式化标签
引用:<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
标签 描述
<fmt:formatNumber> 使用指定的格式或精度格式化数字
<fmt:parseNumber> 解析一个代表着数字,货币或百分比的字符串
<fmt:formatDate> 使用指定的风格或模式格式化日期和时间
<fmt:parseDate> 解析一个代表着日期或时间的字符串
<fmt:bundle> 绑定资源
<fmt:setLocale> 指定地区
<fmt:setBundle> 绑定资源
<fmt:timeZone> 指定时区
<fmt:setTimeZone> 指定时区
<fmt:message> 显示资源配置文件信息
<fmt:requestEncoding> 设置request的字符编码

SQL标签
引用:<%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql" %>
标签 描述
<sql:setDataSource> 指定数据源
<sql:query> 运行SQL查询语句
<sql:update> 运行SQL更新语句
<sql:param> 将SQL语句中的参数设为指定值
<sql:dateParam> 将SQL语句中的日期参数设为指定的java.util.Date 对象值
<sql:transaction> 在共享数据库连接中提供嵌套的数据库行为元素,将所有语句以一个事务的形式来运行

XML标签:
<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml" %>
XML 和 XPath 的相关包拷贝至你的<Tomcat 安装目录>\lib下
标签 描述
<x:out> 与<%= ... >,类似,不过只用于XPath表达式
<x:parse> 解析 XML 数据
<x:set> 设置XPath表达式
<x:if> 判断XPath表达式,若为真,则执行本体中的内容,否则跳过本体
<x:forEach> 迭代XML文档中的节点
<x:choose> <x:when>和<x:otherwise>的父标签
<x:when> <x:choose>的子标签,用来进行条件判断
<x:otherwise> <x:choose>的子标签,当<x:when>判断为false时被执行
<x:transform> 将XSL转换应用在XML文档中
<x:param> 与<x:transform>共同使用,用于设置XSL样式表

JSTL函数
引用:<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
函数 描述
fn:contains() 测试输入的字符串是否包含指定的子串
fn:containsIgnoreCase() 测试输入的字符串是否包含指定的子串,大小写不敏感
fn:endsWith() 测试输入的字符串是否以指定的后缀结尾
fn:escapeXml() 跳过可以作为XML标记的字符
fn:indexOf() 返回指定字符串在输入字符串中出现的位置
fn:join() 将数组中的元素合成一个字符串然后输出
fn:length() 返回字符串长度
fn:replace() 将输入字符串中指定的位置替换为指定的字符串然后返回
fn:split() 将字符串用指定的分隔符分隔然后组成一个子字符串数组并返回
fn:startsWith() 测试输入字符串是否以指定的前缀开始
fn:substring() 返回字符串的子集
fn:substringAfter() 返回字符串在指定子串之后的子集
fn:substringBefore() 返回字符串在指定子串之前的子集
fn:toLowerCase() 将字符串中的字符转为小写
fn:toUpperCase() 将字符串中的字符转为大写
fn:trim() 移除首位的空白符
SQL操作:
<sql:setDataSource var="snapshot" driver="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/RUNOOB?useUnicode=true&characterEncoding=utf-8"
user="root" password="123456"/>
插入数据
<sql:update dataSource="${snapshot}" var="result">
INSERT INTO websites (name,url,alexa,country) VALUES ('菜鸟教程移动站', 'http://m.runoob.com', 5093, 'CN');
</sql:update>
查询数据
<sql:query dataSource="${snapshot}" var="result">
SELECT * from websites;
</sql:query>
删除 ID 为 11 的数据
<sql:update dataSource="${snapshot}" var="count">
DELETE FROM websites WHERE Id = ?
<sql:param value="${11}" />
</sql:update>

<c:forEach var="row" items="${result.rows}">
<tr>
<td><c:out value="${row.id}"/></td>
<td><c:out value="${row.name}"/></td>
<td><c:out value="${row.url}"/></td>
</tr>
</c:forEach>
JSP XML 数据处理
把页面做成XML:<%@ page contentType="text/xml" %>
处理XML
1、引入XML<c:import var="bookInfo" url="http://localhost:8080/books.xml"/>
2、 分析xml <x:parse xml="${bookInfo}" var="output"/>
3、处理xml <x:out select="$output/books/book[1]/name" />
格式化XML
Java Beans
JSP 自定义标签
1、创建标签类,继承SimpleTagSupport 重写doTag,然后编译,把class放到lib中
2、创建\WEB-INF\custom.tld
<taglib>
<tlib-version>1.0</tlib-version>
<jsp-version>2.0</jsp-version>
<short-name>Example TLD</short-name>
<tag>
<name>Hello</name>
<tag-class>com.runoob.HelloTag</tag-class>
<body-content>empty</body-content>
</tag>
</taglib>
3、使用标签
<%@ taglib prefix="ex" uri="WEB-INF/custom.tld"%>
<ex:Hello/>
表达式语言(EL)
${expr}
当JSP编译器在属性中见到"${}"格式后,它会产生代码来计算这个表达式,并且产生一个替代品来代替表达式的值。
想要停用对EL表达式的评估的话,需要使用page指令将isELIgnored属性值设为true:
<%@ page isELIgnored ="true|false" %>
JSP EL中的函数
${ns:func(param1, param2, ...)}
ns指的是命名空间(namespace),func指的是函数的名称,param1指的是第一个参数,param2指的是第二个参数,以此类推。比如,有函数fn:length,在JSTL库中定义,可以像下面这样来获取一个字符串的长度:
${fn:length("Get my length")}
JSP EL隐含对象
隐含对象 描述
pageScope page 作用域
requestScope request 作用域
sessionScope session 作用域
applicationScope application 作用域
param Request 对象的参数,字符串
paramValues Request对象的参数,字符串集合
header HTTP 信息头,字符串
headerValues HTTP 信息头,字符串集合
initParam 上下文初始化参数
cookie Cookie值
pageContext 当前页面的pageContext
pageContext对象${pageContext.request.queryString}
Scope对象pageScope,requestScope,sessionScope,applicationScope变量用来访问存储在各个作用域层次的变量
param和paramValues对象
param和paramValues对象用来访问参数值,通过使用request.getParameter方法和request.getParameterValues方法。
举例来说,访问一个名为order的参数,可以这样使用表达式:${param.order},或者${param["order"]}。
header和headerValues对象
要访问一个名为user-agent的信息头,可以这样使用表达式:${header.user-agent},或者${header["user-agent"]}。
异常处理:
使用这个指定一个错误页面:<%@ page errorPage="ShowError.jsp" %>
在错误页面使用<%@ page isErrorPage="true" %>
${pageContext.exception}
${pageContext.errorData.requestURI}
${pageContext.errorData.statusCode}
${pageContext.exception.stackTrace}
使用try catch
JSP 调试
1/system.out.println()
2/使用JDB Logger
<%@page import="java.util.logging.Logger" %>
<% Logger logger=Logger.getLogger(this.getClass().getName());%>
logger.info( message );
3/使用JDB Debugger
国际化:
国际化(i18n):表明一个页面根据访问者的语言或国家来呈现不同的翻译版本。
本地化(l10n):向网站添加资源,以使它适应不同的地区和文化。比如网站的印度语版本。
区域:这是一个特定的区域或文化,通常认为是一个语言标志和国家标志通过下划线连接起来。比如"en_US"代表美国英语地区。
Locale locale = request.getLocale();
String language = locale.getLanguage();
String country = locale.getCountry();
四个作用域
application 在所有应用程序中有效
session 在当前会话中有效
request 在当前请求中有效
page 在当前页面有效
重点:

1标签
2https://blog.csdn.net/zhang_hongli_li/article/details/48550817 总复习
3几个动作:https://blog.csdn.net/qq_29028175/article/details/53729048 ☆☆☆☆☆☆☆☆☆


posted @ 2019-03-12 09:11  周sir搞人工  阅读(194)  评论(0编辑  收藏  举报