通过win 2012 WEB服务器在其他电脑代理上网设置问题

通过win 2012 WEB服务器在其他电脑代理上网设置问题,第1张

使用IIS8做代理不好

你安装一个 squid for windows版本的,这个做代理非常好。

不过你要想访问国外网站,如果不做加密链接,youtub之类还是会被拦截掉的,所以还要想办法增加一层加密链接,然后再通过squid代理上网

代理程序的种类非常多,根据协议不同可以分成HTTP代理服务程序、FTP代理服务程序等,而运行代理服务程序的服务器也就相应称为HTTP代理服务器和FTP代理服务器。本文将介绍的Web代理服务程序代理的是HTTP协议。

  一、网络代理程序的优点

  代理服务所起的是一个桥的作用,它是网络信息的中转站。在网络中应用代理服务一般是基于以下几个原因:

  (1)充分利用IP地址资源。在局域网中,一般对外的IP地址都是非常有限的,为了保证局域网内部的主机都能够访问互联网资源,通过网络代理就可以实现。

  (2)能够保证网络安全。网络代理可以充当内部网和互联网之间的防火墙,通过过滤IP地址,限定某些IP地址对外部资源的访问。

  (3)能够有效地隐藏自己的IP地址和主机名。由于所有对外网的请求都是通过代理服务器实现的,所以目的主机只能知道代理服务器的IP地址。

  (4)提高网络速度。通常代理服务器都设有一个较大的硬盘缓冲区,它存储界数据,当你再访问相同的数据时,则可以直接从缓冲区中取出信息,从而提高访问速度。

  二、网络代理的类型及实现原理

  网络代理服务根据工作层次,一般可分为应用层代理、传输层代理和SOCKS代理。应用层代理是工作在TCP/IP参考模型的应用层之上,它支持对应用

层协议(如HTTP、FTP)的代理。它提供的控制最多,但是不灵活,必须要有相应的协议支持。如果协议不支持代理(如SMTP和POP),那就只能在应

用层以下代理,也即传输层代理。传输层代理直接与TCP层交互,更加灵活。要求代理服务器具有部分真正服务器的功能:监听特定TCP或UDP端口,接收客

户端的请求同时向客户端发出相应的响应。另一种代理需要改变客户端的IP栈,即SOCKS代理。它是可用的最强大、最灵活的代理标准协议。SOCK V4

允许代理服务器内部的客户端完全地连接到外部的服务器,SOCK V5增加了对客户端的授权和认证,因此它是一种安全性较高的代理。本节后面介绍的代理是

一种应用层上面的代理,所代理的协议是HTTP,也就是经常见到的Web代理。

  正如上面所说,网络代理就是一个连接客户端(需要代理的计算机)和服务器端(提供访问资源的服务器)的桥。要实现这种桥的功能,网络代理就必须满足下列条件,其实也是代理服务的运行的流程:

  (1)接收并解析客户端的请求。

  (2)创建到服务器的新连接,并转发客户端的请求信息。

  (3)接收服务器反馈的信息。

  (4)解释服务器的响应并将该响应传回给客户端。

  网络代理虽然有很多优点,但由于使用代理后,自己对网络的所有请求都是通过代理服务器这个中间人来实现的,所以有可能碰上存有恶意的人监听你的输入的内容。同样,如果选择的代理服务器的带宽比较小,使用代理还会降低网速。

  总而言之,使用代理有利有弊,使用者要根据自身的情况来决定。但无论如何,选择一个好的代理服务器是非常重要的。

  三、C#实现Web代理服务程序

  经过了上面的介绍,我想大家对代理服务应该有了一个基本的认识,下面就让我们通过一个实例来深入体会一下如何用C#实现Web代理服务。Web代理服务的功能顺序是这样的:

  (1)侦听端口,等待客户端浏览器发送来的Web请求信息。

  (2)接收到客户端Web请求信息后,解析出目标Web服务器的地址,并创建一个Socket实例,并以此实例连接Web服务器上。

  (3)通过创建的Socket传送客户端的Web请求数据包到Web服务器的80端口。

  (4)接收Web服务器返回的页面数据。

  (5)把接收来的数据传送到客户端,从而实现Web代理。

  客户端对某个Web地址的浏览,可能要传送很多的Web请求信息(比如网页中的图像、Flash等),为了更快更准确地处理这些信息,Web代理服务

