首页 >>  正文

外网如何访问内网电脑

来源:baiyundou.net   日期:2024-08-15

作者:tane274

一、折腾由来

  上半年,有一朋友拿个赚钱宝要我帮他刷系统,我刷了个OPENWRT,但没过几天就死机了,怎么也进不去,后又帮他刷了个armbian,但也没过几天死机了,后来来回回折腾几次还是没几天就死机进不了系统,最后判断闪存坏了,不能正常使用。如果故事就这样,可能就结束了。

  但是在折腾这段时间他拿到联通的公网IP,也觉得NAS很方便。国庆后就买了个N5105的小电脑,装了个win2019(因为win有桌面对普通人比较友好),我给他装了个可道云、PHP目录列表、µTorrent、jellyfin。

   但是好景不长,11月2号他的公网IP被联通回收了。打电话到客服、投诉…… 能想的手段都用上了,最后得到一个答复:“你换电信宽带吧,电信有公网IP"。

  折腾从这开始了……

二、VPN访问(已弃用)

  我首先想到的办法是在我家搞个VPN服务器,朋友的服务器用VPN拨号进入我家内网,我再把他的WEB服务代理出来。

  这个方法开机好像不能自动连接VPN,这就导致每次开机还要手动连接VPN,而且朋友也觉得走我家宽带会影响我家的网速。最后放弃了这个方法。   

三、cloudflare(有改进) 

  朋友先想到的方法有frp,还有花生棒。我觉得吧用这些还不如用我家VPN,免费还稳定。

  最后我看到一篇文章:https://post.smzdm.com/p/awxlgpvk/,最后就整了这个方案

1、查看宽带是否支持IPV6

  查看是否支持IPV6:https://ipw.cn/ipv6/这个网址可以查看你电脑有支持IPV6(现在的移动联通电信的宽带都支持IPV6,其它家就不太清楚了)。如果不支持IPV6,首先看你路由器是否支持IPV6,路由器是否开启了IPV6。

  

  IPV6一般有两种模式:一种Native(TP里面叫和宽带拨号上网),这种适合光猫做桥接用路由器拨号的情况。别一种叫NAT6(TP里面叫桥接模式),这种适合用光猫拨号路由器做二级路由的情况。

2、关路由器防火墙

  在https://ipw.cn/ipv6ping/这里ping一下自己的IPV6地址如果显示 PingFailed。就是路由器开通的IPV6防火墙(也有可能是电脑系统禁止了ping,系统默认是不会开启,所以不考虑这种情况)。但是有些路由器是不提供IPV6防火墙开关的,比如我的小米路由器(有部分小米路由器支持关闭IPV6防火墙)、我朋友的TP路由器(也有部分支持)。

  我朋友的路由器也不支持关闭IPV6防火墙,我建设他用光猫拨号再把TP路由器改成桥接模式,最后他修改光猫没有成功。由于当时是晚上,我想就要他明天打电话到联通客服。

  没想到他后面发邮件给TP客服说明IPV6防火墙的问题,第二天客服不但回了邮件还附带发给他一个不带IPV6防火墙的路由器固件,还说这是官方的下个版本固件,到此防火墙的事情解决了。

3、购买域名

  在腾迅云,购买一个CN域名。(因为以前用的是TP路由器,用的是TP的二级域名。用我家VPN时用的是我的二级域名)。购买CN域名要实名认证并上传身份证图片。

4、把域名的DNS服务器改成cloudflare的DNS

  今天不知道为什么cloudflare一样不能登录,所以在网络上找了两张图。

5、在cloudflare增加@和*两个AAAA解析

  因为今天不能登录cloudflare借用其它用户图片。增加两个AAAA解析记录,一个@,一个*,都解析到自己服务器的IPV6地址。@解析的是 XXXX.cn,前面有没有xx.的。*是解析所有子域名,比如www.XXXX.cn、xxx.XXXX.cn。

6.写脚本自动更新域名的IP

根据cloudflare的API文档编写PHP脚本。

//define('URI','https://api.cloudflare.com/client/v4/zones/');

