JavaWeb之Servlet(下)

前言

1. 请求

常用方法:

补充1:客户端如何发送数据给服务器

方式1:通过表单 get/post提交

方式2:通过a标签发送数据(get提交)

方式3:通过地址栏直接拼接-get请求

方式4:js提交数据-get请求

补充2:处理请求乱码的问题

补充3:get和post的区别

2. 响应

常用方法:

重定向和转发的对比

3. 会话

常用方法:

方式1: session.setMaxInactiveInterval(10*60);//设置有效时间为10分钟

方式2:修改web.xml    

小结 :让session失效的方式

4.获得初始化参数

1.实现方式:

(1)web.xml中先定义初始化参数

(2)servlet中获得初始化参数,重写init()方法

2.全局初始化参数

(1)定义,context-param是和servlet标签同级别

(2)获得数据

5.servlet3.0

@WebServlet常用属性

2.测试结果

3.注意点:

(1).loadOnStartup属性:

(2).name属性:

(3).urlPatterns/value属性:

(4).在使用注解方式时,需要注意:

(5).urlPatterns的常用规则:

总结


前言

         回顾一下学习并对JavaWeb的学习过程中对笔记总结进行记录,同时将自己学习过程中的理解加入其中,方便自己进行后续的学习和回顾

1. 请求

HttpServletRequest表示Http环境中的Servlet请求。它扩展于javax.servlet.ServletRequest接口)

常用方法:

1)String getParameter(String name) 根据表单组件名称获取提交数据,返回值是String

注:服务器在接收数据时使用字符串统一接收

2)String[ ] getParameterValues(String name) 获取表单组件对应多个值时的请求数据

3)void setCharacterEncoding(String charset) 指定每个请求的编码(针对post请求才起作用)

4)RequestDispatcher getRequestDispatcher(String path) --跳转页面

返回一个RequestDispatcher对象,该对象的forward( )方法用于转发请求

示例:

  request.getRequestDispatcher("../success.jsp").forward(request,response);

5)存值 request.setAttribute("key",value);

6)取值 request.getAttribute("key");//取值后需要向下转型

示例: String a1=(String)request.getAttribute("uname");

补充1:客户端如何发送数据给服务器

方式1:通过表单 get/post提交

方式2:通过a标签发送数据(get提交)

<a href="请求名?key=value&key=value&key=value...">
示例:
<a href="/login?a=10&name=admin&pass=123456">

这里的key值=表单元素的控件名,value值=表单中控件的value属性值

注:第一个参数使用?拼接,之后的参数使用&拼接,获取数据还是通过

String name=request.getParameter("name");

方式3:通过地址栏直接拼接-get请求

方式4:js提交数据-get请求

location.href="目标请求?key=value&key=value"

注:方式2/3都属于get提交方式,表单提交可以使用get、post提交方式

补充2:处理请求乱码的问题

方式1:setCharacterEncoding("UTF-8");//post提交时管用

方式2: String s=new String(变量名.getBytes("ISO-8859-1"),"UTF-8");//针对于get提交时中文乱码

示例: String s=new String(request.getParameter("key").getBytes("ISO-8859-1"),"GBK");

方式3:修改tomcat中配置文件://使用于get提交

在Tomcat目录结构\conf\server.xml中设置字符集

<Connector port="8080" protocol="HTTP/1.1"                                      
            connectionTimeout="20000"
            redirectPort="8443" URIEncoding="UTF-8" />

注意:tomcat8.0以后不需要手动设置这个属性了

补充3:get和post的区别

1、GET请求,请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数用&连接。URL的编码格式采用的是ASCII编码,而不是uniclde,即是说所有的非ASCII字符都要编码之后再传输。

POST请求:POST请求会把请求的数据放置在HTTP请求包的包体中。上面的item=bandsaw就是实际的传输数据。因此,GET请求的数据会暴露在地址栏中,而POST请求则不会。

2、传输数据的大小

        在HTTP规范中,没有对URL的长度和传输的数据大小进行限制。但是在实际开发过程中,对于GET,特定的浏览器和服务器对URL的长度有限制。因此,在使用GET请求时,传输数据会受到URL长度的限制。

        对于POST,由于不是URL传值,理论上是不会受限制的,但是实际上各个服务器会规定对POST提交数据大小进行限制,Apache、IIS都有各自的配置。