程序通常采用多线程来处理每一个Web请求。细心的读者可能会发现,处理每一个客户端的Web请求信息,代理服务器软件都要使用二个Socket,一个是

用来接收/传送客户机的信息,一个是和Web服务器进行交流。为了区分这二个Socket,我们把和服务器对话的称为“服务Socket”,和客户端机器

对话的称为“客户Socket”。

  下面就开始Web代理服务程序的编写工作。这个实例包含三个部分内容:

  1创建一个Web代理类。

  2Web代理服务的类的实例化。

  3如何通过这个Web代理类的实例实现Web代理服务。

  (一)创建一个Web代理类

  具体操作步骤如下:

  1启动Visual StudioNet,依次选择“文件”、“新建”、“项目”菜单后,在弹出“新建项目”对话框中将“项目类型”设置为

“Visual C#项目”,将“模板”设置为“Windows应用程序”,在“名称”文本框中输入“WebProxy”,在“位置”文本框中输入

“E:VSNET项目”,然后单击“确定”按钮,这样项目便建立好了。

  2依次选择菜单“项目”、“添加类”,将弹出“添加新项”对话框。

  3将“模板”设置为“类”。

  4在“名称”文本框中输入“Proxy”,单击“打开”按钮

  5在“解决方案资源管理器”窗口中,双击Proxycs文件,进入Proxycs文件的编辑界

  6在Proxycs源文件的开头,添加下列代码,下列代码是导入Proxycs中要使用到的命名空间:

  using System;

  using SystemNet;

  using SystemNetSockets;

  using SystemText;

  using SystemIO;

  7用下列构造函数替代默认的构造函数。下面的代码是在Proxy类中创建一个构造函数。Proxy类只有一个构造函数,并且这个构造函数只有一个参数,这个参数是Socket对象,它主要用来和客户端进行数据交换,是一个“客户Socket”:

  public Proxy(Socket socket)

  {

  //

  // TODO: 在此处添加构造函数逻辑

  //

  thisclientSocket = socket ;

  }

  8在定义Proxy类代码区中加入下列代码,下列代码是定义Proxy类中的使用的一些变量,这些变量主要是在后面的定义Run方法中使用。

  Socket clientSocket;

  Byte[] read = new byte[1024];

  //定义一个空间,存储来自客户端请求数据包

  Byte [] Buffer = null;

  Encoding ASCII = EncodingASCII;

  //设定编码

  Byte[] RecvBytes = new Byte[4096];

  //定义一个空间,存储Web服务器返回的数据

  9创建Proxy类中的Run方法。Run方法是Proxy类中唯一的方法。其功能是从客户端接收HTTP请求,并传送到Web服务器,然后从

Web服务器接收反馈来的数据,并传送到客户端。为了实现这二个不同方面的数据传送,Run方法中是通过两个Socket实例来实现的。在编写Run方法

