首页 > 编程知识 正文

java中换行的代码是什么,java中怎么给字符串加换行

时间:2023-05-03 22:06:03 阅读:32312 作者:4716

在HTTP中定义的事务由以下四个步骤组成:

1 .建立连接。

2 .客户端发送HTTP请求报头。

3 .服务器端响应生成结果的返回。

4 .服务器端关闭连接,客户端分析回复头,恢复页面。

1 .建立连接:以下以我另一篇文章的地址为例

servlet容器(Tomacat )介绍和配置

请求客户端(即地址)时,Web服务HTTP端口的套接字已打开。 由于网线用作在网络中间传递数据的物理介质,因此数据实际上是通过IO流输出和输入的。 这是在编写servlet时导入Java.io.*; 的原因还包括在将结果返回给客户端时使用PrintWriter对象的println ()方法。

例如我在这里请CSDN社区的地址http://blog.csdn.net。

实际上,首先可以不写这个地址和一个端口80(8080 ) http://blog.csdn.net:80 80,因为浏览器web服务的默认端口号是80。

虽然在Java的基本代码中是这样实现的,但是已经在做了。

socketsocket=new socket (' blog.csdn.net ',8080 );

inputstream in=socket.get inputstream (;

output stream out=socket.get output stream (;

2 .客户端发送HTTP请求报头

建立TCP连接后,Web浏览器向Web服务器发送请求命令。 这是实现ASCII文本请求行、0个或多个HTTP标题、空行和请求的任何数据。 四部分:请求线、请求头、空行和请求数据。

1 )请求行由三个标签组成。 请求方法请求URL的http版本,中间用空格分开

例如,getlvpin/archive/2007/06/09/1645767.aspx http/1.1

HTTP规范定义了八种可能的请求方法。 (最常见的方法有两种:获取和开机自检。 )

GET通过URI获取标识资源的简单请求

HEAD与GET方法一样,服务只返回状态行和标头,而不返回请求的文档

POST服务接受对写入客户端输出流的数据的请求

PUT服务器将请求数据存储为对指定URI的新内容的请求

DELETE服务器删除URI指定资源的请求

OPTIONS服务器支持请求方法信息请求

TRACE Web服务器反馈Http请求及其标头的请求

CONNECT是有文档记录的,但目前没有实现,是为隧道处理而保留的

2 )请求标题) key :由value键值组成,每行一对。 向头通知服务器请求客户端的功能和id。

主机请求的任何服务器端地址、主地址,例如我现在所在的CSDN blog.csdn.net/

作为用户代理用户的客户端可以使用的浏览器。 例如Mozilla/4.0

接受是客户端接受的MIME类型列表,例如image/gif text/html和应用程序/ms word

Content-Length仅适用于POST请求,POST数据的大小以字节表示

3 )空行发送换行和退出,通知服务器以下不再有标题。

4 )请求数据)使用开机自检发送数据,最常用的是内容类型和内容长度报头。

综上所述,可以这样写标准的HTTP请求

post/LV pin/archive/2007/06/09/1645767.aspx http 1.1

HOST: blog.csdn.net/

用户代理: Mozilla/4.0

Accpt: image/gif,text/html,application/pdf,image/png .

key=value key=value key=value……………………(post () ) )请求的数据)

那么,上面的一个例子说明的是

我要访问的服务器端地址是blog.csdn.net/连接其下的资源/LV pin/archive/2007/06/09/1645767.aspx即http://blog.csdn.net

此页面使用了HTTP1.1规范。 我的浏览器版本是Mozilla/4.0

支持的MIME格式包括image/gif、text/html、application/pdf、image/png .等

此MIME格式是我们response.set content type (' text/html; 中情局

rset=gb2312");或者在一个 或者总能见到

那么在这里如何理解 GET 和 POST 最直观的区别,最明显的就是 GET方法将数据的请求跟在了所请求的URL后面,也就是在请求行里面我们是这么样来做的:

GET lvpin/archive/2007/06/09/1645767.aspx?

key=value&key=value&key=value......HTTP1.1

也实际上就是 用 GET 如此传递数据 :

http://blog.csdn.net/lvpin/archive/2007/06/09/1645767.aspx?name=simon&password=simonlv........

3.服务器端接受请求,处理数据后生成响应返回数据到客户端 (部分Servlet 内容穿插)

Web 服务器 解析请求,定位指定的资源http://blog.csdn.net/lvpin/archive/2007/06/09/1645767.aspx

1)根据在 请求时的 GET/POST 来按照响应的 doGet() /doPost()方法来处理(有可能是一些业务逻辑,也有可能是一些验证等等,也有可能是一些数据查询,提交等等)其有效的数据就来源于name=simon&password=simonlv,还有其它的一些封装在 request 对象中的数据资源。

2)处理请求之后,由 response 对象得到 PriterWriter 输出流对象out ,通过 out.println () 将数据以 在客户端提交过的采用的Accpt: 中形式的一种 如 按照 response.setcontentType("text/html;charset=gb2312' )的格式输出流。

它的响应信息与请求信息非常类似,其区别就在于 我们在请求阶段的请求行被状态行给替换了,一个响应由四个部分组成:状态行、响应头标、空行、响应数据

1.状态行:状态行由三个标记组成:HTTP版本、响应代码和响应描述。

HTTP1.1 100 continue ------继续追加后继内容

HTTP1.1 200 OK -----一切正常

HTTP1.1 301 Moved Permanently ---请求的文档在其它地方,会自动连接

HTTP1.1 403 Forbidden -------绝对拒绝你访问这个资源,不管授权没有

HTTP1.1 400 Bad Request -----客户端请求中的不良语法

HTTP1.1 404 Not Found ---最常见,绝对是大名鼎鼎的找不到

HTTP响应码:

1xx:提示性信息,告诉客户端应该对某些其它的动作做出响应

2xx:这些就代表了请求成功

3xx:重定向,为了完成请求,必须进一步执行的动作

4xx:客户端错误

500-599:服务器端的错误

2.响应头标:像请求头标一样,它们指出服务器的功能,标识出响应数据的细节。

Date: Sat,31 Dec 2005 23:59:59 GMT --响应生成的日期和时间

ContentType: text/html;charset=gb2312'

Content-Length: 122 ---响应中的字节数,只在浏览器使用永久(Keep-alive)HTTP连接时需要。

3.空行:最后一个响应头标之后是一个空行,发送回车符和退行,表明服务器以下不再有头标。

4.响应数据:HTML文档和图像等,也就是HTML本身。out.println("").......写出的。。。

<html>

<head>

<title>Welcom to simon lv 's home</title>

</head>

<body>

<!-- 这里是具体的内容,看到了这里

相信大家对 HTTP 工作原理和服务器交互过程已经很清楚了吧

-->

</body>

</html>

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。