java学习-Socket类的学习

java的网络编程中一个重要的类就是Socket类,这个类封装了java的套接字操作。

首先,来看一下这个类的主要的构造函数

Socket() 创建一个未连接的套接字,并使用系统默认类型的SocketImpl。
Socket(InetAddress address, int port) 创建流套接字并将其连接到指定IP地址的指定端口号。
Socket(String host, int port)
创建流套接字并将其连接到指定主机上的指定端口号。

一般来说,第一个和最后一个构造函数使用的比较多,但是最后一个构造函数存在一个问题,那就是如果这个套接字没有连接上,那么会一直处于阻塞状态。所以一般使用的时候,需要这样使用

URL url = new URL(urlstr);
socket = new Socket();
socket.connect(new InetSocketAddress(url.getHost(),80));

这里URL类用来根据所给的String类型的url地址来创建一个URL实例,这个实例封装了URL的一些特征,并且提供了相应的set和get函数来获取这些特征,比如协议,主机,以及端口。

然后,再来看一下Socket这个类的常用的函数

close() 关闭这个套接字
connect(SocketAddress endpoint) 将此套接字连接到服务器。
connect(SocketAddress endpoint, int timeout) 将此套接字连接到具有指定超时值的服务器。
getInputStream() 返回此套接字的输入流。
getOutputStream() 返回此套接字的输出流。

还有一些设定套接字状态的其他函数,以及判断套接字是否打开的函数,这里就不一一赘述了,如果有兴趣可以看看API文档。

下面以一个简单的Demo来总结一下

package cn.ljtnono.net;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.InetSocketAddress;
import java.net.MalformedURLException;
import java.net.Socket;
import java.net.URL;
import java.net.UnknownHostException;

public class SpiderDemo1 {
    
    
    public static void main(String[] args) throws MalformedURLException {
        BufferedWriter bw = null;
        BufferedReader br = null;
        Socket socket = null;
        String urlstr = "http://www.ljtnono.cn/jsgl/";
        URL url; 
        try {
            url = new URL(urlstr);
            System.out.println(url.getHost());
            socket = new Socket();
            socket.connect(new InetSocketAddress(url.getHost(),80));
            socket.setSoTimeout(10000);
            OutputStream outputStream = socket.getOutputStream();
            bw = new BufferedWriter(new OutputStreamWriter(outputStream));
            bw.write("GET " + urlstr + " HTTP/1.0\r\n");
            bw.write("HOST:" + "118.89.247.210" + "\r\n");
            bw.write("\r\n");
            bw.flush();
            
//          bw.write("GET " + urlPojo.getUrl() + " HTTP/1.0\r\n");
//          bw.write("HOST:" + host + "\r\n");
//          //在行的结束符\r\n之前没有任何数据,说明  这时候代表协议族 http header输出给服务端完成
//          bw.write("\r\n");
//          bw.flush();
            InputStream inputStream = socket.getInputStream();
            br = new BufferedReader(new InputStreamReader(inputStream,"UTF-8"));
            String line = null;
            while ((line = br.readLine()) != null) {
                System.out.println(line);
            }
        } catch (UnknownHostException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } finally {
            try {
                if (br != null) {
                    br.close();
                }
                if (bw != null) {
                    bw.close();
                }
                if (socket != null) {
                    socket.close();
                }
            } catch (IOException e) {
                // TODO: handle exception
                e.printStackTrace();
            }
        }
    }
}

这个例子使用Socket套接字发送HTTP请求到服务器,然后将服务器相应的文本打印出来。
结果如下:

www.ljtnono.cn
HTTP/1.1 200 
Set-Cookie: JSESSIONID=F17B1A79492D26D62B4C3C4F6693D23A; Path=/jsgl; HttpOnly
Content-Type: text/html;charset=utf-8
Content-Length: 5869
Date: Wed, 31 Oct 2018 15:02:17 GMT
Connection: close




<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
    <title>login</title>
    <link rel="stylesheet" href="http://www.ljtnono.cn:80/jsgl/css/login.css">
    <link rel="shortcut icon" href="http://www.ljtnono.cn:80/jsgl/images/favicon.ico">
    <script src="http://www.ljtnono.cn:80/jsgl/js/jquery-1.11.0.js"></script>
    <script src="http://www.ljtnono.cn:80/jsgl/js/jquery.validate.js"></script>
    <script src="http://www.ljtnono.cn:80/jsgl/js/login.js"></script>
    
    <script>
        var _hmt = _hmt || [];
        (function() {
            var hm = document.createElement("script");
            hm.src = "https://hm.baidu.com/hm.js?fdc4cac3037f60100589fdd0cdd7b67a";
            var s = document.getElementsByTagName("script")[0];
            s.parentNode.insertBefore(hm, s);
        })();
    </script>