的时候,要注意下面两点:

  (1)由于HTTP建立于TCP协议之上,所以创建的Socket实例应该使用TCP协议。下面代码是创建可以传送HTTP请求命令到Web服务器和接收来自Web服务器反馈来信息的Socket实例:

  Socket IPsocket = new Socket(AddressFamilyInterNetwork, SocketTypeStream, ProtocolTypeTcp);

  (2)另外一个Socket是在代理服务程序侦听端口号,接收连接请求时候得到的,所以应该以此Socket为参数,利用Proxy类中的构造函数来创建一个Proxy实例。此Socket实现从客户端接收HTTP请求信息,并传送数据到客户端。

  Socket创建和使用是实现Web代理软件的关键。在构造函数代码后面,输入下列代码:

  public void Run()

  {

  string clientmessage = " " ;

  //存放来自客户端的HTTP请求字符串

  string URL = " " ;

  //存放解析出地址请求信息

  int bytes = ReadMessage(read, ref clientSocket, ref clientmessage);

  if (bytes == 0)

  {

  return ;

  }

  int index1 = clientmessageIndexOf(' ');

  int index2 = clientmessageIndexOf(' ', index1 + 1);

  if ((index1 == -1) || (index2 == -1))

  {

  throw new IOException();

  }

  string part1 = clientmessageSubstring(index1 + 1, index2 - index1);

  int index3 = part1IndexOf('/', index1 + 8);

  int index4 = part1IndexOf(' ', index1 + 8);

  int index5 = index4 - index3;

  URL = part1Substring(index1 + 4, (part1Length - index5) - 8);

  try

  {

  IPHostEntry IPHost = DnsResolve(URL);

  ConsoleWriteLine("远程主机名: " + IPHostHostName);

  string [] aliases = IPHostAliases;

  IPAddress[] address = IPHostAddressList;

  ConsoleWriteLine("Web服务器IP地址:" + address[0]);

  //解析出要访问的服务器地址

  IPEndPoint ipEndpoint = new IPEndPoint(address[0], 80);

  Socket IPsocket = new Socket(AddressFamilyInterNetwork, SocketTypeStream, ProtocolTypeTcp);

  //创建连接Web服务器端的Socket对象

  IPsocketConnect(ipEndpoint);

  //Socket连Web接服务器

  if (IPsocketConnected)

  ConsoleWriteLine("Socket 正确连接!");

  string GET = clientmessage;

  Byte[] ByteGet = ASCIIGetBytes(GET);

  IPsocketSend(ByteGet, ByteGetLength, 0);

  //代理访问软件对服务器端传送HTTP请求命令

  Int32 rBytes = IPsocketReceive(RecvBytes, RecvBytesLength, 0);

  //代理访问软件接收来自Web服务器端的反馈信息

  ConsoleWriteLine("接收字节数:" + rBytesToString());

  String strRetPage = null;

  strRetPage = strRetPage + ASCIIGetString(RecvBytes, 0, rBytes);

  while (rBytes > 0)

  {

  rBytes = IPsocketReceive(RecvBytes, RecvBytesLength, 0);

  strRetPage = strRetPage + ASCIIGetString(RecvBytes, 0, rBytes);

  }

  IPsocketShutdown(SocketShutdownBoth);

  IPsocketClose();

  SendMessage(clientSocket, strRetPage);

  //代理服务软件往客户端传送接收到的信息

  }

  catch (Exception exc2)

  

  }

  

  //接收客户端的HTTP请求数据

  private int ReadMessage(byte [] ByteArray, ref Socket s, ref String clientmessage)

  {

  int bytes = sReceive(ByteArray, 1024, 0);

  string messagefromclient = EncodingASCIIGetString(ByteArray);

  clientmessage = (String)messagefromclient;

  return bytes;

  }

  

  //传送从Web服务器反馈的数据到客户端

  private void SendMessage(Socket s, string message)

  {

  Buffer = new Byte[messageLength + 1];

  int length = ASCIIGetBytes(message, 0, messageLength, Buffer, 0);

  ConsoleWriteLine("传送字节数:" + lengthToString());

  sSend(Buffer, length, 0);

  }

  至此,Proxy类的定义过程就完成了。

  (二)利用Proxy类,实现Web代理

  下面是利用Proxy类实现Web代理程序的具体实现步骤,Proxy类被定义在命名空间WebProxy中:

  1在Visual Studio Net的代码编辑器中打开Class1cs文件,进入Class1cs的代码编辑界面。

  2在Class1cs源文件的开头导入下列命名空间:

  using System;

  using SystemNet;

  using SystemNetSockets;

  using SystemText;

  using SystemIO;

  using SystemThreading;

  using WebProxy;

  3在Main函数中添加下列代码,下列代码是利用Proxy类,来实现Web代理程序:

  const int port = 8000 ;

  //定义端口号

  TcpListener tcplistener = new TcpListener(port);

  ConsoleWriteLine("侦听端口号: " + portToString());

  tcplistenerStart();

  //侦听端口号

  while (true)

  {

  Socket socket = tcplistenerAcceptSocket();

  //并获取传送和接收数据的Scoket实例

  Proxy proxy = new Proxy(socket);

  //Proxy类实例化

  Thread thread = new Thread(new ThreadStart(proxyRun));

  //创建线程

  threadStart();

  //启动线程

  }

  保存上面的所有步骤,这样一个简单Web代理程序就算是完成了。此Web代理程序侦听的是8000端口号。

  (三)测试Web代码程序

  Web代理程序要通过二台计算机才能够实现,其中的一台计算机运行Web代理程序充当Web代理服务器,另外一台计算机充当客户机,通过Web代理服务器来浏览网页。在确定Web代理软件运行后,需要对客户机进行进行必要的设置:

  1打开IE浏览器。

  2依次选择“工具”、“Internet选项”,在弹出的“Internet选项”对话框中选择“连接”页面,单击其中的“局域网设置”按钮,在弹