//define('ZONEID','22222222333333');   //Zone ID

//define('DNSRECORDS','dns_records');

define('URI','https://api.cloudflare.com/client/v4/zones/22222222333333/dns_records');

/////22222222333333 改为成自己的Zone ID


$fl_key='XXXXX2222222XXXXXXX22222';   //API Tokens,改成自己的API Tokens


function crul_url($url,$accessToken =false,$data=[],$quest='GET'){

    $data = json_encode($data);

    $ch = curl_init(); //初始化CURL句柄 

    $headers[]="Accept:application/json";

    if($accessToken){

        $headers[]  =  "Authorization: Bearer ". $accessToken;

    }

    curl_setopt($ch, CURLOPT_URL, $url); //设置请求的URL

    curl_setopt ($ch, CURLOPT_HTTPHEADER, $headers);

    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);

    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);

    curl_setopt($ch, CURLOPT_RETURNTRANSFER,1); //设为TRUE把curl_exec()结果转化为字串,而不是直接输出 

    curl_setopt($ch, CURLOPT_CUSTOMREQUEST,$quest); //设置请求方式

    curl_setopt($ch, CURLOPT_POSTFIELDS, $data);//设置提交的字符串

    $output = curl_exec($ch);

    curl_close($ch);

    return $output;

}


function updaterecord($fl_key,$fl_dome_id,$ip,$type=false,$name=false,$ttl=false){

    $updatedata['content']=$ip;

    if($name) $updatedata['name']=$name;

    if($type) $updatedata['type']=$type;

    if($ttl)  $updatedata['$ttl']=$ttl;

    $url=URI.'/'.$fl_dome_id;

    $str=crul_url($url,$fl_key,$updatedata,'PATCH');

    $return=json_decode($str,true);

    if($return && $return['success']){

        return true;

    }else{

        return false;

    }

}


function getipv4(){

    $str=crul_url('http://ipv4.lookup.test-ipv6.com/ip/?asn=1&testdomain=test-ipv6.com&testname=test_asn4');

    $arr=json_decode($str,true);

    return $arr['ip'];

}

function getipv6(){

    $str=crul_url('http://ipv6.lookup.test-ipv6.com/ip/?asn=1&testdomain=test-ipv6.com&testname=test_asn6');

    $arr=json_decode($str,true);

    return $arr['ip'];

}


function echoerr($str=''){

    echo($str);

    exit();

}



$ipv4=false;

$ipv6=getipv6();

if(!$ipv6) echoerr('错误:获取不到IPV6地址。');


$strs=crul_url(URI,$fl_key);


$records=json_decode($strs,true);

if(!$records || !$records['success']){

     echoerr('错误:获取不到域名解析记录。');

}

foreach ($records['result'] as $result){

    if($result['type']=='AAAA'){  //只更新IPV6域名

        $type='AAAA';

        $ip=$ipv6;

        if($ip==$result['content']){

            echo('不用更新此域名'.$result['name']."rn");

        }elseif(updaterecord($fl_key,$result['id'],$ip,$type)){

            echo('更新'.$result['name'].'成功'."rn");

        };

    }

}

?>

   


7、到此外网的IPV4和IPV6都可访问服务器的WEB服务。

  可道云、PHP目录列表、µTorrent、jellyfin这几个服务都用ngix反向代理到子目录。cloudflare支持端口  HTTP:80,8080,8880,2052,2082,2086,2095,HTTPS:443,2053,2083,2087,2096,8443,因为国内环境80和443端口都被封,所以无法启用HTTPS(如果有哪位大神HTTPS启用成功了,我向他请教一下)。其实应该就是反向代理服务。


五、IPV6优化:设置IPV6客户端不经过cloudflare代理

这个设置很简单,在导航页判断客户端是否支持IPV6,如果支持就跳转到不经过代理的域名。

现设置一个v6.xxxx.cn为IPV6的专用域名,再在导航页最前面加入下列代码。

