浅析Java web程序之客户端和服务器端交互原理

浅析Java web程序之客户端和服务器端交互原理
浅析Java web程序之客户端和服务器端交互原理

浅析Java web程序之客户端和服务器端交互原理

1. 协议

a. TCP/IP整体构架概述

TCP/IP协议并不完全符合OSI的七层参考模型。传统的开放式系统互连参考模型,是一种通信协议的7层抽象的参考模型,其中每一层执行某一特定任务。该模型的目的是使各种硬件在相同的层次上相互通信。这7层是:物理层、数据链路层、网路层、传输层、话路层、表示层和应用层。而TCP/IP通讯协议采用了4层的层级结构,每一层都呼叫它的下一层所提供的网络来完成自己的需求。这4层分别为:

i. 应用层:应用程序间沟通的层,如超文本传送协议(HTTP)、简单电子邮件传输(SMTP)、文件传输协议(FTP)、网络远程访问协议(Telnet)等。

ii. 传输层:在此层中,它提供了节点间的数据传送服务,如传输控制协议(TCP)、用户数据报协议(UDP)等,TCP和UDP给数据包加入传输数据并把它传输到下一层中,这一层负责传送数据,并且确定数据已被送达并接收。

iii. 互连网络层:负责提供基本的数据封包传送功能,让每一块数据包都能够到达目的主机(但不检查是否被正确接收),如网际协议(IP)。

iv. 网络接口层:对实际的网络媒体的管理,定义如何使用实际网络(如Ethernet、Serial Line等)来传送数据。

b. HTTP协议介绍:

i. HTTP是一种超文本传送协议(HyperText Transfer Protocol),是一套计算机在网络中通信的一种规则。在TCP/IP体系结构中,HTTP属于应用层协议,位于TCP/IP协议的顶层

ii. HTTP是一种无状态的的协议,意思是指在Web 浏览器(客户端)和Web 服务器之间不需要建立持久的连接。整个过程就是当一个客户端向服务器端发送一个请求(request),然后Web服务器返回一个响应 (response),之后连接就关闭了,在服务端此时是没有保留连接的信息。

iii. HTTP 遵循请求/响应(request/response) 模型的,所有的通信交互都被构造在一套请求和响应模型中。

iv. 浏览WEB时,浏览器通过HTTP协议与WEB服务器交换信息,Web服务器向Web浏览器返回的文件都有与之相关的类型,这些信息类型的格式由MIME定义。

1

c. 协议的java实现方式

不论是TCP/IP协议也好,还是HTTP协议也好,java都是通过套接字(https://www.360docs.net/doc/af9248593.html,.Socket)来实现的,可以参考我的另一篇技术博客:一个项目看java TCP/IP Socket编程(1.3版)

2. HTTP报文接口及客户端和服务器端交互原理

a. HTTP定义的事务处理由以下四步组成:

i. 建立连接:

例如我在浏览器里输入 https://www.360docs.net/doc/af9248593.html,,客户端请求这个地址时即打开了web服务器HTTP端口的一个套接字。因为在网络中间作为传递数据的实体介质就是网线,数据实质上是通过IO流进行输出和输入,这就不难理解我们为什么在写一个Servlet的时候要引用 import java.io.*; 的原因,包括我们在向客户端回发结果的时候要用到PrintWriter对象的println()方法。其实请求的这个地址还要加上端口号80,80可以不写,是因为浏览器默认的端口号是80。

在Java底层代码中是这样实现的,只不过它们已经帮我们做了。

Java代码

1.Socket socket = new Socket("https://www.360docs.net/doc/af9248593.html,",80);

2.InputStream in = socket.getInputStream();

3.OutputStream out = socket.getOutputStream();

ii. 客户端发送HTTP请求报文(request)

一旦建立了TCP连接,Web浏览器就会向Web服务器发送请求命令,是一个ASCII文本请求行,后跟0个或多个HTTP头标,一个空行和实现请求的任意数据。

即报文分四个部分:请求行,请求头标,空行和请求数据

1)请求行

请求行由三个标记组成:请求方法、请求URL和HTTP版本,中间用空格分开

例如: GET https://www.360docs.net/doc/af9248593.html,/blog/242842 HTTP/1.1

HTTP规范定义了8种可能的请求方法:(最常见的就是 GET 和 POST 两种方

2

法)

GET -- 检索URI中标识资源的一个简单请求

HEAD -- 与GET方法相同,服务器只返回状态行和头标,并不返回请求文档POST -- 服务器接受被写入客户端输出流中的数据的请求

PUT -- 服务器保存请求数据作为指定URI新内容的请求

DELETE -- 服务器删除URI中命名的资源的请求

OPTIONS -- 关于服务器支持的请求方法信息的请求

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

CONNECT -- 已文档化但当前未实现的一个方法,预留做隧道处理

2)请求头标

请求头标:由key :value 健值组成,每行一对。请求头标用来通知服务器有关客户端的功能和标识。

HOST -- 请求的哪一个服务器端地址,主地址,比如:我的技术blog:https://www.360docs.net/doc/af9248593.html,

User-Agent -- 用户即客户端可以使用的浏览器,如: Mozilla/4.0

Accept -- 即客户端可以接受的MIME 类型列表,如image/gif、text/html、application/msword