出的“局域网(LAN)设置”对话框,选择“为LAN使用代理服务器(X),(这些设置不会应用于拨号和***连接)”多选框,并在其中的“地址”文本框

中输入代理服务器的IP地址,比如“10138198213”,在“端口”文本框中输入“8000”。

  此时客户端的设置就完成了。在确定IP地址为“10138198213”的这台计算机已经运行上面介绍的Web代理程序后,打开客户端的IE浏览器,并输入要浏览的网址,就可以通过Web代理服务器来浏览网页了。

  四、总结

  至此一个简单的Web代理服务软件就算基本完成了。虽然代理服务的实现原理相对简单,但具体实现还是很繁琐的。网络代理是一个内容丰富,实现复杂的论

题,本节介绍的代理服务软件,无论在实现的协议种类,还是实现的功能,都只能算很小的一部分。希望各位能够通过本文的介绍,结合其他相关的知识,创造出功

能更强大、安全性更高,使用更稳定的网络代理服务程序来。

webfreer无法连接到代理服务器解决方法:

设置里面的扩展程序 中的Secure HTTPS Proxy 勾去掉。

1开始“控制面板”--“网络和INTERNET设置”

2“INTERNET选项”

3“INTERNET属性”,“连接”,点右下角“局域网设置…”

4去掉打勾确定

如果您使用代理服务器,请检查您的代理设置或与您的网络管理员联系,以确保代理服务器工作正常。

如果您认为不应该使用代理服务器,请调整您的代理设置:转至扳手菜单 > 选项 > 高级选项 > 更改代理设置 > LAN 设置,取消选中“为 LAN 使用代理服务器”复选框。

错误 130 (net::ERR_PROXY_CONNECTION_FAILED):代理服务器连接失败。

在HTTP通信链上,客户端和目标服务器之间通常存在某些中转代理服务器,它们提供对目标资源的中转访问。一个HTTP请求可能被多个代理服务器转发,后面的服务器称为前面服务器的上游服务器。代理服务器按照其使用方式和作用,分为正向代理服务器,反向代理服务器和透明代理服务器。

 

正向代理要求客户端自己设置代理服务器的地址。客户的每次请求都将直接发送到该代理服务器,并由代理服务器来请求目标资源。比如处于防火墙内的局域网机器要访问Internet,或者要访问一些被屏蔽掉的国外网站,就需要使用正向代理服务器。

 

反向代理则被设置在服务器端,因而客户端无需进行任何设置。反向代理是指用代理服务器来接收Internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从内部服务器上得到的结果返回给客户端。这种情况下,代理服务器对外就表现为一个真实的服务器。各大网站通常分区域设置了多个代理服务器,所以在不同的地方同一个域名可能得到不同的IP地址,因为这些IP地址实际上是代理服务器的IP地址。

 

HTTP代理服务器的工作原理

如图所示,正向代理服务器和客户端主机处于同一个逻辑网络中。该逻辑网络可以是一个本地LAN,也可以是一个更大的网络。反向代理服务器和真正的Web服务器也位于同一个逻辑网络中,这通常由提供网站的公司来配置和管理。

透明代理只能设置在网关上。用户访问Internet的数据报必然都经过网关,如果在网关上设置代理,则该代理对用户来说显然是透明的。透明代理可以看作正向代理的一种特殊情况。

代理服务器通常还提供缓存目标资源的功能,这样用户下次访问同一资源时速度将很快。优秀的开源软件squid,varnish都是提供了缓存能力的代理服务器软件,其中squid支持所有代理方式,而varnish仅能用作反向代理。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 通过win 2012 WEB服务器在其他电脑代理上网设置问题

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情