function _jqjsp(data) {

     var v6url='http://v6.xxxx.cn:8880'; //修改为自己的IPV6专用域名地址

     if(data && data.type && data.type=='ipv6' && window.location.href.substr(0,v6url.length)!=v6url){

         window.location.href=v6url;

     }

 }


上面的代码要把三个一起的感叹号(!!!)全删除,下面载张图。

这样只要支持IPV6的客户访问就会跳到v6.xxxx.cn:8880。

六、IPV4优化:把域名DNS转入到腾讯云,域名解析到cloudflare的IP

  https://zhuanlan.zhihu.com/p/570911722  cloudflare自选指定IP节点教程  找出cloudflare延时最低的IPV4节点。把域名的A记录解析到这个IP,可以分别找出电信联通移动 ping值最低掉包最少的节点,记住IP。比如电信最稳定IP为:172.67.209.188,联通最稳定IP为:162.159.160.222

把域名DNS转入腾讯云,但是cloudflare里面的解析和修改不用更改。

可以分别设置电信联通移动解析的IP,这样就可优化不同营运商访问到最佳的cloudflare节点。

在这要注意把cloudflare上的v6.xxxx.cn的AAAA解析记录删除,还要把导航页在第五段的跳转脚本删除。

七:IPV6优化2:把域名的AAAA记录解析到服务器的IPV6地址

把@和*的AAAA记录全解析到服务器的IPV6地址

写脚本自动更新所有域名的AAAA记录。

代码不知道为什么发到文章就不能保存,先截张图。

ID和Token获取方法见官方文档:https://docs.dnspod.cn/account/dnspod-token/


define('URI','https://dnsapi.cn/');

$satcdata=[

    'login_token'=>'ID,Token',   //比如 ID 为:13490,ToKen为:6b5976c68aba5b14a0558b77c17c3932。即完整的 Token 为:13490,6b5976c68aba5b14a0558b77c17c3932 。

    'format'=>'json',

    'lang'=>'cn',

    'error_on_empty'=>'no',

    'domain'=>'XXXX.cn'

];


function recordlist($data){

    $url=URI.'Record.List';

    $return=json_decode(curl_dnspod($url,$data),true);

    return $return;

}


function recordModify($data){

\t$url=URI.'Record.Modify';

\t$return=json_decode(curl_dnspod($url,$data),true);

\treturn $return;

}


function curl_dnspod($url,$data=[]){

\t$ch = curl_init ();

\tcurl_setopt ( $ch, CURLOPT_URL, $url );

\tcurl_setopt ( $ch, CURLOPT_POST, 1 );

\tcurl_setopt ( $ch, CURLOPT_HEADER, 0 );

\tcurl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 );

\tcurl_setopt ( $ch, CURLOPT_POSTFIELDS, $data );

\t$return = curl_exec ( $ch );

\tcurl_close ( $ch );

\treturn $return;

}


function recordlupdate($data,$ip){

    $data['record_type']='AAAA';  //只查询AAAA记录的IPV6解析

    $recordlist=recordlist($data);

    if($recordlist && $recordlist['status'] && $recordlist['status']['code']=="1" && $recordlist['records']){

        foreach ($recordlist['records'] as $record){

            if($ip==$record['value']){

                echo('不用更新此域名'.$record['name'].'.'.$data['domain']."rn");

            }else{

                $redata=$data;

                $redata['record_id']=$record['id'];

                $redata['sub_domain']=$record['name'];

                $redata['record_line_id']=$record['line_id'];

                $redata['value'] = $ip;

                $retrun=recordModify($redata);

                if($recordlist && $recordlist['status'] && $recordlist['status']['code']=="1"){

                    echo('更新域名成功:'.$record['name'].'.'.$data['domain']."rn");

                }else{

                    echo('更新域名失败:'.$retrun['status']['message'].':'.$record['name'].'.'.$data['domain']."rn");

                }

            }

        }

    }elseif($recordlist && $recordlist['status']){

        echo('查询域名失败:'.$retrun['status']['message'].':'.$data['domain']."rn");

    }

}