Content-Length -- 只适用于POST请求,以字节给出POST数据的尺寸

3)空行

发送回车符和退行,通知服务器以下不再有头标。

4)请求数据

使用POST传送数据,最常使用的是Content-Type和Content-Length头标。

请求报文总结:

我们可以这样写出一个标准的 HTTP请求:

POST /blog/242842 HTTP1.1

HOST: https://www.360docs.net/doc/af9248593.html,/

User-Agent: Mozilla/4.0

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

key=value&key=value&key=value...... (POST()请求的数据)

这上面的一个例子意思是:

我要去访问的服务器端的地址是https://www.360docs.net/doc/af9248593.html,/ 它下面的资源

/blog/242842

3

连起来就是: https://www.360docs.net/doc/af9248593.html,/blog/242842

这个页面用的是 HTTP1.1 规范,我的浏览器版本是Mozilla/4.0

可以支持的MIME格式为 image/gif,text/html,application/pdf,image/png...等等这个MIME格式我们在servlet中写法是:

response.setContentType("text/html;charset=gb2312");

或者在jsp中写法是:<%@ page

contentType="text/html;charset=gb2312"%>

或者在html中写法是:

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

GET /blog/242842?key=value&key=value&key=value......HTTP1.1

实际上用 GET 是这样传递数据的:

https://www.360docs.net/doc/af9248593.html,/?page=2......

iii.服务器端响应请求生成结果并回发(response)

Web 服务器解析请求,定位指定的资源

https://www.360docs.net/doc/af9248593.html,/blog/242842

1)根据请求时的 GET/POST 对应的用servlet里的 doGet() / doPost()方法来处理(有可能是一些业务逻辑,也有可能是一些验证等等,也有可能是一些数据查询,提交等等)其有效的数据就来源于

key=value&key=value&key=value......,以及其它的一些封装在 request 对象中的数据资源。

2)处理请求之后,由 response 对象得到 java.io.PrintWriter 输出流对象out,通过 out.println(); 将数据以指定的格式,如按照

response.setcontentType("text/html;charset=gb2312");的格式输出到输出流。

它的响应报文与请求报文非常类似,其区别就在于:我们在请求阶段的请求行被状态行给替换了,再来看响应报文:

3)一个响应报文由四个部分组成:状态行、响应头标、空行、响应数据:(a).状态行:

4

状态行由三个标记组成: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: 服务器端的错误

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

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

ContentType: 'text/html;charset=gb2312'

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

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

(d).响应数据:HTML文档和图像等,也就是HTML本身。

out.println("......");写到客户端。

Html代码

1.

2.

3.Welcome to cuishen's IT blog

4.

5.

6.

9.

10.

5

iv. 服务器端关闭连接,客户端解析回发响应报文,恢复页面

1)浏览器先解析状态行,查看请求是否成功的状态代码--HTTP响应码:404 400 200 ....

2)解析每一个响应头标,如:

ContentType:

text/html;charset=gb2312

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

3)读取响应数据HTML,根据标签中的内容恢复标准的HTML 格式页面或者其它。

4)一个HTML 文档可能包含其它的需要被载入的资源,浏览器会识别,并对这些资源再进行额外的请求,这个过程可以是循环的方式一直到所有的数据都按照响应头标中规定的格式恢复到页面中。

5)数据传送完毕,服务器端关闭连接,即无状态协议。

3. 总结

不要被高深的名词和理论吓到,其实HTTP客户端和服务器端的交互原理很简单:即先是浏览器和服务器端建立Socket无状态连接,也就是短连接,然后通过IO流进行报文信息(这个报文是严格遵循HTTP报文接口的)的交互,最后会话结束后就关闭连接。对于这些底层的协议和报文的打包解包交互的实现,其实java和浏览器早都已经封装好了,程序员只要专注于业务逻辑的实现就行啦,这些都不必关心!!

6

关于客户端与数据库服务器端的时间同步问题

关于客户端与数据库服务器端的时间同步问题 这是一个做C/S的管理软件开发时经常被忽略的问题,客户端的时间与服务器的时间如果有偏差,数据统计、报表等等肯定会有“意外”的情况发生。 意图很简单:从数据库服务器获取到时间,根据这个时间修改当前客户端电脑时间。 用Sql的函数getdate(),是比较容易的。 我们是基于dotnet4.0、EntityFramework开发软件,所以希望用ESQL的方式获取数据库服务器的时间,但昨天折腾了半天,还没搞定。 如果有哪位同学已经解决了这个问题,希望能指点一下! 暂时解决,之所以说是暂时,是因为并没有用Esql的方式,而是用T-Sql的方式。 以下是我的过程: System.Data.EntityClient.EntityConnection 这个是实体概念模型与数据源的连接,继承自DbConnection 在这个连接下CreateCommand(),就需要写Esql语句,我的语句是"SELECT VALUE CurrentDateTime()",却是语法错误。翻遍了手册和网络查询,没有任何有用的结果。 但在这个连接对象下有一个属性StoreConnection,返回的是Sql方式的连接,在这个下面CreateCommand(),可以写T-Sql语句,我的语句是"SELECT getdate()",运行成功。