3、安全性

        POST的安全性比GET的高。这里的安全是指真正的安全,而不同于上面GET提到的安全方法中的安全,上面提到的安全仅仅是不修改服务器的数据。比如,在进行登录操作,通过GET请求,用户名和密码都会暴露再URL上,因为登录页面有可能被浏览器缓存以及其他人查看浏览器的历史记录的原因,此时的用户名和密码就很容易被他人拿到了。除此之外,GET请求提交的数据还可能会造成Cross-site request frogery攻击.

2. 响应

        在Service API中,定义了一个HttpServletResponse接口,它继承自ServletResponse接口,专门用来封装HTTP响应消息。 在HttpServletResponse接口中定义了向客户端发送响应状态码,响应消息头,响应消息体的方法。

常用方法:

void addCookie(Cookie var1);//给这个响应添加一个cookie

void sendRedirect(String var1) ;//发送一条响应码,将浏览器跳转到指定的位置

PrintWriter getWriter() 获得字符流,通过字符流的write(String s)方法可以将字符串设置到response 缓冲区中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览器端。

setContentType() 设置响应内容的类型

重定向和转发的对比

重定向:response.sendRedirect()

转发:request.getRequestDispatcher("../success.jsp").forward(request,response);

相同点:都用来跳转页面

不同点:

a.重定向时地址栏会改变,request中存储的数据会丢失.转发时地址栏显示的是请求页面的地址,request数据可以保存。

b.转发属于一次请求一次响应,重定向属于两次请求(地址栏修改了两次)两次响应。

补充:使用out对象往页面中输出js或html,css

out.print("<script type='text/javascript'>alert('登录失败');location='../login.jsp'</script>");

注:使用js跳转页面,也会丢失request中的数据

3. 会话

request存的值只能在单次请求中保存,保存的数据不能跨页面,当重定向时,request存的值会丢失

session的数据可以在多个页面中共享,即使重定向页面,数据不会丢失

session中可以包含n个request。

会话的概念:从打开浏览器到关闭浏览器,期间访问服务器就称为一次会话

常用方法:

void setAttribute(String key,Object value) 以key/value的形式保存对象值,将数据存储在服务器端

Object getAttribute(String key) 通过key获取对象值

void invalidate() 设置session对象失效

String getId() 获取sessionid,当第一次登录成功后,session会产生一个唯一的id,浏览器之后访问时如果发现id值还是之前id,那么说明 当前访问的属于同一个会话

void setMaxInactiveInterval(int interval) 设定session的非活动时间

示例:

方式1: session.setMaxInactiveInterval(10*60);//设置有效时间为10分钟

方式2:修改web.xml    

   <session-config>
        <session-timeout>10</session-timeout>//单位:分钟 
    </session-config>         

int getMaxInactiveInterval() 获取session的有效非活动时间(以秒为单位),默认的有效时间:30分钟

void removeAttribute(String key)

从session中删除指定名称(key)所对应的对象

小结 :让session失效的方式

(1)invalidate() (2)removeAttribute("key") (3)直接关闭浏览器。

示例:使用session验证用户是否登录

补充:

自动刷新到某页面:<meta http-equiv="refresh" content="3;url=index.jsp">

注:在head标签中添加该标签,单位:秒

4.获得初始化参数

        request.setCharacterEncoding("utf-8");代码的耦合度太高,不便于后期维护修改。可以通过初始化参数实现

1.实现方式:

(1)web.xml中先定义初始化参数

<servlet>
    <servlet-name></servlet-name>
    <servlet-class></servlet-class>
    <init-param>
       <param-name>encoding</param-name>
       <param-value>utf-8</param-value>
    </init-param>
</servlet>

(2)servlet中获得初始化参数,重写init()方法

public void init(ServletConfig config) throws ServletException {
          encoding= config.getInitParameter("encoding");
}

注意:这种方式的初始化参数仅限于当前servlet中使用。

2.全局初始化参数

(1)定义,context-param是和servlet标签同级别

<context-param>
   <param-name>bianma</param-name>
   <param-value>utf-8</param-value>
  </context-param>

(2)获得数据

@Override  // 请求->init()->service()->doget/dopost->destory();
​
public void init(ServletConfig config) throws ServletException {
    bianhao=config.getServletContext().getInitParameter("bianma");
}

