Proxy-Go 全平台 SDK 迎来 v4.8 更新! - 开源中国社区
Float_left Icon_close
Proxy-Go 全平台 SDK 迎来 v4.8 更新!
狂奔的蜗牛. 2018年05月04日

Proxy-Go 全平台 SDK 迎来 v4.8 更新!

狂奔的蜗牛. 狂奔的蜗牛. 发布于2018年05月04日 收藏 16

Proxy-Go 全平台 SDK是proxy使用gombile实现了一份go代码编译为android和ios平台下面可以直接调用的sdk类库, 另外还为linux和windows提供sdk支持,基于这些类库,APP开发者可以轻松的开发出各种形式的代理工具。

此次更新:

1.修复了多个服务同时开启日志,只会输出到最后一个日志文件的bug.

2.增加了获取sdk版本的Version()方法.

3.重构了所有服务的启动代码对日志进行友好的支持。

Proxy SDK 使用说明

支持以下平台:

  • Android,.arr库

  • IOS,.framework库

  • Windows,.dll库

  • Linux,.so库

  • MacOS,.dylib库

proxy使用gombile实现了一份go代码编译为android和ios平台下面可以直接调用的sdk类库, 另外还为linux和windows提供sdk支持,基于这些类库,APP开发者可以轻松的开发出各种形式的代理工具。

下面分平台介绍SDK的用法

Android SDK

点击下载Android-SDK
在Android系统提供的sdk形式是一个后缀为.aar的类库文件,开发的时候只需要把arr类库文件引入android项目即可.

Android-SDK使用实例

1.导入包

import snail007.proxy.Porxy

2.启动一个服务

String serviceID="http01";//这里serviceID是自定义的唯一标识字符串,保证每个启动的服务不一样即可 String serviceArgs="http -p :8080"; String err=Proxy.start(serviceID,serviceArgs); if (!err.isEmpty()){ //启动失败 System.out.println("start fail,error:"+err);
}else{ //启动成功 }

3.停止一个服务

String serviceID="http01"; Proxy.stop(serviceID); //停止完毕

IOS SDK

点击下载IOS-SDK
在IOS系统提供的sdk形式是一个后缀为.framework的类库文件夹,开发的时候只需要把类库文件引入项目,然后调用方法即可.

IOS-SDK使用实例

导入包

#import <Proxy/Proxy.objc.h>

2.启动一个服务

-(IBAction)doStart:(id)sender
{ //这里serviceID是自定义的唯一标识字符串,保证每个启动的服务不一样 NSString *serviceID = @"http01"; NSString *serviceArgs = @"http -p :8080"; NSString *error = ProxyStart(serviceID,serviceArgs); if (error != nil && error.length > 0)
    { NSLog(@"start error %@",error);
    }else{ NSLog(@"启动成功");
    }
}

3.停止一个服务

-(IBAction)doStop:(id)sender
{ NSString *serviceID = @"http01"; ProxyStop(serviceID); //停止完毕 }

Windows SDK

点击下载Windows-SDK
在Windows系统提供的sdk形式是一个后缀为.dll的类库文件,开发的时候只需要把dll类库文件加载,然后调用方法即可.

Windows-SDK使用实例

C++示例,不需要包含头文件,只需要加载proxy-sdk.dll即可,ieshims.dll需要和proxy-sdk.dll在一起。
作者:yjbdsky

#include <stdio.h> #include<stdlib.h> #include <string.h> #include<pthread.h> #include<Windows.h> #ifdef __cplusplus extern "C" {
#endif typedef char *(*GOSTART)(char *s); typedef char *(*GOSTOP)(char *s); typedef int(*GOISRUN)(char *s);
HMODULE GODLL = LoadLibrary("proxy-sdk.dll"); char * Start(char * p0,char * p1)
{ if (GODLL != NULL)
	{
		GOSTART gostart = *(GOSTART)(GetProcAddress(GODLL, "Start")); if (gostart != NULL){ printf("%s:%s\n",p0, p1); char *ret = gostart(p0,p1); return ret;
		}
	} return "Cannot Find dll";
} char * Stop(char * p)
{ if (GODLL != NULL)
	{
		GOSTOP gostop = *(GOSTOP)(GetProcAddress(GODLL, "Stop")); if (gostop != NULL){ printf("%s\n", p); char *ret = gostop(p); return ret;
		}
	} return "Cannot Find dll";
} int main()
{ //这里p0是自定义的唯一标识字符串,保证每个启动的服务不一样 char *p0 = "http01"; char *p1 = "http -t tcp -p :38080"; printf("This is demo application.\n"); //启动服务,返回空字符串说明启动成功;返回非空字符串说明启动失败,返回的字符串是错误原因 printf("start result %s\n", Start(p0,p1)); //停止服务,没有返回值 Stop(p0); return 0;
}


#ifdef __cplusplus
}
#endif

C++示例2,请移步:GoProxyForC

Linux SDK

点击下载Linux-SDK
在Linux系统提供的sdk形式是一个后缀为.so的类库文件,开发的时候只需要把so类库加载,调用方法即可.

Linux-SDK使用实例

Linux下面使用的sdk是so文件即libproxy-sdk.so,下面写一个简单的C程序示例,调用so库里面的方法.

vi test-proxy.c

#include <stdio.h>
#include "libproxy-sdk.h"

int main() {
     printf("This is demo application.\n");
	 //这里p0是自定义的唯一标识字符串,保证每个启动的服务不一样
	 char *p0 = "http01";
     char *p1 = "http -t tcp -p :38080";
     //启动服务,返回空字符串说明启动成功;返回非空字符串说明启动失败,返回的字符串是错误原因
     printf("start result %s\n",Start(p0,p1));
     //停止服务,没有返回值
     Stop(p0);
     return 0;
}




编译test-proxy.c

export LD_LIBRARY_PATH=./ && gcc -o test-proxy test.c libproxy-sdk.so

执行

./test-proxy

MacOS SDK

点击下载MacOS-SDK
在MacOS系统提供的sdk形式是一个后缀为.dylib的类库文件,开发的时候只需要把so类库加载,调用方法即可.

MacOS-SDK使用实例

MacOS下面使用的sdk是dylib文件即libproxy-sdk.dylib,下面写一个简单的Obj-C程序示例,调用dylib库里面的方法.

#import "libproxy-sdk.h" -(IBAction)doStart:(id)sender
{ char *result = Start("http01", "http -t tcp -p :38080"); if (result)
    { printf("started");
    }else{ printf("not started");
    }
  
}
-(IBAction)doStop:(id)sender
{ Stop("http01");

}

关于服务

proxy的服务有11种,分别是:

http  
socks  
sps  
tcp  
udp  
bridge  
server  
client  
tbridge  
tserver  
tclient

服务启动时,如果存在正在运行的相同ID的服务,那么之前的服务会被停掉,后面启动的服务覆盖之前的服务.
所以要保证每次启动服务的时候,第一个ID参数唯一.
上面这些服务的具体使用方式和具体参数,可以参考proxy手册
sdk里面的服务不支持手册里面的:--daemon和--forever参数.

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动共创开源社区。
转载请注明:文章转载自 开源中国社区 [http://www.oschina.net]
本文标题:Proxy-Go 全平台 SDK 迎来 v4.8 更新!
分享
评论(7)
最新评论
有人说一下这个是干嘛的吗?
最好能有一个白名单系统
0
酷!
0
我不能再点star了,,,因为……再点就取消了
0
真是勤奋
0
了不起
0
顶部