出现Cache Access Denied这种提示的情况一般是使用代理IP的终端设备IP地址变更了,导致添加的白名单IP授权失败。
您可以检查下使用代理的终端IP有没有变;如果变了,需要重新添加白名单进行绑定,如下图;
绑定完成后重新获取新的IP即可正常使用。
此示例Nodejs使用superagent并通过代理进行请求发送。
下面的代码需要用到npm包:superagent、superagent-proxy,请先引入文件中
此代码以http和https代理为例
// 安装superagen 终端执行 npm install superagent
// 安装superagent-proxy终端执行 npm install superagent-proxy
let request = require('superagent')
require('superagent-proxy')(request)
let targetUrl = 'https://myip.ipip.net/' //要访问的目标站点
let auth = 'XXXXXXXX:XXXXXXXXXXXX' //冒号分帐号和密码: KeyAuth:KeyPass
let proxyServer = 'tunnel.qg.net:13953' //代理服务器地址和对应端口
// 两种验证方式
let proxyUrl_account = 'http://' auth '@' proxyServer //帐密认证
let proxyUrl_white = 'http://' proxyServer //白名单认证
//帐密认证模式
request.get(targetUrl)
.proxy(proxyUrl_account) //请求时设置调用代理信息
.then(res => {
console.log('当前:帐密认证模式')
console.log(res.text)
}).catch(err => {
console.log(err.message)
})
//白名单认证模式
request.get(targetUrl)
.proxy(proxyUrl_white) //请求时设置调用代理信息
.then(res => {
console.log('当前:白名单认证模式')
console.log(res.text)
}).catch(err => {
console.log(err.message)
})
运行结果详情如下图:
此示例Nodejs使用axios并通过代理进行请求发送。
下面的代码需要用到npm包:axios-https-proxy-fix,请先引入文件中。
此代码以http和https代理为例。
// 终端执行 npm install axios-https-proxy-fix 下载相应的包
// 引入包:axios-https-proxy-fix
let axios = require('axios-https-proxy-fix')
// 目标网站
let targetUrl = 'https://myip.ipip.net/' //要访问的目标站点
//服务器信息
let serverURL = 'xxx.xxx.xxx.xxx' //代理服务器地址
let serverPort = 'xxx' //代理服务器端口
//账密登录信息
let authKey = 'xxxxxxx' //代理服务器帐号
let authPwd = 'xxxxxxx' //代理服务器密码
// 设置代理
let proxy = {
host: serverURL,
port: serverPort,
// 使用白名单可不添加 auth 字段
auth: {
username: authKey,
password: authPwd
}
}
axios.get(targetUrl, {proxy: proxy}) //请求时设置调用代理信息
.then((res) => {
console.log(res.data)
}).catch((err) => {
console.log(err.message)
})
运行结果详情如下图:
以下示例适用于python2 及 python3
进行http请求,我们一般使用requests库,该库支持http/https代理。 安装如下
pip install requests
如果需要使用socks5代理,可以安装支持socks的版本
pip install 'requests[socks]'
下面以使用socks5代理为例
import requests
proxyHost = "222.222.222.222" #获取到的代理IP
proxyPort = "12345" #获取到的代理端口
key = "key" #用户key
passwd = "123456" #用户密码
# 账密模式
proxy = 'socks5://{}:{}@{}:{}'.format(key, passwd, proxyHost, proxyPort)
# 如果使用IP白名单模式,请用下行替换上一行
# proxy = 'socks5://{}:{}'.format(proxyHost, proxyPort)
proxies = {
"http": proxy,
"https": proxy
}
response = requests.get("https://httpbin.org/get", proxies=proxies)
print(response.text)
如果想使用http/https代理,请修改接入代理的协议,如下
# 账密模式
proxy = 'http://{}:{}@{}:{}'.format(key, passwd, proxyHost, proxyPort)
# 如果使用IP白名单模式,请用下行替换上一行
# proxy = 'http://{}:{}'.format(proxyHost, proxyPort)
点击 “添加到Firefox” 后浏览器会弹出插件添加确认提醒,确认添加后即可;
确认添加提示,选择“添加”即可
添加成功后将会自动跳转到设置页面,点击“下一步” 查看该插件的介绍说明信息即可。
点击左侧菜单项目中的“情景模式”分组下方的“新增情景模式”进行添加代理IP连接信息 ;
新建情景模式,设置情景模式名称,模式类型默认选择(代理服务器),确认“创建”即可;
点击左侧菜单项目中的”情景模式”分组下方的”qg.net”进行代理设置 ;
选择代理IP的连接协议类型并填入相应的代理IP的服务器地址和端口信息。
网址协议(默认) 一行的信息中,代理协议选择 HTTP , 并输入代理服务器地址和代理端口信息,可点击最后的锁图标,可输入账号密码进行账密验证登录连接。
例如:
帐号密码登录设置:
设置完毕后点击左侧菜单进行应用选项 ;
使用前:
使用后:
选中添加的qg.net 代理IP连接,并测试连接成功 ;
本文将针对傲游浏览器如何使用代理IP进行详细说明,具体步骤如下:
在“代理ip”-“业务管理”里面查看自己购买的代理ip,然后点击”管理”查看自己的代理IP业务信息(“AuthKey”和“AuthPwd”),具体如下图;
使用自己购买的“AuthKey”去“调试工具”里面选择“资源申请”获取ip,如下图:
步骤如下:
3.1.1 打开傲游浏览器,点击右上角的菜单,再点击“设置”并在搜索栏里面输入“代理”进行搜索,如下图:
3.1.2 打开的设置页面中选择“使用自定义代理设置”然后点击“添加”;
3.1.3 在弹出的窗口输入“名称”,然后需要选择代理的类型,类型包括(http、https、socks模式),然后输入代理的“地址”跟端口,然后输入“用户名”和“密码”(用户名就是“AuthKey”,密码就是“AuthPwd”),输入完成后点击“确定”即可。
3.1.4 添加完成后选择刚刚添加的代理,点击“启用”即完成遨游浏览器的代理设置;
使用傲游浏览器打开浏览器打开https://www.baidu.com/s?word=ip,查看ip是否和设置的代理ip相同,相同则为设置成功;
取消代理的话,直接在设置里面点击“不使用代理”即可取消掉。
此示例是通过修改JVM中的网络设置来达到代理的效果,如果程序员有些请求不需要代理可以在代理请求之后再将JVM配置项改回默认项。支持http、https、socks5代理
此代码以http和https代理为例:
``
```java
// 使用socks5代理配置
package com.qg;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.*;
public class ProxyClient {
//用户key
private static String user = "key";
//用户密码
private static String password = "proxy_password";
//获取到的代理IP
private static String proxyIP = "127.0.0.1";
//获取到的代理端口
private static String proxyPort = "1080";
public static void main(String[] args) {
// 下面http、https代理和socks5代理只需要设置一个就可以
// 使用http代理和https代理
System.setProperty("http.proxySet", "true");
// 发起http请求时使用的代理服务器配置
System.setProperty("http.proxyHost", proxyIP);
System.setProperty("http.proxyPort", proxyPort);
// 发起https请求时使用的代理服务器配置
System.setProperty("https.proxyHost", proxyIP);
System.setProperty("https.proxyPort", proxyPort);
// 这行代码是身份验证的关键配置,不然身份验证不起作用
System.setProperty("jdk.http.auth.tunneling.disabledSchemes", "");
System.setProperty("jdk.http.auth.proxying.disabledSchemes", "");
// 身份验证
Authenticator.setDefault(
new Authenticator() {
public PasswordAuthentication getPasswordAuthentication() {
return new PasswordAuthentication(
user, password.toCharArray());
}
}
);
sendRequest("http://www.fwvps.com");
sendRequest("https://www.fwvps.com");
}
public static void sendRequest(String urlStr) {
URL url;
&nbs; BufferedReader in;
StringBuilder result = new StringBuilder();
try {
url = new URL(urlStr);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.connect();
in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
String line;
while ((line = in.readLine()) != null) {
result.append(line);
}
conn.disconnect();
System.out.println("http status code:" conn.getResponseCode());
System.out.println("body: " result);
} catch (IOException e) {
e.printStackTrace();
}
}
}
```
如需使用socks5代理可以将main函数中的代码替换为:
```java
// 使用socks5代理配置
System.setProperty("socksProxyHost", proxyIP);
System.setProperty("socksProxyPort", proxyPort);
System.setProperty("socksProxyVersion", "5");
System.setProperty("java.net.socks.username", user);
System.setProperty("java.net.socks.password", password);
```
以下示例适用于php5及php7
下面的代码需要用到php的curl库,请预先安装并开启
$url = 'https://httpbin.org/get';
//获取到的代理IP和端口
$proxy = '222.222.222.222:12345';
//用户的key和密码,使用账密模式访问代理的时候用到。如果使用IP白名单模式,请注释掉下行
$proxyauth = 'key:passwd';
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
//设置代理
curl_setopt($ch, CURLOPT_PROXY, $proxy);
//使用账密模式访问代理时设置账密。如果使用IP白名单模式,请注释掉下行
curl_setopt($ch, CURLOPT_PROXYUSERPWD, $proxyauth);
//设置使用的代理类型,当前为socks5类型,如果不设置,默认为http/https类型
curl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5);
if ( ! $res = curl_exec($ch))
{
trigger_error(curl_error($ch));
}
curl_close($ch);
echo $res;
此代码适用.NET 5.0 and .NET Core
此示例通过**WebProxy**进行代理设置,并通过**HttpWebResquest**发送请求。
代码
下面的代码需要用到命名空间 **System.Net**、**System.Text**、**System.IO**,请先引入命名空间
此代码以http和https代理为例
using System;
using System.Net;
using System.Text;
using System.IO;
namespace proxy_demo
{
class Program
{
static void Main(string[] args)
{
sendRequest("https://www.fwvps.com", SetProxy());
}
private static void sendRequest(String urlStr, WebProxy proxyObj)
{
try
{
// 设置Http/https请求
HttpWebRequest httpRequest = (HttpWebRequest)HttpWebRequest.Create(urlStr);
httpRequest.Method = "GET";
httpRequest.Credentials = CredentialCache.DefaultCredentials;
// 在发起HTTP请求前将proxyObj赋值给HttpWebRequest的Proxy属性
httpRequest.Proxy = proxyObj;
// 抓取响应返回的页面数据
HttpWebResponse res = (HttpWebResponse)httpRequest.GetResponse();
StreamReader reader = new StreamReader(res.GetResponseStream(), System.Text.Encoding.UTF8);
string content = reader.ReadToEnd();
reader.Close();
Console.WriteLine("{0}", content);
}
catch (Exception e)
{
Console.WriteLine(e.ToString());
}
}
private static WebProxy SetProxy()
{
WebProxy proxy = new WebProxy();
try
{
// 设置代理属性WebProxy
string server = @"tunnel.www.fwvps.com:11883"; //代理IP的服务器地址
string proxyUser = @"4B2AF3A6"; //帐号
string proxyPass = @"D95133B9A167"; //密码
proxy.Address = new Uri(string.Format("http://{0}/",server));
proxy.Credentials = new System.Net.NetworkCredential(proxyUser, proxyPass); //如使用白名单方式连接,可注释此行
Console.WriteLine("代理服务器连接成功:{0}", server);
return proxy;
}
catch (NullReferenceException e)
{
Console.WriteLine("代理服务器连接失败,请检查服务器地址、用户名、密码是否有误。" e.ToString());
}
return proxy;
}
}
}
运行结果:

