javaee-HttpServletResponse 类相关源代码

ServletAPI 2.5的源代码

 

1.ServletResponse类的源代码如下:

 

package javax.servlet;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Locale;

public abstract interface ServletResponse
{
  public abstract String getCharacterEncoding();

  public abstract String getContentType();

  public abstract ServletOutputStream getOutputStream()
    throws IOException;

  public abstract PrintWriter getWriter()
    throws IOException;

  public abstract void setCharacterEncoding(String paramString);

  public abstract void setContentLength(int paramInt);

  public abstract void setContentType(String paramString);

  public abstract void setBufferSize(int paramInt);

  public abstract int getBufferSize();

  public abstract void flushBuffer()
    throws IOException;

  public abstract void resetBuffer();

  public abstract boolean isCommitted();

  public abstract void reset();

  public abstract void setLocale(Locale paramLocale);

  public abstract Locale getLocale();
}
 

 

 

2.HttpServletResponse 类的源代码如下:

 

 

package javax.servlet.http;

import java.io.IOException;
import javax.servlet.ServletResponse;

public abstract interface HttpServletResponse extends ServletResponse
{
  public static final int SC_CONTINUE = 100;//SC是 status code的简写
  public static final int SC_SWITCHING_PROTOCOLS = 101;
  public static final int SC_OK = 200;
  public static final int SC_CREATED = 201;
  public static final int SC_ACCEPTED = 202;
  public static final int SC_NON_AUTHORITATIVE_INFORMATION = 203;
  public static final int SC_NO_CONTENT = 204;
  public static final int SC_RESET_CONTENT = 205;
  public static final int SC_PARTIAL_CONTENT = 206;
  public static final int SC_MULTIPLE_CHOICES = 300;
  public static final int SC_MOVED_PERMANENTLY = 301;
  public static final int SC_MOVED_TEMPORARILY = 302;
  public static final int SC_FOUND = 302;
  public static final int SC_SEE_OTHER = 303;
  public static final int SC_NOT_MODIFIED = 304;
  public static final int SC_USE_PROXY = 305;
  public static final int SC_TEMPORARY_REDIRECT = 307;
  public static final int SC_BAD_REQUEST = 400;
  public static final int SC_UNAUTHORIZED = 401;
  public static final int SC_PAYMENT_REQUIRED = 402;
  public static final int SC_FORBIDDEN = 403;
  public static final int SC_NOT_FOUND = 404;
  public static final int SC_METHOD_NOT_ALLOWED = 405;
  public static final int SC_NOT_ACCEPTABLE = 406;
  public static final int SC_PROXY_AUTHENTICATION_REQUIRED = 407;
  public static final int SC_REQUEST_TIMEOUT = 408;
  public static final int SC_CONFLICT = 409;
  public static final int SC_GONE = 410;
  public static final int SC_LENGTH_REQUIRED = 411;
  public static final int SC_PRECONDITION_FAILED = 412;
  public static final int SC_REQUEST_ENTITY_TOO_LARGE = 413;
  public static final int SC_REQUEST_URI_TOO_LONG = 414;
  public static final int SC_UNSUPPORTED_MEDIA_TYPE = 415;
  public static final int SC_REQUESTED_RANGE_NOT_SATISFIABLE = 416;
  public static final int SC_EXPECTATION_FAILED = 417;
  public static final int SC_INTERNAL_SERVER_ERROR = 500;
  public static final int SC_NOT_IMPLEMENTED = 501;
  public static final int SC_BAD_GATEWAY = 502;
  public static final int SC_SERVICE_UNAVAILABLE = 503;
  public static final int SC_GATEWAY_TIMEOUT = 504;
  public static final int SC_HTTP_VERSION_NOT_SUPPORTED = 505;

  public abstract void addCookie(Cookie paramCookie);

  public abstract boolean containsHeader(String paramString);

  public abstract String encodeURL(String paramString);

  public abstract String encodeRedirectURL(String paramString);

  /**
   * @deprecated
   */
  public abstract String encodeUrl(String paramString);

  /**
   * @deprecated
   */
  public abstract String encodeRedirectUrl(String paramString);

  public abstract void sendError(int paramInt, String paramString)
    throws IOException;

  public abstract void sendError(int paramInt)
    throws IOException;

  public abstract void sendRedirect(String paramString)
    throws IOException;

  public abstract void setDateHeader(String paramString, long paramLong);

  public abstract void addDateHeader(String paramString, long paramLong);

  public abstract void setHeader(String paramString1, String paramString2);

  public abstract void addHeader(String paramString1, String paramString2);

  public abstract void setIntHeader(String paramString, int paramInt);

  public abstract void addIntHeader(String paramString, int paramInt);

  public abstract void setStatus(int paramInt);

  /**
   * @deprecated
   */
  public abstract void setStatus(int paramInt, String paramString);
}
 

 

2.1HttpServletResponse 对象所想描述的结构如下(http响应格式图):

 

 

 

 

 

 

其中,消息头,可以通过“meta ”标签equiv属性来模拟,如下

 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
……
 

但是其优先级没有相应头高。

 

 

 

另外,如果页面本身编码为utf-8,浏览器将会识别出来,并强制设置为utf-8编码。"Content-Type""将不起作用。

 

 

3.ServletOutputStream和PrintWriter

 

ServletResponse类提供了如下两个方法:

 

 

public abstract ServletOutputStream getOutputStream()
    throws IOException;

  public abstract PrintWriter getWriter()
    throws IOException;
 

 

 

 

      Servlet程序向ServletOutputStreamPrintWriter对象中写入的数据将被Servlet引擎获取,Servlet引擎,将这些数据当作响应消息的正文,然后再与响应状态行,响应头组合输出到客户端(通常为IEChrome等浏览器)。

 

       ServletOutputStream主要针对字节,而PrintWriter针对字符串。另外getOutputStreamgetWriter在一个service方法中不能同时调用。

 

 

参考:《深入体验Java_Web开发内幕-核心基础\》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaEE-书管理系统通常需要包含以下数据库表: 1. 用户表(user):包括用户ID、用户名、密码、邮箱等字段。 2. 书表(book):包括书ID、书名称、作者、出版社、ISBN号等字段。 3. 借阅记录表(borrow_record):包括借阅记录ID、用户ID、书ID、借阅时间、归还时间等字段。 4. 管理员表(admin):包括管理员ID、管理员名称、密码等字段。 以下是JavaEE-书管理系统数据库代码示例: ```sql -- 用户表 CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(50) NOT NULL, `password` varchar(50) NOT NULL, `email` varchar(50) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- 书表 CREATE TABLE `book` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `author` varchar(50) NOT NULL, `publisher` varchar(50) NOT NULL, `isbn` varchar(20) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- 借阅记录表 CREATE TABLE `borrow_record` ( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) NOT NULL, `book_id` int(11) NOT NULL, `borrow_time` datetime NOT NULL, `return_time` datetime DEFAULT NULL, PRIMARY KEY (`id`), KEY `fk_user_id_idx` (`user_id`), KEY `fk_book_id_idx` (`book_id`), CONSTRAINT `fk_book_id` FOREIGN KEY (`book_id`) REFERENCES `book` (`id`) ON DELETE CASCADE ON UPDATE CASCADE, CONSTRAINT `fk_user_id` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- 管理员表 CREATE TABLE `admin` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(50) NOT NULL, `password` varchar(50) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; ``` -- 相关问题--: 1. 如何创建数据库表? 2. 如何在JavaEE中连接数据库? 3. 数据库中的什么是外键?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值