登录vpn后,java程序无法访问远数据库或远程服务(微服务或webservice服务)场景:在家远程办公,使用vpn访问公司微服务, 浏览器能正常访问, 但java程序发起的请求不能
解决方法:加入java启动参数:-Djava.net.preferIPv4Stack=true
如果使用的是tomcat则在tomcat启动参数里面添加-Djava.net.preferIPv4Stack=true
如果使用的是springboot则
如何将开源项目打包成.so文件但是最近要做一个Androidjavavpn代码的VPN客户端javavpn代码 , 由于没找到基于Javajavavpn代码的VPN开源库,只找到了C语言编写的开源客户端,叫做PPTP Client , 这个代码是公开的 。
javavpn代码我想把这个开源项目的C代码打包成so文件,然后放到javavpn代码我的Android项目中,在JAVA代码中通过JNI调用PPTP Client , 实现VPN连接 。
我有一个自动建立VPN的批处理文件.但是有缺陷.就是连接上本机不能上网.从上面给javavpn代码的代码来看,javavpn代码你应该是想在里面加一段代码.可以实现自动把勾去掉..(从你javavpn代码的文字说明看,不明确,可能你会) 。
你可以用SendKeys "{TAB}"定位到这个常规选项卡中javavpn代码的复选框,再用SendKeys " ",输出空格键,就可以把复选框中的钩去掉javavpn代码了 。
至于后面的问题 , 你可以试着不自动登录VPN而是手动登录VPN 。如果问题依旧,那应该就与那台电脑的网络环境或者机器的相关设置有关了 。
如果手动可以,很有可能是那台电脑有些键的输入与你的机器不同 , 可能要输入个组合键才能输入一个正常的键盘的键(尤其是笔记本) , 你自己可以手动试试看 。
通过hook connect 函数 实现 VPN功能是否可行在android系统中javavpn代码,可以使用iptables控制单个应用网络访问 。在google code上有一个开源项目-droidwall就是基于iptables实现javavpn代码的 。除了iptables可以实现控制单个应用网络访问外javavpn代码,还可以通过拦截应用中的connect函数,达到控制应用访问网络的目的 。下面从几个方面分析android应用中connect调用流程为例来实现拦截connect实现网络禁用和ip过滤 。(以下分析基于4.2源码)
1.android中网络访问流程
1)android系统中访问网络可以通过Socket.java、URL.java、HttpPost.java、HttpGet.java等关键类来访问网络资源 。通过代码追踪,这些类访问网络资源最终需要通过native方式,调用linux系统下的socket函数访问网络 。在android4.2源码中,java层访问网络得native方法定义在源码路径libcore/luni/src/main/java/libcore/io/Posix.java中(4.0之前的网络系统、文件系统的native方法是独立分开得,4.0之后组织在Posix.java中) 。如下是Posix.java中的代码片段javavpn代码:
public final class Posix implements Os {Posix() { }public native FileDescriptor accept(FileDescriptor fd, InetSocketAddress peerAddress) throws ErrnoException, SocketException;public native boolean access(String path, int mode) throws ErrnoException;public native void bind(FileDescriptor fd, InetAddress address, int port) throws ErrnoException, SocketException;......//对应linux下的connect系统调用public native void connect(FileDescriptor fd, InetAddress address, int port) throws ErrnoException, SocketException;
2)Posix.java中的native方法实现源码路径libcore/luni/src/main/native/libcore_io_Posix.cpp文件中,nativeconnect方法实现代码片段如下:
taticvoidPosix_connect(JNIEnv*env,jobject,jobjectjavaFd,jobjectjavaAddress,jintport)
{
sockaddr_storagess;
if(!inetAddressToSockaddr(env,javaAddress,port,ss))
{
return;
}
constsockaddr*sa=reinterpret_castconstsockaddr*(ss);
(void)NET_FAILURE_RETRY(env,int,connect,javaFd,sa,sizeof(sockaddr_storage));
}
有上代码可知,java层connect最终功能由linux系统connect函数实现 。
2.so注入
so注入可以参考古河大哥牛逼的libInject(点击这里访问) 。
3.拦截connect库编写
在connect中 , 获取传入的参数ip地址,根据需要把需要禁用的ip地址改为127.0.01.以下是javavpn代码我测试的拦截connect函数关键代码:
intnew_connect(intsockfd,conststructsockaddr*addr,socklen_taddrlen)
{
LOGDD("HOOK
====new connect****************");
charip[128]={0};
intport=-1;
if(addr-sa_family==AF_INET)
{
structsockaddr_in*sa4=(structsockaddr_in*)addr;
inet_ntop(AF_INET,(void*)(structsockaddr*)sa4-sin_addr,ip,128);
port=ntohs(sa4-sin_port);
LOGDD("AF_INETIP===%s:%d",ip,port);
}
【javavpn代码的简单介绍】elseif(addr-sa_family==AF_INET6)
{
structsockaddr_in6*sa6=(structsockaddr_in6*)addr;
char*ipv6=NULL;
inet_ntop(AF_INET6,(void*)(structsockaddr*)sa6-sin6_addr,ip,128);
ipv6=strstr(ip,"f:");
if(NULL!=ipv6)
{
strcpy(ip,ipv6 2);
}
port=ntohs(sa6-sin6_port);
LOGDD("af_inet6
IP===%s:%d",ip,port);
}
else
{
returnold_connect(sockfd,addr,addrlen);
}
if(strcmp(ip,"115.23.20.178")==0)
{
LOGDD("%s
==127.0.0.1",ip);
structsockaddr_inmy_addr;
intmy_len=sizeof(structsockaddr_in);
bzero(my_addr,sizeof(my_addr));
my_addr.sin_family=AF_INET;
my_addr.sin_port=htons(80);
my_addr.sin_addr.s_addr=inet_addr("127.0.0.1");
returnold_connect(sockfd,(constsockaddr*)my_addr,sizeof(my_addr));
}
else
{
returnold_connect(sockfd,addr,addrlen);
}
}
4.拦截connect函数功效
1)禁用应用网络访问 。
2)过滤广告ip
3)禁用定位功能
javavpn代码的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于、javavpn代码的信息别忘了在本站进行查找喔 。
推荐阅读
- 手机卡网络为什么是2g网络,手机卡为什么总是2g网络
- 宠物医院管理系统python,宠物医院管理系统流程图
- oracle如何执行存储过程6,oracle执行存储过程的语句
- 拍摄摩托车的图片叫什么,拍摄摩托车的图片叫什么来着
- oracle如何连接服务器 oracle连接28547
- python3中kfold,Python3菜鸟工具
- 华为服务器vpu,华为服务器400技术支持电话
- vb.net读取键盘 vb读写ini
- 怎么将微信视频号保存图片,微信视频号视频怎么保存相册