首页
社区
课程
招聘
关于LSP的问题
发表于: 2016-4-28 18:06 6580

关于LSP的问题

2016-4-28 18:06
6580
int socksProxy(SOCKET s, const struct sockaddr *name, int namelen)  
{  
    int rc = 0;
    //连接代理服务器  
        SOCKADDR_IN* addr =(SOCKADDR_IN*)name;
        DWORD GameServerPort;
        char GameServerIP[128];
        GameServerPort = ntohs(addr->sin_port);
        strcpy(GameServerIP,inet_ntoa(addr->sin_addr));

    sockaddr_in serveraddr;  
    memset(&serveraddr, 0, sizeof(serveraddr));  
    serveraddr.sin_family = AF_INET;   
        serveraddr.sin_addr.S_un.S_addr = inet_addr(lpmycurmsg->DailiIP); //代理服务器地址,从无忧代理网获取的,质量还行,不过只能用几天,发现连不上的话重新获取吧  
        serveraddr.sin_port = htons(lpmycurmsg->Port); // 端口号  
    WSABUF DataBuf;  
    char buffer[4];  
    memset(buffer, 0, sizeof(buffer));  
    DataBuf.len = 4;   
    DataBuf.buf = buffer;   
    int err = 0;  
    if((rc = NextProcTable.lpWSPConnect(s, (struct sockaddr *)&serveraddr, sizeof(struct sockaddr), &DataBuf, NULL, NULL, NULL, &err)) != 0)  
    {  
        PutDbgStr("Error %d : attempting to connect to SOCKS server!", err);  
        return rc;  
    }
    //发送请求来协商版本和认证方法  
    //VER   NMETHODS    METHODS  
    //1     1           1 to 255  
    struct timeval timeout ;  //后面的代码就是连接代理服务器的代码
        fd_set r;
        FD_ZERO(&r);  
        FD_SET(s, &r);  
        timeout.tv_sec = 5;   
        timeout.tv_usec =0;  
        rc = select(0, 0, &r, 0, &timeout);  
        if (rc < 0)  
        {
                PutDbgStr("Select Error!");
                return rc;
        }
        int nTimeout = 5000;  
        setsockopt(s, SOL_SOCKET, SO_RCVTIMEO, (char *)&nTimeout, sizeof(int));    //设置
        char buf[512];  
        memset(buf, 0, sizeof(buf));  
        struct TSock5req1 *proxyreq1;   
        proxyreq1 = (struct TSock5req1 *)buf;   
        proxyreq1->Ver = 5;   
        proxyreq1->nMethods = 2;   
        proxyreq1->Methods[0] = 0;
        proxyreq1->Methods[1] = 2;
    if((rc = send(s, buf, 4,0)) < 0)  
    {  
        PutDbgStr("Error %d : attempting to send SOCKS method negotiation!",  WSAGetLastError());  
        return rc;  
    }
    //接收代理服务器返回信息  
   
        struct TSock5ans1 *proxyans1;   
        proxyans1 = (struct TSock5ans1 *)buf;   
        memset(buf, 0, sizeof(buf));  
        FD_ZERO(&r);  
        FD_SET(s, &r);  
        timeout.tv_sec = 10;   
        timeout.tv_usec =0;
        rc = select(0, &r, 0, 0, &timeout);  
        if (rc < 0)
        {
        PutDbgStr("Select Error!");
                return rc;
        }         
        rc = recv(s, buf, sizeof(buf),0);
        if(proxyans1->Ver != 5 || (proxyans1->Method != 0 && proxyans1->Method != 2))   
        {
                PutDbgStr("版本不支持!");
                closesocket(s);
                return rc;
        }  
        if(proxyans1->Method == 2)   
        {   
                int nUserLen = strlen(lpmycurmsg->User);  //代理服务器的账号密码
                int nPassLen = strlen(lpmycurmsg->Pass);  

                buf[0] = 1;  
                buf[1] = nUserLen;  
                memcpy(buf + 2, lpmycurmsg->User, nUserLen);  
                buf[2 + nUserLen] = nPassLen;  
                memcpy(buf + 3 + nUserLen, lpmycurmsg->Pass, nPassLen);  
                send(s, buf, 3 + nUserLen + nPassLen,0);

                struct TAuthans *authans;   
                authans = (struct TAuthans *)buf;   
                memset(buf, 0, sizeof(buf));   
                FD_ZERO(&r);  
                FD_SET(s, &r);  
                timeout.tv_sec = 5;   
                timeout.tv_usec =0;
                rc = select(0, 0, &r, 0, &timeout);  
                if (rc < 0)
                {
                        PutDbgStr("Select Error!");
                    return rc;
                }
                rc = recv(s, buf, sizeof(buf),0);  
                if(authans->Ver != 1 || authans->Status != 0)   
                {
                        PutDbgStr("设置账号密码错误!");
                        return rc;
                }   
        }
  
        memset(buf, 0, sizeof(buf));  
        struct TSock5req2 *proxyreq2;   
        proxyreq2 = (struct TSock5req2 *)buf;   
        proxyreq2->Ver = 5;   
        proxyreq2->Cmd = 1;   
        proxyreq2->Rsv = 0;   
        proxyreq2->Atyp = 1;
        unsigned long tmpLong = inet_addr(GameServerIP);   //转发的游戏IP
        unsigned short port1 = ntohs(GameServerPort);   
        memcpy((char*)&proxyreq2->other, &tmpLong, 4);   
        memcpy((char*)(&proxyreq2->other) + 4, &port1, 2);   
        send(s, buf, 10,0);

        struct TSock5ans2 *proxyans2;   
        memset(buf ,0, sizeof(buf));   
        proxyans2 = (struct TSock5ans2 *)buf;  
        FD_ZERO(&r);  
        FD_SET(s, &r);  
        timeout.tv_sec = 5;   
        timeout.tv_usec =0;
        rc = select(0, &r, 0, 0, &timeout);  
        if (rc < 0)
        {
        PutDbgStr("Select Error!");
                return rc;
        }
  
        rc = recv(s, buf, sizeof(buf),0);
        if(proxyans2->Ver != 5 || proxyans2->Rep != 0)   
        {   
            PutDbgStr("创建联接失败!");
                return rc;
        }
    return 0;  
}

