<![endif]>
|
|||||||
The goal
|
|
||||||
The goal of Proxy Rental API
functions is to provide user an ability to switch IPS. For that purpose
several API calls have to be made in certain sequence. Below we will describe
each necessary operation, functions used for this operations with their
appropriate parameters, while further down we will provide an example
application demonstrating their usage.
|
|||||||
Downloading The PRSetup.exe
|
|
||||||
You can download the
PRSetup.exe from http://www.proxyrental.net/thankyou/. Navigating to this page will download the
installation package. You will need proxy Rental program installed in order
to use Proxy Rental APIs.
|
|||||||
Recommended Software
|
|
||||||
<![if !supportLists]>·
<![endif]>.NET
compiler that supports .NET 4.0: Microsoft Visual Studio 2010
<![if !supportLists]>·
<![endif]>Microsoft
Visual C# 2010 Express
<![if !supportLists]>·
<![endif]>Microsoft
Visual Basic 2010 Express
<![if !supportLists]>·
<![endif]>Microsoft
Visual Studio 2012
<![if !supportLists]>·
<![endif]>Microsoft
Visual Studio Express 2012 for Windows Desktop
|
|||||||
Add Service Reference
|
|
||||||
Prior to using ProxyRental
APIs, add the following Service Reference to your c# project
|
|||||||
Opening new session
|
|
||||||
A Proxy Rental user can switch IPs multiple
times. The actual number depends on
the program purchased from Proxy Rental.
However, in order to accomplish any operation with Proxy Rental APIs a
user have to have an open SOAP session.
|
|||||||
private Session session;
...
session = new Session();
session =
client.TryRestoreOrLogin(user, session);
|
|||||||
This call authenticates user on the server
side and allows subsequent calls to change IPS.
Session type is defined in ProxyRental service
reference that should be included in the program.
Client parameter is of SoapClientServiceClient type and is also defined in ProxyRental service reference as is the user parameter.
User user = new User();
user.Name =
userName;
user.Hash = GetEncryptedString(userPwd);
User type has two properties Name and
Hash. Name is self explanatory, while
Hash is Encrypted user password. Each
user selects his or her own user name and password during ProxyRental Install
procedure, prior to login in.
Encryption is provider via MD5CryptoService defined
in System.Security.Cryptography A sample of encryption function is provided below
in the subsequent example.
In
case of success the function session =
client.TryRestoreOrLogin(user, session);
returns
session id that needs to be supplied to subsequent functions. If this function fails then the function
might return the following error values.
|
|||||||
Error Value
|
Meaning
|
||||||
00000000-0000-0000-0000-000000000000
|
unknown behavior (example user
is not logged in)
|
||||||
10000000-0000-0000-0000-000000000000
|
user subscription has expired
|
||||||
20000000-0000-0000-0000-000000000000
|
Number of
allowed sessions has expired
|
||||||
30000000-0000-0000-0000-000000000000
|
incorrect
user name or user password
|
||||||
40000000-0000-0000-0000-000000000000
|
server is
under diagnostics
|
||||||
|
|||||||
Change Proxy
|
|
||||||
Now, once session is established, a user
can start changing IPs. For that
purpose one should use Proxy Rental method ChangeProxy.
ChangeProxyResult
changeProxyResult = client.ChangeProxy(session);
ChangeProxy
method is also defined in ProxyRental
service reference. It accepts session parameter, changes IP, does a number of
other internal operations and collects important information that is made
available by calling the following
method:
GlobalInfo ginfo =
client.GetProxyInfo(session, sort);
|
|||||||
Global Information
|
|
||||||
GetProxyInfo method accepts two parameters: sessionID and sort, where
sort could have two possible values specified in enumerator GlobalInfoSort
GlobalInfoSort.ByDistance
or
GlobalInfoSort.ByState
Sort order starts matter when user deals
with geo-location associated with the new IP and will be discussed below. When changing ip is the only purpose of the
call, the sort parameter can be passed as null. GlobalInfo ginfo =
client.GetProxyInfo(session, null);
GlobalInfo structure returns the following
information:
public class GlobalInfo
{
private
GlobalInfo[] nearestInfos;
public string
CurrentIP { get; set; }
public string
City { get; set; }
public string
CityCode { get; set; }
public string
CountryName { get; set; }
public string
AreaCode { get; set; }
public string
State { get; set; }
public string
Latitude { get; set; }
public string
Longitude { get; set; }
public TimeSpan
ProxyTimeout { get; set; }
public int
NonDstTimeZone { get; set; }
public long
CLTime { get; set; }
public long
CLTimeActuality { get; set; }
public string
TimeZoneID { get; set; }
public double
Persistence;
public double
Health;
}
Below is the description of those data members that are usually are
most useful.
|
|||||||
Field
|
Description
|
||||||
nearestInfos
|
Array containing a list of
locations nearest to the Current IP
|
||||||
AreaCode
|
Area Code of the Current IP
|
||||||
City
|
City of the Current IP
|
||||||
CityCode
|
Craigs's List City Code
|
||||||
CountryName
|
Country of the current IP
|
||||||
CurrentIP
|
New IP that user gains after
switch
|
||||||
Lattitude
|
Lattitude of the Current IP
|
||||||
Longitude
|
Longitide of the Current IP
|
||||||
State
|
State of the Current IP
|
||||||
Persistence
|
Proxy stability - a value
between 0 and 10
|
||||||
Global
Information[] nearestInfos
|
|||||||
This array,
containing the information about nearest locations to the current IP,
deserves special consideration. This
information becomes pertinent when an IP happens to be located not in the
vicinity of a CL city, but, for example, in some rural area. In this case, nearestInfos array provides information regarding surrounding CL cities. Latitude and longitude information can be used to
determine the distance from the IP location to the CL city. Please click here for example.
|
|||||||
|
|
|
|
||||
public struct
ProxyFilterParams
{
public float?
Persistance;
public int?
ProxyTimeout;
public ProxyFilterClassification
ProxyKind;
public float
SpeedQuality;
}
|
|||||||
Test Project
|
|
||||||
|
|
||||||
Sunday, August 10, 2014
Subscribe to:
Posts (Atom)