声明:本文仅为方便绘画交流与学习,恕不提供 Pixiv 外其他网站指导!上次更新:2019.9.9
目录
I.Nginx 本地代理(PC适用)
II.Android 第三方客户端
III.镜像站
前言
自从 2017 年末,Pixiv 的网页和 APP 始终无法直接打开,但是检测发现其 IP 本身并没有被封禁,所以只要一点小把戏,并借助平时做网站常用反代理服务器 Nginx 即可以完美绕过针对 SNI 审查,整个代理过程在用户自己的电脑上完成,并不涉及任何第三方服务,因此理论上是完全合法的个人行为。鉴于是小白向的指南,所以不想写太多望而生畏(其实业内并不复杂)内容,如果要问原理请看这里。
- 个人精力有限无法为大家一一作出指导,可以到 QQ 群咨询其他大佬,一群:905209253,二群:901311039,三群:681759820,四群:1038688540,验证问题的答案是
Sakura
。 请低调使用此教程和工具,不建议广泛传播。
Nginx 本地代理
Windows 使用方法
从 Github 或者国内镜像下载,并解压到电脑任意路径中不含中文、日文等非英文字符的位置,之后安装文件名为 ca.cer
的根证书文件,然后参考下方「hosts 修改方法」部分修改 hosts(请使用压缩包里的hosts,因为每次更新都可能变的),最后通过可视化工具或者调试工具启动 Nginx 即可。
重要提醒:使用 Nginx 反代理的时候建议关闭各类全局代理,如各类 VPN 客户端、浏览器代理插件、某些 steam 代理工具、类似 ADSafe 这样的广告屏蔽软件,如果对 P 站的域名启用了代理,那么 hosts 就无法生效,所以请将他们暂时关闭或者把 P 站相关域名移出代理列表。
说明:
① Chrome 浏览器证书安装方法、FireFox 浏览器证书安装方法,按键具体位置因浏览器版本而异,可利用浏览器配置界面的搜索框快速查找;其他浏览器请自行寻找安装方法。务必确保 Mashiro Internet Fake Authority CA 已经添加到了受信任机构列表中(如图),遇到浏览器安全提醒说明你一定还没有添加成功。注意:如果遇到浏览器显示网站不可信任,这时即使你点了信任,网页内的图片等内容还是可能被浏览器阻止,最好的解决办法是保证证书安装成功。
② 如果遇到 Nginx 启动失败,首先请确保路径为全英文,可将解压出来的整个文件夹移动到各个磁盘的根目录处;其次自行查看错误日志,通常用搜索引擎直接检索日志里那行信息就可以找到一大堆解决方法了;如需反馈请附上logs/error.log
中的日志(摘取出现错误时间点的片段即可,一般在文件最后几行,切勿在我这里发太长的日志)。
③ 无法启动 Nginx,常见原因是端口被占用(80 或 443 端口,建议先看一下日志),参考端口占用的解决方法。
④ 很多人说图片显示不出来,可依次尝试把 hosts 中 i.pximg.net
的 IP 改成 210.140.92.140、210.140.92.141、210.140.92.134、210.140.92.135、210.140.92.139、210.140.92.143、210.140.92.137、210.140.92.138 中的任意一个。
⑤ 可视化工具仅支持 Windows 64 位版,32 位版请尝试通过调试脚本启动,如果都不行请看用 cmd 管理 Nginx
。
MAC 使用方法
MAC 上同样可以使用 Nginx,详细的 MAC 配置方法请看这篇文章。
Linux 使用方法
Nginx 配置文件目录为 /etc/nginx/
,使用和 MAC 完全一致的配置文件和证书并替换配置文件即可,最后参考下方「hosts 修改方法」部分的方法修改 hosts(请使用压缩包里的hosts,因为每次更新都可能变的)。
hosts 修改方法
以下是针对 Windows 的改法,其他系统类似,可自行百度 hosts 文件的位置。MAC用户看这里。Linux各发行版:sudo nano /etc/hosts
,原则上立即生效。
用文本编辑器(比如 Notepad++)打开 "C:\Windows\System32\drivers\etc\hosts"
文件(64位和32位系统都是这个路径,不熟悉的注意看下后面的补充及截图),最下方直接粘贴压缩包内 hosts 文件中的内容后保存(遇到权限问题无法保存看这里),这时应该就可以正常访问了。如果仍然无法访问,请按下 + R 键,输入 cmd
,回车,进入 cmd 后输入 ipconfig /flushdns
,回车执行以刷新DNS缓存,若还不行请尝试清理浏览器缓存、Cookie、停用所有浏览器插件并重启电脑。
请注意: hosts文件无后缀,无后缀,无后缀! 同时 hosts 文件中不能有 http://
、https://
等开头和斜杠 /
。
hosts 文件位置如下:
hosts 文件粘贴示例(实际粘贴的内容与图中不完全一致):
如果你嫌上面的操作太麻烦了,或者极少数电脑原本就没有 hosts 文件,可直接用压缩包内的 hosts 文件覆盖原文件或放到以上 hosts 文件的路径就行了。
Android 代理方案
在第三方客户端 Pivision 基础上更换了代理接口、修复了 OAuth 登陆问题,重新打的包改名 PivisionS,这里下载。
PivisionS 更新记录:
发布时间 | 版本号 | 更新内容 |
---|---|---|
2019-09-09 06:30 | 1.0 | 修复大陆无法使用的“bug”;更新 OAuth 登陆接口 |
2019-09-09 20:00 | 5.0.1 | 更新代理源 |
做这个纯属举手之劳,并且能力也有限,如果嫌慢、功能少请自购 VPN 吧。
此外也有不少优秀的 Pixiv 第三方客户端可以选择,它们基于类似前文的域前置方法实现了直链访问。比较优秀的两个是 Shaft 和 Pix-EzViewer,这两个 APP 的安装包可以在文章开头的群文件里获取。
iOS 代理方案
抱歉,iOS 客户端除了 VPN 暂时没有更好的办法了(其实像上面 Android 那样做个客户端也不难,几个简单的接口改一下就行了)。
镜像站
如果你有自己的服务器的话,可以搭建镜像站,虽然难度不大,但是都有自己服务器了何不直接自建 VPN 呢?而且这显然是不合法的,自己悄悄用就好了。
相关教程:https://moe.best/technology/pixiv-proxy.html
常见问题
无法登陆/注册
登陆问题在最新版 Nginx 本地代理工具包中解决了,注册的话,可以加文章开头的 QQ 群,找管理员免费代注册。
关于证书
这是我自己签的证书,如果你信任我,那么直接安装即可;如果不信任,那么请自己签,自签证书教程。
证书十年后到期,到时候记得来找我,haha。
关于维基百科和 Steam
Wikipedia、Steam Community 的封锁情况与 P 站完全一致,所以在 mashirozx/Pixiv-Nginx 中都顺便反代了,相应地增加以下 hosts 即可:
# Wikipedia Start
# 维基百科语言众多,其他语言参照下面添加 xx.wikipedia.org 及 xx.m.wikipedia.org 的记录即可
127.0.0.1 en.wikipedia.org #英文维基百科桌面版
127.0.0.1 zh.wikipedia.org #中文维基百科桌面版
127.0.0.1 en.m.wikipedia.org #英文维基百科移动版
127.0.0.1 zh.m.wikipedia.org #中文维基百科移动版
127.0.0.1 zh-yue.wikipedia.org #粤文维基百科桌面版
127.0.0.1 wuu.wikipedia.org #吴语维基百科桌面版
127.0.0.1 ug.wikipedia.org #维吾尔文维基百科桌面版
127.0.0.1 ja.wikipedia.org #日文维基百科桌面版
# Wikipedia End
# Steam Community
127.0.0.1 store.steampowered.com
127.0.0.1 steamcommunity.com
# Steam Community End
法律适用
《国际联网暂行规定》第六条规定:“计算机信息网络直接进行国际联网,必须使用邮电部国家公用电信网提供的国际出入口信道。任何单位和个人不得自行建立或者使用其他信道进行国际联网。”Nginx 本地代理和服务器代理(代理服务器位于广州)使用的都是“公用电信网提供的国际出入口信道”,从日本 Pixiv 服务器到国内用户电脑/代理服务器的流量,使用的是正常流量通道,其间未对流量进行任何额外加密(仅有网页原有的 SSL 加密,用户和代理人并不掌握该 SSL 密钥,区别于 VPN 的流量加密),而 Nginx 获取到网页数据之后发生的整个代理过程完全在国内,不再适用国际互联网相关之规定。
其他
如果嫌每次手动开启 Nginx 麻烦,可以在确保无端口占用的情况下,将 nginx.exe
的添加到开机启动项中,方法可自行查找,不再赘述。
转载请注明出处: https://2heng.xin/2017/09/19/pixiv/
「樱花庄的白猫」原创文章:《PIXIV网页版及客户端访问恢复指南》,转载请保留出处!https://2heng.xin/2017/09/19/pixiv/
Q.E.D.
Comments | 2,600 条评论
博主 3512215909
所以..steamcommunity302并不能和这个一起打开的说
博主 fnagppp
最近好像i.pximg.net挂了,上了pixiv但是刷不出图片。前2天还正常。
博主 1944623988
@fnagppp 其实只要把hots跟新一下就好了
博主 88
@1944623988 请问下如何更新啊,按文章内说的改i.pximg.net的IP那些全都没效果啊
博主 111111111
@88 用Chrome,右击图片选择在隐身窗口打开链接,然后用这个窗口浏览图片就行了
博主 青心雨
@111111111 试了,不行啊。。。。
博主 名無し
@1944623988 请问怎么办,我也是刷不出图片
博主 sss
@名無し 点上面的此处下载,可以看到里面的hots上个月更新过一次,然后把他下载下来复制粘贴到pc端hots的位置然后就ok了
博主 水澄律
圖片加載不出來怎麼辦
博主 韩至
直接在https://www.lengjiao.me 买个加速器就可以上pixiv了,8块钱能用2个月,稳定。nginx也该淘汰了。
博主 SheffYava
为什么打不开steam,显示“421 Misdirected Request nginx”?
博主 走音喇叭
我安装证书之后就上不了github.io了,怎么办呀
博主 倵绫
最近vikacg的dns也被污染了,有没有大佬知道怎么反代啊
博主 Lalalalarara
@倵绫 一行Hosts解决的事在这唧唧歪歪,104.26.12.176 https://www.vikacg.com,根本用不着反代那么麻烦,20秒测试完,可以访问。
博主 liyuqi
你好想问一下这种错误该如何解决。
访问某网站502。
检查error.log提示为,1 peer closed connection in SSL handshake (10054: An existing connection was forcibly closed by the remote host) while SSL handshaking to upstream
博主 wangkai
你们把上pixiv想的太复杂了吧。直接在 oxk.me 里面买个助手即可上pixiv,8块60天,刷图不要太香
博主 Enderturtle
这段时间突然pixiv极其卡顿,不知道什么原因
博主 ShioMile
花了两小时把解决数个问题终于让Android通过turmux配置好了Nginx反代。待解决的问题是:目前好像只能作用于浏览器,对app没有效果。
博主 空之星星
@ShioMile 大佬,用你的一件签的证书p站能正常上但是e站会跳502跟504是哪里出的问题?
博主 ShioMile
@空之星星
是exhentai吧,一般可以检查 log 文件夹下的 error.log,看是哪个IP比较缓慢,在 pixiv.conf 文件中删掉即可。
中国互联网国际出口数量少,拥堵,这当然为了方便GFW审查有意设置。特别是在下午18:00 – 凌晨3:00,ISP会启用QoS限速,pixiv图片加载不出来也是这原因(大部分没有CDN的境外网站都会在这个时间点拉跨)。
博主 9953369705
现在改用梯子上了,为什么网站加载速度变得非常缓,怎么还原这个
博主 ShioMile
我是“自签名一键批处理脚本”的作者,现在已经Fork项目继续开发(https://github.com/ShioMile/Pixiv-Nginx),还写了一份图文并茂的教程(https://github.com/ShioMile/Pixiv-Nginx/wiki/%E4%BD%BF%E7%94%A8%E6%96%B9%E6%B3%95),欢迎大家Star和PR。
博主 ShioMile
@ShioMile v2020.12.18 新增MEGA和OneDrive网盘的访问。
更新地址:https://github.com/ShioMile/Pixiv-Nginx/releases/latest
博主 nobody
@ShioMile 谢谢大佬,很好用,已加星
博主 fromzero1501
@ShioMile 楼主的证书可以,你这个不行。不过楼主的登录后加载不了图片
博主 TENET
@fromzero1501 不行到底是哪里不行,能不能说清楚。虽然他接手的这东西删掉了原来的证书不能直接开箱即用,但在我这里效果不错,你查查你的安装步骤是否有问题。
博主 fromzero1501
@TENET 1 证书混一起了,不好测试
2 Nginx启动,我看楼主是2个进程,你这个怎么只有1个进程
3 配置报错,检查测试 nginx 配置文件……
nginx: [emerg] cannot load certificate “D:\SoftWare\enhanceSoftWare\nginx-1.19.6/conf/ca/localhost.crt”: BIO_new_file() failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen(‘D:\SoftWare\enhanceSoftWare\nginx-1.19.6/conf/ca/localhost.crt’,’r’) error:2006D080:BIO routines:BIO_new_file:no such file)
nginx: configuration file D:\SoftWare\enhanceSoftWare\nginx-1.19.6/conf/nginx.conf test failed
4 你这个打开后,显示拒绝请求,和没打开一样。楼主那个,有图片未显示的配置文件,我替换后,现在能显示图片,但速度很慢,只有50k左右
博主 TENET
@fromzero1501 草,我也发现,他在pixiv.conf里配置里全写的是ssl_certificate ca/localhost.crt,弱智啊
博主 TENET
@fromzero1501 我用它访问维基百科没发现这错误,看你的日志才发现。这种错误可以自己手动用文本编辑器比如notepad++之类的替换掉
博主 ShioMile
@fromzero1501 已修复,不好意思把其它测试环境使用的证书没注意就写进conf文件了,以后提交会仔细审查测试
博主 110
@ShioMile 建议保留证书、nginx.exe、可视化工具。原本只要往浏览器导入证书,改下host就能用了,现在反而变麻烦了。
博主 回眸望生
博主 柠檬
网站能进去,但是加载不出图片= =