代码如上:

首先这个代码有问题吗?为什么每次都是输出”版本不支持“
麻烦大牛些给我看看啊。哪里可以找到这方面的资料啊。

[招生]系统0day安全班,企业级设备固件漏洞挖掘,Linux平台漏洞挖掘!

收藏
免费 0
支持
分享
最新回复 (8)
雪    币: 91
活跃值: (11)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
2
我自已架设了一个socket5代理服务器。可以正确运行,应该是我找的那些代理IP可能有问题吧。后期再观察
2016-4-28 21:06
0
雪    币: 5
活跃值: (11)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
关注学习了
2016-4-28 22:17
0
雪    币: 248
活跃值: (3789)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
关注,路过围观一下
2016-4-29 00:28
0
雪    币: 91
活跃值: (11)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
5
有个问题困扰很久了,我自已编写的TCP/IP通迅软件是可以通过代理服务器通信的。但是一换成游戏就不能正常了。lpWSPConnect这里调用是出错的。在网上收了好久的资料,估计是阻塞与非阻塞的问题,有哪位老大知道这里面的原因啊。
2016-5-4 15:34
0
雪    币: 29992
活跃值: (2642)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
6
哪里有这么简单。。。。。
举几个简单例子:
1、程序使用的是消息窗口,当wspconnect,你改为connect你的代理,成功后,系统发送此消息给原来注册的窗口过程,然后该过程可能开始收发数据,而你这边和代理交互,也需要收发数据,导致数据乱套。
你的在wsaselect的时候,保存窗口句柄和消息常量,连接代理前,先取消这个关联,处理完毕后,再SendMessage或postmessage给该保存的窗口。
2、事件Socket。同理。
3、完成端口Socket。同理。

另外,例如IE等很多是连接127.0.0.1的,你也没判断,这种应该直接放行。
路还远着呢。
2016-5-7 13:23
0
雪    币: 9
活跃值: (21)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
7
还有UDP的游戏
2016-6-7 11:42
0
雪    币: 9
活跃值: (21)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
8
建议自己搭建本地代理服务器
估计问题出在验证上
2016-6-14 13:54
0
雪    币: 142
活跃值: (60)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
9
用网络驱动实现很简单的
2016-12-30 11:24
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码