Servlet (2) ------ 请求、响应与会话

请求:

    HttpServletRequest表示Http环境中的Servlet请求。它扩展于
            javax.servlet.ServletRequest接⼝)
    HttpServletRequest继承于ServletRequest所以他们一样

客户端发送数据给服务器方式:

    ⽅式1:通过表单 get/post提交
        表单中:key值是name属性的值
    ⽅式2:通过a标签发送数据(get提交)

<a href = "请求名?key=value&key=value"></a>

        key = value 表示的是想要传给服务器的一对参数,多个用“&”连接
        这⾥的key值=表单元素的控件名,value值=表单中控件的value属性值
        :第⼀个参数使⽤?拼接,之后的参数使⽤&拼接,获取数据还是通过
            String name=request.getParameter(“name”);
    ⽅式3:通过地址栏直接拼接-get请求
    ⽅式4:js提交数据-get请求
        location.href=“⽬标请求?key=value&key=value”
    :⽅式2/3都属于get提交⽅式,表单提交可以使⽤get、post提交⽅式

处理乱码问题:

    ⽅式1:setCharacterEncoding(“UTF-8”);//post提交时管⽤
    ⽅式2: String s=new String(变量名.getBytes(“ISO-8859-1”),“UTF-8”);//针对于get提
                交时中⽂乱码
    ⽅式3:修改tomcat中配置⽂件://使⽤于get提交 在Tomcat⽬录结构\conf\server.xml
                中设置字符集(Tomcat 8.0后不需要)

get和post的区别:

    1.GET请求的数据会暴露在地址栏中,⽽POST请求则不会。
            GET请求:请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数⽤&连接。
            URL的编码 格式采⽤的是ASCII编码,⽽不是uniclde,即是说所有的⾮ASCII
            字符都要编码之后再传输。
        POST请求:POST请求会把请求的数据放置在HTTP请求包的包体中。
    2.传输数据大小
        对于GET,特定的浏览器和服务器对URL的⻓度有限制。因此,在使⽤GET请求时,传
            输数据会受到URL⻓度的限制。
         对于POST,由于不是URL传值,理论上是不会受限制的,但是实际上各个服务器会规
            定对POST提交数 据⼤⼩进⾏限制,Apache、IIS都有各⾃的配置。
    3.安全性
        POST的安全性⽐GET的⾼。
        在进⾏登录操作,通过GET请求,⽤户名和密码都 会暴露再URL上
        GET请求提交的数据还可能会造成Cross-site request frogery攻击

方法:

    1)String getParameter(String name) 根据表单组件名称获取提交数据,返回值是String
        注:服务器在接收数据时使⽤字符串统⼀接收
    2)void setCharacterEncoding(String charset) 指定每个请求的编码(针对post请求才起作⽤)
    3)String[ ] getParameterValues(String name) 获取表单组件对应多个值时的请求数据
        例如:复选框,通过name属性的起的名,获取value的值
    4)RequestDispatcher getRequestDispatcher(String path) --跳转⻚⾯ 返回⼀个
        RequestDispatcher对象,该对象的forward( )⽅法⽤于转发请求
        req.getRequestDispatcher(“地址”).forward(req,resp)
    例如:

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

        跳转页面的斜杠表示从Web目录开始寻找资源
    5)存值 request.setAttribute(“key”,value);
        用于后台给前台传数据的时候
        request存值是单次请求有效
    6)取值 request.getAttribute(“key”);//取值后需要向下转型 示例:
        String a1=(String)request.getAttribute(“uname”);

响应:

    HttpServletResponse接⼝,它继承⾃ServletResponse接⼝,专⻔⽤来封 装HTTP响应消息,其
    中定义了向客户端发送响应状态码,响应消息头,响应消息体的方法。

方法:

    void sendRedirect(String var1) 发送⼀条响应码,将浏览器跳转到指定的页面(重定向)
    setContentType() 设置响应内容的类型(text/html)
    void addCookie(Cookie var1) 给这个响应添加⼀个cookie存储器
    PrintWriter writer = resp. getWriter()
        得到一个可以给前端输出信息的输出流对象
        获得字符流,通过字符流的write(String s)⽅法可以将字符串设置到response 缓冲区
        中,随后Tomcat会将response缓冲区中的内容组装成Http响应返回给浏览器端。

转发和定向:

在这里插入图片描述
    转发跳转页面地址栏显示的是请求名,重定向显示的是要跳转的页面地址
    相同点:都⽤来跳转⻚⾯
    不同点: a.重定向时地址栏会改变,request中存储的数据会丢失
                    转发时地址栏显示的是请求⻚⾯的地址,request数据可以保存。
                b.转发属于⼀次请求⼀次响应,重定向属于两次请求(地址栏修改了两次)两次响应。

会话:

    会话对象:session
    通过 req.getSession();获得一个HttpSession对象
    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的⾮活动时间
        或修改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验证⽤户是否登录
    补充: ⾃动刷新到某⻚⾯:
    注:在head标签中添加该标签,单位:秒

初始化参数:

    避免耦合度高,可以再web.xml文件中设置初始化参数
    可以用于设置编码格式

<!--全局初始化参数-->
<context-param>
    <param-name>allparam</param-name>
    <param-value>allparam参数</param-value>
</context-param>
<servlet>
    <servlet-name>b1</servlet-name>
    <servlet-class>web.userServlet</servlet-class>
    <init-param>
        <!--针对于某一个Servlet-->
        <param-name>myparam</param-name>
        <param-value>myparam的值</param-value>
    </init-param>
</servlet>
获取参数:
@Override
public void init(ServletConfig config) throws ServletException {
    //局部初始化参数
    System.out.println("UsersServlet-init->myparam"
                    +config.getInitParameter("myparam"));
    //全局初始化参数
    System.out.println("UsersServlet-init->allparam"
                +config.getServletContext().getInitParameter("allparam"));
}

Servlet注解

    防止xml文件中代码过长
    WebServlet常用属性:
在这里插入图片描述
    @WebServlet()
        (1).loadOnStartup属性:标记容器是否在启动应⽤时就加载Servlet,默认不配置或数值为负数时表示客
            户端第⼀次请求Servlet时再加载;0或正数表示启动应⽤就加载,正数情况下,数值越⼩,加载该
            Servlet的优先级越⾼;
        (2).name属性:可以指定也可以不指定,通过getServletName()可以获取到,若不指定,则为Servlet的 完
                整类名,如:cn.edu.njit.servlet.UserServlet
        (3).urlPatterns/value属性: String[]类型,可以配置多个映射,
                如:urlPatterns={"/user/test", “/user/example”}
        (4).在使⽤注解⽅式时,需要注意: 根元素中不能配置属性metadata-complete=“true”,否则⽆法加载
            Servlet。metadata-complete属性 表示通知Web容器是否寻找注解,默认不写或者设置false,
            容器会扫描注解,为Web应⽤程序构建有效 的元数据;metadata-complete=“true”,
            会在启动时不扫描注解(annotation)。如果不扫描注解的 话,⽤注解进⾏的配置就⽆法⽣效,
            例如:@WebServlet
        (5).urlPatterns的常⽤规则:
                 /*或者/:拦截所有
                 .do:拦截指定后缀
                 /user/test:拦截路径
                 /user/.do、/.do、test
.do都是⾮法的,启动时候会报错
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

王某人@

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值