5.servlet3.0

注解(提供给程序读取的信息) -- 注释(提供给程序员看的信息)

注解的格式:@开头的 如:@Override

@WebServlet注解配置Servlet

从Servlet3.0开始,配置Servlet支持注解方式,但还是保留了配置web.xml方式,所有使用Servlet有两种方式:

(1)Servlet类上使用@WebServlet注解进行配置

(2)web.xml文件中配置

@WebServlet常用属性

属性类型是否必须说明
asyncSupportedboolean指定Servlet是否支持异步操作模式
displayNameString指定Servlet显示名称
initParamswebInitParam[]配置初始化参数
loadOnStartupint标记容器是否在应用启动时就加载这个Servlet,等价于配置文件中的<load-on-startup>标签
nameString指定Servlet名称
urlPatterns/valueString[]这两个属性作用相同,指定Servlet处理的url
<servlet>
    <servlet-name>a</servlet-name>
    <servlet-class>
       <!-- 处理类的完整路径 -->
       com.yhp.web.SelectServlet
    </servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>

测试代码如下:

1.UserServlet

通过注解方式配置,web.xml中不需要配置该Servlet

@WebServlet(name = "myUserServlet", 
    urlPatterns = "/user/test",   //斜杠必须
    loadOnStartup = 1,  
    initParams = {
            @WebInitParam(name="name", value="小明"), 
            @WebInitParam(name="pwd", value="123456")
    }
)
public class UserServlet extends HttpServlet {
    private static final long serialVersionUID = 7109220574468622594L;
    
    @Override
    public void init(ServletConfig config) throws ServletException {
        super.init(config);
        
        System.out.println("servlet初始化...");
    }
    
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html");
        response.setCharacterEncoding("utf-8");
        PrintWriter pw = response.getWriter();
        
        pw.append("Hello Servlet!<br>" );
        
        //servletName
        pw.append("servletName:" + getServletName() + "<br>");
        
        //initParam
        ServletConfig servletConfig = this.getServletConfig();
        Enumeration<String> paramNames = servletConfig.getInitParameterNames();
        while (paramNames.hasMoreElements()) {
            String paramName = paramNames.nextElement();
            pw.append(paramName + ":" + servletConfig.getInitParameter(paramName) + "<br>");
        }
        
        pw.close();
        
    }
 
 
    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }
}

2.测试结果

2.1应用启动时,servlet就会初始化,因为配置了loadOnStartup=1

2.2访问/user/test,页面上显示结果;表名参数正确初始化以及自定义的servlet名称

3.注意点:

(1).loadOnStartup属性:

        标记容器是否在启动应用时就加载Servlet,默认不配置或数值为负数时表示客户端第一次请求Servlet时再加载;0或正数表示启动应用就加载,正数情况下,数值越小,加载该Servlet的优先级越高;

实例://斜杠必须

@WebServlet(value="/test1",loadOnStartup=1)

(2).name属性:

        可以指定也可以不指定,通过getServletName()可以获取到,若不指定,则为Servlet的完整类名,如:cn.edu.njit.servlet.UserServlet

(3).urlPatterns/value属性:

        String[]类型,可以配置多个映射,如:urlPatterns={"/user/test", "/user/example"}

实例:

//斜杠必须

@WebServlet(loadOnStartup=1,urlPatterns= {"/test1","/test2"})

(4).在使用注解方式时,需要注意:

        <web-app> </web-app>根元素中不能配置属性metadata-complete="true",否则无法加载Servlet。metadata-complete属性表示通知Web容器是否寻找注解,默认不写或者设置false,容器会扫描注解,为Web应用程序构建有效的元数据;metadata-complete="true",会在启动时不扫描注解(annotation)。如果不扫描注解的话,用注解进行的配置就无法生效,例如:@WebServlet

(5).urlPatterns的常用规则:

/*或者/:拦截所有

*.do:拦截指定后缀

/user/test:拦截路径

/user/.do、/.do、test*.do都是非法的,启动时候会报错

总结

   本篇博文是对学习servlet知识总结的一部分,通过对学习笔记的总结,能够有一个深刻的理解,并且在学习过程中,自己也总结出了自己学习的思路以及学习大纲,走出了自己的学习节奏.

  • 16
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

XError_xiaoyu

你的支持,使我更好的创作

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值