function getipv6(){

    $str=curl_dnspod('http://ipv6.lookup.test-ipv6.com/ip/?asn=1&testdomain=test-ipv6.com&testname=test_asn6');

    $str=trim($str);

    $arr=json_decode($str,true);

    if($arr['ip']){

        return $arr['ip'];

    }else{

        return false;

    }

}

$ipv6=getipv6();

if($ipv6){

    recordlupdate($satcdata,$ip);

}else{

    echo("没有获取到IPV6地址。rn");

}


代码终于发出来了。

现在可以实现IPV6直接访问服务器,IPV4用cloudflare反向代理访问,还可根据营运商访问不同的cloudflare节点,实现快速稳定访问服务器。

","force_purephv":"0","gnid":"98c16fbb424ddc026","img_data":[{"flag":2,"img":[{"desc":"","height":"407","title":"","url":"https://p0.ssl.img.360kuai.com/t0135a9aac4f040977a.jpg","width":"600"},{"desc":"","height":"290","title":"","url":"https://p0.ssl.img.360kuai.com/t01bba1516c15f60454.jpg","width":"600"},{"desc":"","height":"410","title":"","url":"https://p0.ssl.img.360kuai.com/t01d63ef0c1810f5004.jpg","width":"600"},{"desc":"","height":"642","title":"","url":"https://p0.ssl.img.360kuai.com/t015275314ad2b640ba.jpg","width":"600"},{"desc":"","height":"463","title":"","url":"https://p0.ssl.img.360kuai.com/t012dec3e6c8226f7dc.jpg","width":"600"},{"desc":"","height":"370","title":"","url":"https://p0.ssl.img.360kuai.com/t01bb2e2476c7871526.jpg","width":"600"},{"desc":"","height":"387","title":"","url":"https://p0.ssl.img.360kuai.com/t01e86d4db8fd086f38.jpg","width":"600"},{"desc":"","height":"346","title":"","url":"https://p0.ssl.img.360kuai.com/t01860f9aceb96a9d13.jpg","width":"600"},{"desc":"","height":"303","title":"","url":"https://p0.ssl.img.360kuai.com/t013b18dd1d03dff1f8.jpg","width":"600"},{"desc":"","height":"421","title":"","url":"https://p0.ssl.img.360kuai.com/t01d2914285030e7d2f.jpg","width":"600"},{"desc":"","height":"516","title":"","url":"https://p0.ssl.img.360kuai.com/t0179b2276b00de489c.jpg","width":"600"},{"desc":"","height":"502","title":"","url":"https://p0.ssl.img.360kuai.com/t016c8b45a4a14af1d2.jpg","width":"600"},{"desc":"","height":"421","title":"","url":"https://p0.ssl.img.360kuai.com/t01d929825571daab2f.jpg","width":"600"},{"desc":"","height":"347","title":"","url":"https://p0.ssl.img.360kuai.com/t0116a215a66a98aee3.jpg","width":"600"},{"desc":"","height":"269","title":"","url":"https://p0.ssl.img.360kuai.com/t017f869a6482594f85.jpg","width":"600"},{"desc":"","height":"314","title":"","url":"https://p0.ssl.img.360kuai.com/t010fdcbf4de76e08ca.jpg","width":"600"},{"desc":"","height":"314","title":"","url":"https://p0.ssl.img.360kuai.com/t01e640fdbd511414f3.jpg","width":"600"},{"desc":"","height":"372","title":"","url":"https://p0.ssl.img.360kuai.com/t018b14a53a6d55c98d.jpg","width":"600"},{"desc":"","height":"333","title":"","url":"https://p0.ssl.img.360kuai.com/t014f7153caacef2ab9.jpg","width":"600"},{"desc":"","height":"317","title":"","url":"https://p0.ssl.img.360kuai.com/t012ad10c45047644f7.jpg","width":"600"},{"desc":"","height":"231","title":"","url":"https://p0.ssl.img.360kuai.com/t01be7b4281cf2f5662.jpg","width":"600"},{"desc":"","height":"231","title":"","url":"https://p0.ssl.img.360kuai.com/t01e85f5772ff2950d1.jpg","width":"600"},{"desc":"","height":"574","title":"","url":"https://p0.ssl.img.360kuai.com/t013ff0b0d54b807f68.jpg","width":"600"}]}],"original":0,"pat":"art_src_1,fts0,sts0","powerby":"hbase","pub_time":1667888379000,"pure":"","rawurl":"http://zm.news.so.com/c51b9a7e8524d9ae0aa3459ad4f8ee96","redirect":0,"rptid":"a708eb3990502887","s":"t","src":"什么值得买","tag":[{"clk":"ktechnology_1:路由器","k":"路由器","u":""}],"title":"IPV6被全网访问折腾记!——NAS无IPV4公网、无内网穿透、无VPN,外网访问折腾记实

