public void doGet (HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException
{
res.setContentType("text/html")
ServletOutputStream out = res.getOutputStream()
OutputStreamWriter ow = new OutputStreamWriter(out,"GB2312")
ow.write("这是测试")
ow.flush()
ow.close()
}
数据库服务器上不一定开了80端口呀,个人感觉判断网络是否通,还是使用Ping命令的好,如下:String ip = "127.0.0.1" // 使用正则,从Url中解析出数据库IP地址
System.out.println("ip = " + ip)
Process process = Runtime.getRuntime().exec("ping " + ip)// 执行Ping命令
DataInputStream dis = new DataInputStream(process.getInputStream())
byte[] buffer = new byte[1024 * 1000]
int len = dis.read(buffer)
StringBuffer sb = new StringBuffer()
while (len >0) {
sb.append(new String(buffer, 0, len))
len = dis.read(buffer)
}
System.out.println("ping result = " + sb.toString())
// 从Ping的结果中,解析出丢失率
Pattern p = Pattern.compile("(?<=\\().*%")
Matcher m = p.matcher(sb.toString())
boolean flag = true// 网络是否通
if (m.find()) {
String str = m.group()
System.out.println("lost = " + str)
// 如果丢失率等于100%,则说明网络不通
flag = str.equals("100%") ? false : true
}
System.out.println("the net is " + flag)
随着互联网的不断发展,用户在访问互联网的时候使用的终端设备类型也在不断的变化,但是这些都是基于http协议来实现的,下面我们就简单分析一下,http发送请求的处理过程。
HTTP协议是基于TCP协议的,所以它使用面向连接的方式发送请求,通过stream二进制流的方式传给对方。
当然,到了TCP层,它会把二进制流变成一个的报文段发送给服务器。
在发送给每个报文段的时候,都需要对方有一个回应ACK,来保证报文可靠地到达了对方。
如果没有回应,那么TCP这一层会进行重新传输,直到可以到达。
同一个包有可能被传了好多次,但是HTTP这一层不需要知道这一点,因为是TCP这一层在埋头苦干。
TCP层发送每一个报文的时候,都需要加上自己的地址(即源地址)和它想要去的地方(即目标地址),将这两个信息放到IP头里面,交给IP层进行传输。
IP层需要查看目标地址和自己是否是在同一个局域网。
如果是,就发送ARP协议来请求这个目标地址对应的MAC地址,然后将源MAC和目标MAC放入MAC头,发送出去即可。
如果不在同一个局域网,就需要发送到网关,还要需要发送ARP协议,来获取网关的MAC地址,然后将源MAC和网关MAC放入MAC头,发送出去。
网关收到包发现MAC符合,取出目标IP地址,根据路由协议找到下一跳的路由器,获取下一跳路由器的MAC地址,将包发给下一跳路由器。
这样路由器一跳一跳终于到达目标的局域网。
这个时候,后一跳的路由器能够发现,目标地址就在自己的某一个出口的局域网上。
于是,在这个局域网上发送ARP,获得这个目标地址的MAC地址,将包发出去。
目标的机器发现MAC地址符合,就将包收起来发现IP地址符合,根据IP头中协议项,知道自己上一层是TCP协议,于是解析TCP的头,里面有序列号,IT培训http://www.kmbdqn.cn/建议需要看一看这个序列包是不是我要的,如果是就放入缓存中然后返回一个ACK,如果不是就丢弃。
TCP头里面还有端口号,HTTP的服务器正在监听这个端口号。
于是,目标机器自然知道是HTTP服务器这个进程想要这个包,于是将包发给HTTP服务器。
HTTP服务器的进程看到,原来这个请求是要访问一个网页,于是就把这个网页发给客户端。