以上是程序代码例子: //与数据库服务器的时间进行同步 System.Data.EntityClient.EntityConnection conn = (System.D ata.EntityClient.EntityConnection)Blemployee.myData.Conne ction ; IDbConnection conn0=conn.StoreConnection; IDbCommand comm =conn0.CreateCommand(); //https://www.360docs.net/doc/af9248593.html,mandText = "SELECT VALUE CurrentDateTime()"; https://www.360docs.net/doc/af9248593.html,mandText = "SELECT getdate()"; https://www.360docs.net/doc/af9248593.html,mandType = CommandType.Text; if (comm.Connection.State != ConnectionState.Open) comm.Connection.Open(); object tt= comm.ExecuteScalar(); DateTime sqlDT = Convert.ToDateTime(tt); SetLocalTime(sqlDT); //设置本机时间

Java

第1章 Java概述 1.1 练习 1、理解Java语言的“完全面向对象”、“解释性”、“可移植性”、“内 存动态管理”的特点。 2、搭建Java运行环境,并写一个Java程序打印出“我一定把Web程序设计学好!”; 3、理解Java程序的运行过程即JVM工作原理; 4、有一个Java源文件A.java,编译源文件和运行class文件的命令是什么? 5、修正Test1.java、Test2.java、Test3.java、Test4.java四个java源 文件中的错误,使其能够编译和运行; ① Test1.j ava源程序。 public class Test1 { public static void main(String[] args) { System.out.println("What's wrong with this program?"); } } public class TestAnother1 { public static void main(String[] args) { System.out.println("What's wrong with this program?"); } } ② Test2.java public class Testing2 { public static void main(String[] args) { System.out.println("What's wrong with this program?"); } } ③ Test3.java public class Test3 { public static void main(String args) { System.out.println("What's wrong with this program?"); } } ④Test4.java public class Test4 { public void main(String[] args) {

服务器端与客户端建立并连接小Demo

服务器端代码: using https://www.360docs.net/doc/af9248593.html,; using https://www.360docs.net/doc/af9248593.html,.Sockets; Static void Main(string[] args){ Socket serverSocket=new Socket(AddressFamily.InterNetWork,SocketType.Stream,ProtocalTy pe.TCP); //new一个Socket对象,注意这里用的是流式Socket(针对于面向连接的TCP服务应用)而不是数据报式Socket(针对于面向无连接的UDP服务应用)。 IPAddress serverIP=IPAddress.Parse("127.0.0.1"); int port=2112; IPEndPoint ipEndPoint=new IPEndPoint(serverIP,port);//网络节点对象 serverSocket.Bind(ipEndPoint);//将结点绑定到套接字上 serverSocket.Listen(10);//设置连接队列的最大长度,可根据服务器的性能,可以设置更大程度。 Console.WriteLine("服务器已就绪准备客户端连接。。。。"); while(true){//循环监听端口,得到客户端连接 Socket socket=serverSocket.Accept();//当有客户端连接时,就产生一个socket实例 SessionServer sserver=new SessionServer(socket);//将socket实例传入到消息处理类中 Thread t=new Thread(sserver.GetClientMsg);//当有一个客户端连接,就启动一个线程来处理此客户端的消息 t.Start();

iCloud服务与客户端下载使用教程

iOS设备篇 苹果寄予厚望,在iOS5升级占有重要地位的iCloud云服务正式发布了。下面就让小编带领大家,体验苹果为我们奉上的云服务大餐。 在iOS设备中,首先需要确保升级iOS5。所有iOS5 GM版本以前的固件,都不被iCloud 云服务支持。相应的,电脑管理iTunes也要升级到10.5版本。 在iOS5固件更新完成后,系统在欢迎界面会自动提醒你注册Apple ID和打开iCloud 云服务。由于iOS5的众多服务都直接与Apple ID关联,所以注册一个自己使用的ID是必须的。 iOS5更新完成后,进入系统设置选项,即可以见到iCloud的各种设置菜单。在这里,你可以自由选择那些应用的数据需要备份,并管理自己的空间。苹果免费为每位用户提供5GB的存储空间,如果需要更多空间,可以支付20美元10GB每年的服务费用,增加自己的存储容量。不过对于大多数人来说,5GB的免费空间已经足够使用。

iCloud还有一项重要的功能,即是可以同步更新所有iOS设备上的应用。什么意思呢,也就是说如果你在电脑端购买了一款应用或者图书等,那么你所有打开了自动下载选项的iOS设备,将会自动在后台下载新增内容。等到你拿起iOS设备时,你设备中已经出现了新购买的应用。不过这项功能的选项,不在iCloud菜单中,而是另外一个单独的Store菜单里,在这里,你可以选择需要自动下载的内容。 为了方便使用,苹果还推出了PC专用的iCloud程序,可以将PC上的内容也与iCloud 服务进行同步和管理。 首先用户需要前往苹果官网下载一个专用的应用iCloud Control Panel,目前还没有推出中文版,只有英、法、德、日这四个iPhone4S首发国家语言,不过相信很快中文版就会推出。 下载地址为:https://www.360docs.net/doc/af9248593.html,/kb/DL1455

客户端与服务器端交互原理

客户端与服务器端交互原理 经常看到HTTP客户端与服务器端交互原理的各种版本的文章,但是专业术语太多,且流程过于复杂,不容易消化。于是就按照在Servlet 里面的内容大致做了一些穿插。本来连Tomcat容器和Servlet的生命周期也准备在这里一起写的,但怕过于庞大,于是就简单的引用了一些Servlet对象。这样的一个整个流程看下来,相信至少在理解HTTP协议和request和response是如何完成从请求到生成响应结果回发的。在后续的一些文章里会专门讲一讲Tomcat和Servlet 是如何处理请求和完成响应的,更多的是说明Servlet的生命周期。 HTTP介绍 1. HTTP是一种超文本传送协议(HyperText Transfer Protocol),是一套计算机在网络中通信的一种规则。在TCP/IP体系结构中,HTTP属于应用层协议,位于TCP/IP协议的顶层。 2. HTTP是一种无状态的协议,意思是指在Web浏览器(客户端)和Web 服务器之间不需要建立持久的连接。整个过程就是当一个客户端向服务器端发送一个请求(request),然后Web服务器返回一个响应(respo nse),之后连接就关闭了,在服务端此时是没有保留连接的信息。 3. HTTP遵循请求/响应(request/response)模型的,所有的通信交互都被构造在一套请求和响应模型中。 4. 浏览Web时,浏览器通过HTTP协议与Web服务器交换信息,Web服务器向Web 浏览器返回的文件都有与之相关的类型,这些信息类型的格式由 MIME 定义。 HTTP定义的事务处理由以下四步组成: 1. 建立连接。 2?客户端发送HTTP请求头。 3. 服务器端响应生成结果回发。 4. 服务器端关闭连接,客户端解析回发响应头,恢复页面。

Java虚拟机工作原理(JVM)

As the Java V irtual Machine is a stack-based machine, almost all of its instructions involve the operand stack in some way. Most instructions push values, pop values, or both as they perform their functions. Java虚拟机是基于栈的(stack-based machine)。几乎所有的java虚拟机的指令,都与操作数栈(operand stack)有关.绝大多数指令都会在执行自己功能的时候进行入栈、出栈操作。 1Java体系结构介绍 Javaís architecture arises out of four distinct but interrelated technologies, each of which is defined by a separate specification from Sun Microsystems: 1.1 Java体系结构包括哪几部分? Java体系结构包括4个独立但相关的技术 the Java programming language →程序设计语言 the Java class file format →字节码文件格式 the Java Application Programming Interface→应用编程接口 the Java V irtual Machine →虚拟机 1.2 什么是JVM java虚拟机和java API组成了java运行时。 1.3 JVM的主要任务。 Java虚拟机的主要任务是装载class文件并执行其中的字节码。 Java虚拟机包含了一个类装载器。 类装载器的体系结构 二种类装载器 启动类装载器 用户定义的类装载器 启动类装载器是JVM实现的一部分 当被装载的类引用另外一个类时,JVM就是使用装载第一个类的类装载器装载被引用的类。 1.4 为什么java容易被反编译? ●因为java程序是动态连接的。从一个类到另一个类的引用是符号化的。在静态连接的 可执行程序中。类之间的引用只是直接的指针或者偏移量。相反在java的class文件中,指向另一个类的引用通过字符串清楚的标明了所指向的这个类的名字。

客户机与服务器结构.

C/S 结构,即大家熟知的客户机和服务器结构。它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理分配到Client端和Server端来实现,降低了系统的通讯开销。目前大多数应用软件系统都是Client/Server形式的两层结构,由于现在的软件应用系统正在向分布式的Web应用发展,Web和 Client/Server 应用都可以进行同样的业务处理,应用不同的模块共享逻辑组件;因此,内部的和外部的用户都可以访问新的和现有的应用系统,通过现有应用系统中的逻辑可以扩展出新的应用系统。这也就是目前应用系统的发展方向。概要(Client/Server或客户/服务器模式):Client和Server常常分别处在相距很远的两台计算机上,Client程序的任务是将用户的要求提交给Server程序,再将Server程序返回的结果以特定的形式显示给用户;Server程序的任务是接收客户程序提出的服务请求,进行相应的处理,再将结果返回给客户程序。传统的C/S体系结构虽然采用的是开放模式,但这只是系统开发一级的开放性,在特定的应用中无论是Client端还是Server端都还需要特定的软件支持。由于没能提供用户真正期望的开放环境,C/S结构的软件需要针对不同的操作系统开发不同版本的软件,加之产品的更新换代十分快,已经很难适应百台电脑以上局域网用户同时使用。而且代价高,效率低。编辑本段C/S工作模式C/S 结构的基本原则是将计算机应用任务分解成多个子任务,由多台计算机分工完成,即采用“功能分布”原则。客户端完成数据处理,数据表示以及用户接口功能;服务器端完成DBMS的核心功能。这种客户请求服务、服务器提供服务的处理方式是一种新型的计算机应用模式。编辑本段C/S结构的优点C/S结构的优点是能充分发挥客户端PC的处理能力,很多工作可以在客户端处理后再提交给服务器。对应的优点就是客户端响应速度快。缺点主要有以下几个:只适用于局域网。而随着互联网的飞速发展,移动办公和分布式办公越来越普及,这需要我们的系统具有扩展性。这种方式远程访问需要专门的技术,同时要对系统进行专门的设计来处理分布式的数据。客户端需要安装专用的客户端软件。首先涉及到安装的工作量,其次任何一台电脑出问题,如病毒、硬件损坏,都需要进行安装或维护。特别是有很多分部或专卖店的情况,不是工作量的问题,而是路程的问题。还有,系统软件升级时,每一台客户

c#带界面-客户端与服务器通信TCP

服务器端界面 服务器端代码: using System; using System.Collections.Generic; using https://www.360docs.net/doc/af9248593.html,ponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using https://www.360docs.net/doc/af9248593.html,.Sockets; using System.Threading; using System.IO; using https://www.360docs.net/doc/af9248593.html,; using System.Collections; namespace IMS.Server { public partial class Server : Form { TcpListener myListener; TcpClient tcpClient = new TcpClient(); Thread mythread; NetworkStream ns;

public Server() { InitializeComponent(); } private void Server_Load(object sender, EventArgs e) { Control.CheckForIllegalCrossThreadCalls = false; mythread = new Thread(new ThreadStart(receive)); mythread.IsBackground = true; mythread.Start(); } private void receive() { myListener = new TcpListener(IPAddress.Parse("192.168.1.106"), 8080); myListener.Start(); tcpClient = myListener.AcceptTcpClient(); while (true) { string rec = ""; ns = tcpClient.GetStream(); byte[] bytes = new byte[1024]; ns.Read(bytes,0,bytes.Length); rec = Encoding.Unicode.GetString(bytes); richTextBox1.Text = rec; ns.Flush(); } } private void btnSend_Click(object sender, EventArgs e) { try { ns = tcpClient.GetStream(); byte[] bytes = new byte[1024]; // bytes = Encoding.Unicode.GetBytes(sendmsg); bytes = Encoding.Unicode.GetBytes(richTextBox1.Text +"\r\n" + "服务器说:" + richTextBox2.Text);

Java的数据结构相关的类实现原理

Java的数据结构相关的类实现原理 List接口 List是有序的Collection,使用此接口能够精确的控制每个元素插入的位置。用户能够使用索引(元素在List中的位置,类似于数组下标)来访问List中的元素,这类似于Java的数组。 和下面要提到的Set不同,List允许有相同的元素。 除了具有Collection接口必备的iterator()方法外,List还提供一个listIterator()方法,返回一个ListIterator接口,和标准的Iterator接口相比,ListIterator多了一些add()之类的方法,允许添加,删除,设定元素,还能向前或向后遍历。 实现List接口的常用类有LinkedList,ArrayList,Vector和Stack。 LinkedList List 接口的链接列表实现。实现所有可选的列表操作,并且允许所有元素(包括 null)。除了实现 List 接口外,LinkedList 类还为在列表的开头及结尾 get、remove 和 insert 元素提供了统一的命名方法。这些操作允许将链接列表用作堆栈、队列或双端队列。 此类实现 Deque 接口,为 add、poll 提供先进先出队列操作,以及其他堆栈和双端队列操作。 所有操作都是按照双重链接列表的需要执行的。在列表中编索引的操作将从开头或结尾遍历列表(从靠近指定索引的一端)。 注意,此实现不是同步的。如果多个线程同时访问一个链接列表,而其中至少一个线程从结构上修改了该列表,则它必须保持外部同步。(结构修改指添加或删除一个或多个元素的任何操作;仅设置元素的值不是结构修改。)这一般通过对自然封装该列表的对象进行同步操作来完成。如果不存在这样的对象,则应该使 用 Collections.synchronizedList 方法来“包装”该列表。最好在创建时完成这一操作,以防止对列表进行意外的不同步访问,如下所示: List list = Collections.synchronizedList(new LinkedList(...)); 此类的 iterator 和 listIterator 方法返回的迭代器是快速失败的:在迭代器创建之后,如果从结构上对列表进行修改,除非通过迭代器自身的remove 或 add 方法,其他任何时间任何方式的修改,迭代器都将抛 出 ConcurrentModificationException。因此,面对并发的修改,迭代器很快就会完全失败,而不冒将来不确定的时间任意发生不确定行为的风险。 注意,迭代器的快速失败行为不能得到保证,一般来说,存在不同步的并发修改时,不可能作出任何硬性保证。快速失败迭代器尽最大努力抛出ConcurrentModificationException。因此,编写依赖于此异常的程序的方式是错误的,正确做法是:迭代器的快速失败行为应该仅用于检测程序错误。 ArrayList

客户端与服务器端

Qt编写TCP通讯程序客户端与服务器端 说明:这是本人的练手之作,学习这个程序花费了大量时间,学习过程中借鉴了网友的成果。现在百忙之中将我的学习成果制作成学习教程供大家学习。同时我也希望大家都将自己的学习成果发布到网上,让大家共享。 由于我是初学者,该程序肯定会有BUG和许多需要改进的地方。有需要讨论的请加我的QQ:489478088,加我时请注明:QT学习讨论。或者加入我的QQ群84998716。 下载源代码后,由于不同版本的QT Creator创建的环境不同,可能无法正确运行,所以打开后,QT Creator可能会提示QT Creator发现其他环境的配置文件,问是否要载入,选择No。提示如下: 这时要选择NO。如果还无法运行,那你就只好新建一个工程,把我的源文件代码全部复制到你的新建工程里,再运行。 下面,开始讲解如何编写TCP测试软件: 第一步,创建工程,选中QtNetwork支持,基类选择Widget。如果创建工程中没有QtNetwork 选项,在工程建好后,在工程文件*.pro文件里QT+=core gui语句后面加入QT+=network 否则编译将出现“QNetworkInterface: No such file o”等错误 第二步,新建->文件或工程->选择QT项目->选择qt设计师界面类->选择Dialog without buttons,类名为client,完成。 编辑client ui界面,右击空白部分,将对象名称改为“client”,在界面添加标签按钮等,添加完成如下:

第三步,服务器地址行编辑器(Line Edit)的对象名改为clientIPlineEdit;数据发送区行编辑器(Line Edit)的对象名改为clientMessagelineEdit; 端口行编辑器(Line Edit)的对象名改为clientPortlineEdit; 数据显示区行编辑器(textBrowser)的对象名改为messagetextBrowser;发送按钮的对象名改为clientSendpushButton; 清空按钮的对象名改为cCleanpushButton; 连接按钮的对象名改为connectpushButton; 断开按钮的对象名改为disconnectpushButton; Ready标签的对象名改为cStatuslabel。 第四步,编辑client.h文件 1.添加: #include #include 2.在函数class client:public QDialog添加 private: QListIPlist; QTcpServer*tcpServer; QTcpSocket*tcpClient; QString clientPort; QString serverIP; QString clientMessage;//客户端发出的信息 QString message; quint16blockSize;//存放文件的大小信息 QTcpSocket*clientConnection; private slots: void clientSendMessage(); void updateStatus(); void readMessage();//接收数据

Linux网络编程-简单的客户端和服务器通讯程序开发入门

Linux网络编程-基础知识(1) 1. Linux网络知识介绍 1.1 客户端程序和服务端程序 网络程序和普通的程序有一个最大的区别是网络程序是由两个部分组成的--客户端和服务器端. 网络程序是先有服务器程序启动,等待客户端的程序运行并建立连接. 一般的来说是服务端的程序在一个端口上监听,直到有一个客户端的程序发来了请求. 1.2 常用的命令 由于网络程序是有两个部分组成,所以在调试的时候比较麻烦,为此我们有必要知道一些常用的网络命令 netstat 命令netstat是用来显示网络的连接,路由表和接口统计等网络的信息. netstat有许多的选项我们常用的选项是-an 用来显示详细的网络状态.至于其它的选项我们可以使用帮助手册获得详细的情况. telnet telnet是一个用来远程控制的程序,但是我们完全可以用这个程序来调试我们的服务端程序的. 比如我们的服务器程序在监听8888端口,我们可以用telnet localhost 8888来查看服务端的状况. 1.3 TCP/UDP介绍 TCP(Transfer Control Protocol)传输控制协议是一种面向连接的协议, 当我们的网络程序使用这个协议的时候,网络可以保证我们的客户端和服务端的连接是可靠的,安全的. UDP(User Datagram Protocol)用户数据报协议是一种非面向连接的协议, 这种协议并不能保证我们的网络程序的连接是可靠的,所以我们现在编写的程序一般是采用TCP协议的. Linux网络编程-简单的客户端和服务器通讯程序开发入门(2)简介: 本文详细介绍了Linux下B/S结构的客户端服务器通讯程序的开发入门, 其中对重要的网络函数和结构体作了详细的说明和分析, 最后给出一个简单的客户端和服务器通讯程序示例以加深理解。 2. 初等网络函数介绍(TCP) Linux系统是通过提供套接字(socket)来进行网络编程的.网络程序通过socket和其它几个函数的调用, 会返回一个通讯的文件描述符,我们可以将这个描述符看成普通的文件的描述符来操作, 这就是linux的设备无关性的好处.我们可以通过向描述符读写操作实现网络之间的数据交流. 2.1 socket

java web拦截器配置及原理

java web 过滤器 (2013-03-01 10:04:24)本人转载收藏 ServletFilter,Servlet过滤器: Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,WEB开发人员通过Filter技术可以对web服务器管理的所有web资源:Jsp, Servlet, 静态图片文件或静态html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL 级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。ServletAPI提供了一个Filter接口,实现这个接口的Servlet就是一个过虑器。过虑器在WEB应用访问流程中如下: 由图可见,只要我们编写了过滤器,可以对一切访问WEB应用的连接进行过滤。比如,用户访问权限、统一WEB编码… Filter是如何实现拦截的? 实现了Filter接口的Servlet是过滤器,因为Filter接口有一个 doFilter(ServletRequest request, ServletResponse response, FilterChain chain)方法,只要用户访问我们在web.xml中配置的映射目录,服务器便会调用过滤器的doFilter方法。我们在这里实现过虑功能代码,当我们调用 chain.doFilter(request, response);方法时,将请求反给服务器服务器再去调用相当的Servlet。如果我们不调用此方法,说明拒绝了用户的请求。 Filter开发入门: 在WEB应用中添加一个过滤器,有两步工作需要完成: 1.编写实现了Filter接口的Servlet——过滤器。 2.在web.xml中配置过滤器: (1). 标签添加器 (2). 注册过滤器的映射目录(过滤目录),与注册Servlet一样。 在实际WEB应用中,我们可能需要编写多个过虑器,比如:1.统一WEB编码的过滤器(过虑所有访问)2.用户访问权限管理。这样,用户的访问需要选经过过滤器1过滤然后再经过过滤器2过滤。doFilter中有一个FilterChain参数,这个参数是服务器根据web.xml中配置的过滤器,按照先后顺序生成的过滤器链。当我们在doFilter方法中调用chain.doFilter(request, response);方法时,服务器会查找过滤链中是否还有过滤器,如果有继续调用下一个过滤器,如果没有将调用相应的Servlet处理用户请求。 Filter接口的其他细节: 1.Filter的Init(FilterConfig filterConfig)方法: 与Servlet的Init方法一样,在创建时被调用,之后被保存在内存中直至服务器重启或关闭时Filter实例才会被销毁。与Servlet不同之处在于,服务器启动时就会实例化所有Filter,而Servlet中有当用户第一次访问它时才会被实例化。我们通过在web.xml使用对Filter配置的初始化参数,可以通过FilterConfig来获得。 FilterConfig的方法有: String getFilterName():得到filter的名称。

服务器和客户端通信

实验六基于TCP/IP的网络编程 1 实验目的 MFC提供的关于网络应用的类CSocket是一个比较高级的封装,使用它编制出属于自己的网络应用程序,可以编一个属于自己的网络通讯软件。通过这个实验,同学们也可以增进对于TCP/IP协议的理解。 2 实验内容 基于TCP/IP的通信基本上都是利用SOCKET套接字进行数据通讯,程序一般分为服务器端和用户端两部分。设计思路(VC6.0下): 第一部分服务器端 一、创建服务器套接字(create)。 二、服务器套接字进行信息绑定(bind),并开始监听连接(listen)。 三、接受来自用户端的连接请求(accept)。 四、开始数据传输(send/receive)。 五、关闭套接字(closesocket)。 第二部分客户端 一、创建客户套接字(create)。 二、与远程服务器进行连接(connect),如被接受则创建接收进程。 三、开始数据传输(send/receive)。 四、关闭套接字(closesocket)。 CSocket的编程步骤:(注意我们一定要在创建MFC程序第二步的时候选上Windows Socket 选项,其中ServerSocket是服务器端用到的,ClientSocket是客户端用的。) (1)构造CSocket对象,如下例: CSocket ServerSocket; CSocket ClientSocket; (2)CSocket对象的Create函数用来创建Windows Socket,Create()函数会自行调用Bind()函数将此Socket绑定到指定的地址上面。如下例: ServerSocket.Create(823); //服务器端需要指定一个端口号,我们用823。ClientSocket.Create(); //客户端不用指定端口号。 (3)现在已经创建完基本的Socket对象了,现在我们来启动它,对于服务器端,我们需要这个Socket不停的监听是否有来自于网络上的连接请求,如下例: ServerSocket.Listen(5);//参数5是表示我们的待处理Socket队列中最多能有几个Socket。(4)对于客户端我们就要实行连接了,具体实现如下例: ClientSocket.Connect(CString SerAddress,Unsinged int SerPort);//其中SerAddress是服务器的IP地址,SerPort是端口号。 (5)服务器是怎么来接受这份连接的呢?它会进一步调用Accept(ReceiveSocket)来接收它,而此时服务器端还须建立一个新的CSocket对象,用它来和客户端进行交流。如下例:CSocket ReceiveSocket; ServerSocket.Accept(ReceiveSocket); (6)如果想在两个程序之间接收或发送信息,MFC也提供了相应的函数。 (7)代码 package test.socket3; import java.awt.event.ActionEvent; import java.awt.event.ActionListener;

Java基础之映射表

映射表 Java类库为映射表提供了两个通用的实现:HashMap和TreeMap。这两个类都实现了Map接口。 散列映射表对键进行散列,树映射表用键的整体对元素进行排序,并将其组织成搜索树。 每当往映射表中添加对象时,必须同时提供一个键。 要想检索一个对象,必须也提供一个键。 1常见操作: V put(K key,V value)(键可以为null,但值不能为null) V get(K key) V remove(K key) boolean containsKey(Object key) 如果在映射表中应经有这个键,返回true boolean containsValue(Object value) 如果在映射表中应经有这个值,返回true size方法用于返回映射表中的元素数。 2举例: HashMapitems=new HashMap(); items.put(src.charAt(i),1); items.containsKey(src.charAt(i) 3HashMap的底层实现原理 在Java编程语言中,最基本的结构就是两种,一个是数组,另外一个是模拟指针(引用),所有的数据结构都可以用这两个基本结构来构造的,HashMap也不例外。HashMap实际上是一个“链表散列”的数据结构,即数组和链表的结合体。 一个线性的数组怎么实现按键值对来存取数据呢?这里HashMap有做一些处理。 首先HashMap里面实现一个静态内部类Entry,基本结构它包含三个类key,value和指向下一个Entity的next,我们上面说到HashMap的基

客户端和服务器端判断请求来至微信客户端

有两种情况: client端区分 添加js代码 1.var browser={ 2. 3.versions:function(){ 4. 5.var u = https://www.360docs.net/doc/af9248593.html,erAgent, app = navigator.appVersion; 6. 7.return {//移动终端浏览器版本信息 8. 9.trident: u.indexOf('Trident') > -1, //IE内核 10. 11.presto: u.indexOf('Presto') > -1, //opera内核 12. 13.webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核 14. 15.gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核 16. 17.mobile: !!u.match(/AppleWebKit.*Mobile.*/)||!!u.match(/AppleWebKit/), //是否 为移动终端 18. 19.ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端 20. 21.android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端 或者uc浏览器 22. 23.iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者 QQHD浏览器 24. 25.iPad: u.indexOf('iPad') > -1, //是否iPad 26. 27.webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部 28. 29.}; 30. 31.}(), 32. https://www.360docs.net/doc/af9248593.html,nguage:(navigator.browserLanguage || https://www.360docs.net/doc/af9248593.html,nguage).toLowerCase() 34. 35.} 36.

oracle服务器端与客户端配置

近段时间很多网友提出监听配置相关问题,客户终端(Client)无法连接服务器端(Server)。本文现对监听配置作一简单介绍,并提出一些客户终端无法连接服务器端的解决思路,愿对广大网友与读者有一些帮助。 一、监听器(LISTENER) 监听器是Oracle基于服务器端的一种网络服务,主要用于监听客户端向数据库服务器端提出的连接请求。既然是基于服务器端的服务,那么它也只存在于数据库服务器端,进行监听器的设置也是在数据库服务器端完成的。 二、本地服务名(Tnsname) Oracle客户端与服务器端的连接是通过客户端发出连接请求,由服务器端监听器对客户端连接请求进行合法检查,如果连接请求有效,则进行连接,否则拒绝该连接。 本地服务名是Oracle客户端网络配置的一种,另外还有Oracle名字服务器(Oracle Names Server)等。Oracle常用的客户端配置就是采用的本地服务名,本文中介绍的也主要是基于本地服务名的配置。 三、Oracle网络连接配置方法 配置Oracle服务器端与客户端都可以在其自带的图形化Oracle网络管理器(Oracle Net Manager)里完成(强烈建议在这个图形化的工具下完成Oracle 服务端或客户端的配置)。在Windows下,点击“开始/程序/Oracle - OraHome92/Configuration and Migration Tools/Net Manager”启动Oracle 网络管理器工具,在Linux/Unix下,利用netmgr命令来启动图形化Oracle网络管理器,如: $ netmgr Windows下启动Net Manager图形窗口如下图示:

Java开发中的Memcache原理及实现

Java开发中的Memcache原理及实现 作者:jiaxiaoyuan1204 整理:chaijunkun 来源:https://www.360docs.net/doc/af9248593.html,/

一、概述 1. Memcache是什么 Memcache(Memcached)是集群环境下的缓存解决方案。 Memcache是https://www.360docs.net/doc/af9248593.html,的一个项目,最早是为LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力。它可以应对任意多个连接,使用非阻塞的网络IO。它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached自管理这些HashTable。 Memcache官方网站:https://www.360docs.net/doc/af9248593.html,/memcached,更多详细的信息可以来这里了解。 2. 为什么会有Memcache和memcached两种名称 其实Memcache是这个项目的名称,而memcached是它服务器端的主程序文件名,知道我的意思了吧。一个是项目名称,一个是主程序文件名,在网上看到了很多人不明白,于是混用了。 3. 如何在Java开发中使用Memcache 在Java开发中使用Memcache,一般要用到以下几个程序: 1) Memcached 该程序用来在Linux或Windows服务器上建立和管理缓存。 其项目网址为:https://www.360docs.net/doc/af9248593.html,/memcached/。 2) Magent Magent是一款开源的Memcached代理服务器软件,使用它可以搭建高可用性的集群应用的Memcached服务,其项目网址为:https://www.360docs.net/doc/af9248593.html,/p/memagent/。 3) Memcached客户端程序 至于Memcached的客户端程序,一般推荐用memcached client for java,为什么推荐用这种客户端,后面会讲到具体的原因,其项目的网址为: https://www.360docs.net/doc/af9248593.html,/gwhalin/Memcached-Java-Client/。 4)其它程序 i. Libevent 在Linux环境下应用Memcache时,Memcache用到了libevent这个库,用于Socket的处理,所以还需要安装libevent。libevent的最新版本是libevent-1.4.13。(如果你的系统已经安装了libevent,可以不用安装)。 官网:https://www.360docs.net/doc/af9248593.html,/~provos/libevent/ 下载:https://www.360docs.net/doc/af9248593.html,/~provos/libevent-1.4.13-stable.tar.gz ii. Windows下的安装程序 Memcache也可以安装在Windows服务器下,安装程序:memcached-1.2.1-win32.zip

客户端与服务器通信

SimpleChatServer.java package test.chatclient; import java.io.*; import https://www.360docs.net/doc/af9248593.html,.*; import java.util.*; public class SimpleChatServer { ArrayList clientOutputStreams; public static void main(String[] args){ new SimpleChatServer().go(); } public class ClientHandler implements Runnable{ BufferedReader reader; Socket sock; public ClientHandler(Socket clientSocket){ try{ sock = clientSocket; InputStreamReader isReader = new InputStreamReader(sock.getInputStream()); reader = new BufferedReader(isReader); }catch(Exception ex){ ex.printStackTrace(); } } @Override public void run() { String message; try{ while((message = reader.readLine()) != null){ System.out.println("read " + message); tellEveryone(message); } }catch(Exception ex){ ex.printStackTrace(); } } } public void tellEveryone(String message){ Iterator it = clientOutputStreams.iterator(); while(it.hasNext()){

相关文档
最新文档