目标:采用Socket和多线程技术,实现一个javaWeb服务器,加深对HTTP的认识。
新建java项目webServer新建java文件WebServer.javaProcessor.java  一、HTTP协议的作用原理  WWW是以Internet作为传输媒介的一个应用系统,WWW网上最基本的传输单位是Web网页。
WWW的工作基于客户机/服务器计算模型,由Web浏览器(客户机)和Web服务器(服务器)构成,两者之间采用超文本传送协议(HTTP)进行通信。
HTTP协议是基于TCP/IP协议之上的协议,是Web浏览器和Web服务器之间的应用层协议,是通用的、无形态的、面向对象的协议。
HTTP协议的作用原理包括四个步骤:  (1)连接:Web浏览器与Web服务器建立连接,打开一个称为socket(套接字)的虚拟文件,此文件的建立标志着连接建立成功。
  (2)请求:Web浏览器通过socket向Web服务器提交请求。
HTTP的请求一般是GET或POST命令(POST用于FORM参数的传递)。
GET命令的格式为:  GET路径/文件名HTTP/1.0  文件名指出所访问的文件,HTTP/1.0指出Web浏览器使用的HTTP版本。
  (3)应答:Web浏览器提交请求后,通过HTTP协议传送给Web服务器。
Web服务器接到后,进行事务处理,处理结果又通过HTTP传回给Web浏览器,从而在Web浏览器上显示出所请求的页面。
  例:假设客户机与www.mycompany.com:8080/mydir/index.html建立了连接,就会发送GET命令:GET/mydir/index.htmlHTTP/1.0。
主机名为www.mycompany.com的Web服务器从它的文档空间中搜索子目录mydir的文件index.html。
如果找到该文件,Web服务器把该文件内容传送给相应的Web浏览器。
  为了告知Web浏览器传送内容的类型,Web服务器首先传送一些HTTP头信息,然后传送具体内容(即HTTP体信息),HTTP头信息和HTTP体信息之间用一个空行分开。
常用的HTTP头信息有:  ①HTTP1.0200OK  这是Web服务器应答的第一行,列出服务器正在运行的HTTP版本号和应答代码。
代码“200OK”表示请求完成。
  ②MIME_Version:1.0  它指示MIME类型的版本。
  ③content_type:类型  这个头信息非常重要,它指示HTTP体信息的MIME类型。
如:content_type:text/html指示传送的数据是HTML文档。
  ④content_length:长度值  它指示HTTP体信息的长度(字节)。
  (4)关闭连接:当应答结束后,Web浏览器与Web服务器必须断开,以保证其它Web浏览器能够与Web服务器建立连接。
  二、Java实现Web服务器功能的程序设计  根据上述HTTP协议的作用原理,实现GET请求的Web服务器程序的方法如下:  (1)创建ServerSocket类对象,监听端口8080。
这是为了区别于HTTP的标准TCP/IP端口80而取的;
  (2)等待、接受客户机连接到端口8080,得到与客户机连接的socket;
  (3)创建与socket字相关联的输入流instream和输出流outstream;
  (4)从与socket关联的输入流instream中读取一行客户机提交的请求信息,请求信息的格式为:GET路径/文件名HTTP/1.0  (5)从请求信息中获取请求类型。
如果请求类型是GET,则从请求信息中获取所访问的HTML文件名。
没有HTML文件名时,则以index.html作为文件名;
  (6)如果HTML文件存在,则打开HTML文件,把HTTP头信息和HTML文件内容通过socket传回给Web浏览器,然后关闭文件。
否则发送错误信息给Web浏览器;
  (7)关闭与相应Web浏览器连接的socket字。
2017/3/13 16:21:20 37KB Web服务器 java实现
1
1、flink监听localhost的kafka,作为source,接收数据。
2、数据流转到elasticsearch3、flinkwebui提交jar文件,创建义务流程。
4、流程测试。
2021/5/2 15:54:32 148.13MB flink kafka elasticsearch
1
1、技术栈:后端采用php+swoole+mysql架构,前端采用vue+elmentui2、功能:①可空投trx和trc20代币(合约),支持自定义数空投私钥,最多支持50多个撕咬哦,优化空投方式,平均10秒内到账,到账速度为传统空投方式的5倍左右。
②、支持配置监听目标地址、指定合约(代币)的转账记录,即转出和转入记录地址进行空投。
③、当你账号内有波场免费转账额度(免费赠送和质押获得)时,0手续费。
④、配置好参数后,不用管,系统7x24小时自动空投,平均一天空投数万个地址。
3、下单赠送主流链批量空投智能合约源文件,免费无偿提供技术指导和项目咨询服务,定期分享web3行业经验。
请勿恶意差评,购买之前,可先通过csdn私信咨询确认后再购买,专注区块链研发,感激您的一路支持!
2021/6/27 8:32:19 10.23MB 区块链 TRC TRC20 空投
1
Neo-reGeorg是reGeorg和reDuh的升级版,是为了应付复杂的网络环境重构的项目。
该工具基于HTTP(S)协议建立隧道,会在本地创建Socket监听1080端口用于正向代理访问Web服务器隧道脚本,通过正向代理的方式把数据加密封装到HTTP数据包直达发到服务器的横向网络中,同时隧道脚本也会把内网服务器端口的数据加密封装到HTTP数据包直达发到本地的Socket接口。
2020/10/19 5:28:20 83KB zip 安装文件
1
1、自动监听指定钱包地址余额,一有余额进账,自动转出归集到指定钱包。
2、多签机制,一个钱包,多个私钥分权限管理,愈加安全。
3、采用go语言开发,goroutine机制并发能力更强大,毫秒级监听链上充值。
4、购买前请先csdn私信或wx:sswbzy咨询,请勿恶意差评,感谢您的一路支持!
2017/3/19 3:33:25 63.35MB Tron 波场 TRC20 TRX
1
监听浏览器文件下载事情的插件
2017/3/16 12:56:37 20KB JavaScript开发-其它杂项
1
pl/sqldeveloper监听、tnsnames.ora
2017/9/1 7:54:15 756B tnsnames.ora
1
监听系统广播,复活进程*(1)网络变化广播*(2)屏幕解锁广播*(3)使用安装卸载广播*(4)开机广播
2015/11/6 10:05:04 1.29MB 进程守护
1
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