</head>
<body>
<h1>竞赛管理系统登录</h1>
<div class="login" style="margin-top:50px;">
    <div class="header">
        <div class="switch" id="switch">
            <a class="switch_btn_focus" id="switch_qlogin" href="javascript:void(0);" tabindex="7">快速登录</a>
            <a class="switch_btn" id="switch_login" href="javascript:void(0);" tabindex="8">快速注册</a>
            <div class="switch_bottom" id="switch_bottom" style="position: absolute; width: 64px; left: 0px;">
            </div>
        </div>
    </div>
    <div class="web_qr_login" id="web_qr_login" style="display: block; height: 235px;">
            <!--登录-->
        <div class="web_login" id="web_login">
            <div class="login-box">
                <div class="login_form">
                    <form action="http://www.ljtnono.cn:80/jsgl/user/login" name="loginform" accept-charset="utf-8" id="login_form" class="loginForm" method="post"><input type="hidden" name="did" value="0"/>
                        <input type="hidden" name="to" value="log"/>
                        <div class="uinArea" id="uinArea">
                            <label class="input-tips" for="u">帐号:</label>
                            <div class="inputOuter" id="uArea">
                                <input type="text" id="u" name="username" class="inputstyle"/>
                            </div>
                        </div>
                    <div class="pwdArea" id="pwdArea">
                        <label class="input-tips" for="p">密码:</label>
                        <div class="inputOuter" id="pArea">
                            <input type="password" id="p" name="password" class="inputstyle"/>
                        </div>
                    </div>
                        <div style="padding-left:50px;margin-top:20px;"><input type="submit" value="登 录" style="width:150px;" class="button_blue"/></div>
                    </form>
                </div>
            </div>
        </div>
        <!--登录end-->
    </div>
  <!--注册-->
    <div class="qlogin" id="qlogin" style="display: none;">
        <div class="web_login">
            <form name="form2" id="regUser" accept-charset="utf-8"  action="http://www.ljtnono.cn:80/jsgl/user/register" method="post">
                <input type="hidden" name="to" value="reg"/>
                <input type="hidden" name="did" value="0"/>
                <ul class="reg_form" id="reg-ul">
                    <li style="margin-top:20px;">
                        <label for="user"  class="input-tips2">用户名:</label>
                        <div class="inputOuter2">
                            <input type="text" id="user" name="username" maxlength="16" class="inputstyle2"/>
                        </div>
                    </li>
                    <li>
                        <label for="passwd" class="input-tips2">密码:</label>
                        <div class="inputOuter2">
                            <input type="password" id="passwd"  name="password" maxlength="16" class="inputstyle2"/>
                        </div>
                    </li>
                    <li>
                        <label for="passwd2" class="input-tips2">确认密码:</label>
                        <div class="inputOuter2">
                            <input type="password" id="passwd2" name="repassword" maxlength="16" class="inputstyle2" />
                        </div>
                    </li>
                    <li>
                        <label for="tel" class="input-tips2">电话:</label>
                        <div class="inputOuter2">
                            <input type="text" id="tel" name="tel" maxlength="20" class="inputstyle2"/>
                        </div>
                    </li>
                    <li>
                        <label for="qq" class="input-tips2">QQ:</label>
                        <div class="inputOuter2">
                            <input type="text" id="qq" name="qq" maxlength="10" class="inputstyle2"/>
                        </div>
                    </li>
                    <li>
                        <label for="mail" class="input-tips2">邮箱:</label>
                        <div class="inputOuter2">
                            <input type="text" id="mail" name="email" class="inputstyle2"/>
                        </div>
                    </li>
                    <li>
                        <div class="inputArea">
                            <input type="submit"id="reg"style="margin-top:10px;margin-left:85px;" class="button_blue" value="同意协议并注册"/>
                        </div>
                    </li>
                    <div class="cl"></div>
                </ul>
            </form>
        </div>
    </div>
    <!--注册end-->
</div>
</body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 230,825评论 6 546
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 99,814评论 3 429
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 178,980评论 0 384
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 64,064评论 1 319
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 72,779评论 6 414
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 56,109评论 1 330
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 44,099评论 3 450
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 43,287评论 0 291
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 49,799评论 1 338
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 41,515评论 3 361
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 43,750评论 1 375
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 39,221评论 5 365
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,933评论 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 35,327评论 0 28
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 36,667评论 1 296
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 52,492评论 3 400
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 48,703评论 2 380

推荐阅读更多精彩内容