诸钓忠4487外网怎样访问内网?内网通过路由器上网 -
杨咏屠19722363503 ______ 如果你是普通宽带路由器,外网访问内网基本来说可以用两种方式 第一把内网的某台电脑(要固定设置IP)放在DMZ里(在路由器删设置),这样只要外网的电脑访问你上网的外网IP 就能直接访问这个机器了(远程桌面 、ftp、web 还有你需要的应用) 第二,做端口映射,把你需要的应用程序端口 在路由器nat 那个菜单那边做映射,映射到你局域网内对应的服务器就行了

诸钓忠4487让外网可以访问我的电脑 -
杨咏屠19722363503 ______ 1、你的电脑要设定一个固定的内网IP,如192.168.1.168; 2、在路由器内虚拟服务器设置80端口转发到192.168.1.168; 3、先在自己的电脑里用http://192.168.1.168试着访问一下,如果不行的话应该是你的IIS还没设置成功;如果能访问应该是花生壳设置的问题(当然,如楼上所言,现在开通个人网站还要备案). 4、希望你的网站早日开通.

诸钓忠4487怎样让外网访问内网中的一台电脑
杨咏屠19722363503 ______ 有类似于异速联的软件安装在内网的电脑上. 最后只须在路由或防火墙那开通相应的端口即可.

诸钓忠4487如何从外网访问办公室内网 -
杨咏屠19722363503 ______ 如果你想从外部网络来访问你的内部网络!需要你在你内网代理服务器上做端口影射(也就是你内网是通过什么上网的!比如硬路由、软路由、代理服务器等)!让来访问你公网ip的端口影射到内网ip的端口上!比如你准备开网站的话那需要影射80端口到你内网ip的80端口!如果是传奇私服的话得影射7000 7100 7200端口!不知道解释的是否理解!

诸钓忠4487如何从外网连接内网主机
杨咏屠19722363503 ______ 设置内网路由器DMZ,添上你要被外网访问的机器IP地址

诸钓忠4487如何让外网访问内网 -
杨咏屠19722363503 ______ 1.路由器有个DMZ功能,意思就是把指定的IP直接透传过路由器完全暴露在公网上. 2.路由器有 虚拟服务器 功能,把你要开放的内网IP的端口开放出来.(你要先知道你共享的服务的端口)

诸钓忠4487外网如何访问内网 -
杨咏屠19722363503 ______ 在路由器上做端口映射``例如外网的80端口``你的内网ip是192.168.1.10的话``直接把外网的ip的80端口映射到你192.168.1.10的80端口`就可以了

诸钓忠4487请问外网(互联网)电脑如何访问内网(内部办公网、未链接互联网)电 -
杨咏屠19722363503 ______ 相互访问,需要线路上的连通 你内网未连接互联网,就导致外网电脑无法访问了啊 你必须设置网络连接 比如在那台要访问的内网电脑上加装网卡,连接入外网 或者把整个内网通过路由器接入到外网 至于设置,你最好还是叫有经验的来,不然安全方面出问题了损失大

诸钓忠4487怎么从外网PC连接到内网PC -
杨咏屠19722363503 ______ 使用IP地址切换器之类的软件即可

(编辑:自媒体)
关于我们 | 客户服务 | 服务条款 | 联系我们 | 免责声明 | 网站地图 @ 白云都 2024