如果企业使用物理服务器,因为其成本较昂贵,且不仅是购机支出,后期对维护场地维护人员及机器实际维护都还是有很大一笔开支,且有些平台使用情况,需求还远不需要达到服务器的配置。如果是租用云服务器,可以根据自身需求选择资源付费,就无需要承担服务器硬件带来的巨大运维成本。
云服务器采用了云计算技术,其弹性优势更明显。客户可以根据自身的实际情况实现自由、无缝对接到云端,具备更为强大的云计算能力。企业在使用云服务器的时候,服务商是及时对技术和资源情况进行升级和更新,无论从成本还是技术上,用户都得到了最全面的技术维护和设备使用,整体的性能更优。
代理IP连接速度快,我们的工作效率也会提升。比如说,如果我们需要使用代理IP抓取数据,连接快的代理IP能够让我们在相同的时间之内顺利的爬取更多有用的信息。使用高匿IP地址池的优势,当对目标进行扫描或爬取时,当触发目标服务器的检测规则时,客户端的IP可能会被禁止访问。此时本地建立高匿IP地址池,当客户端IP被Ban或定时切换IP,对目标进行扫描或爬取,可以对目标进行循环扫描,直到获取结果。
飞网网络代理ip支持多种协议,动态静态可选,根据使用情况选择计费方式。飞网网络是高效多云管理服务商,同市面上各大品牌携手合作,业务范围有阿里云、腾讯云、华为云、电信云等,全国乃至海外主要地区云服务器租用、托管。企业多年专业运营管理经验获得广大客户信赖好评,是少有工信部颁发的全网IDC/ISP/IP-VPN资质企业之一。