神代綺凛

[Pixiv] Nginx 真·反代P站
解决了一年前的我无法解决的世纪难题(x 深刻意识到,很多以前自己认为无解的问题并不是真的无解,只是自己的知识面不够...
扫描右侧二维码阅读全文
08
2018/11

[Pixiv] Nginx 真·反代P站

解决了一年前的我无法解决的世纪难题(x

深刻意识到,很多以前自己认为无解的问题并不是真的无解,只是自己的知识面不够而无法意识到问题的核心所在罢了。

总结起来就一个字:菜

Head Pic: 「Halloween」/「鳥成」のイラスト [pixiv]

前言

本文所述的所有内容仅供交流学习,请勿实际做出任何违反国家法律的行为!

此方案为真的反代,而不是在本地反代以绕过 SNI 审查的方法(Mashiro - PIXIV网页版及客户端访问恢复指南

请不要在互联网上公开自己搭建的反代站,P 站可能会发邮件到您的主机商投诉。如果您因为此种原因导致 VPS 服务等被终止,本人不负任何责任。

准备工作

  1. 一台没被P站屏蔽的主机
    众所周知 Vultr 大部分IP段都被P站屏蔽
  2. 一个船新的域名
    其实随意啦,用自己域名的二级来弄也可,只是域名会变得比较长
    后续均以example.com来指代我们使用的域名,请灵性代换
  3. 因为反代域名较多,最好使用支持泛域名的 SSL 证书,这里我们自然首推 Let's Encrypt

域名及证书

需要使用哪些域?

在反代时我们需要用到以下几个域

如果你愿意使用一个船新域名专门反代:

example.com
*.example.com
*.pximg.example.com
  • example.com
    随意,你可以放点自己的东西做一些伪装或者说明,或者直接 301 到www.example.com
  • *.example.com
    用于反代对齐*.pixiv.net
  • *.pximg.example.com
    用于反代对齐*.pximg.net,其实该域名中的pximg也可以替换成其他的字符串,只要不与P站的二级域名服务产生冲突即可

如果你想用一个自己正在使用的域名反代并且不想影响该域名的其他服务:

pixiv.example.com
*.pixiv.example.com
*.pximg.example.com

各自作用同上,在后续配置上灵性修改即可

获取证书

如果你愿意套 CloudFlare,你可以跳过这一节

使用 acme 的 DNS API 方式进行挑战验证来签发证书是最方便的

参考以下文章

在配置好 API 之后我们使用这样的命令即可签发一个我们想要的三域名合一的证书了,并且还能自动续签,岂不美哉

~/.acme.sh/acme.sh --issue --dns dns_cx -d example.com -d '*.example.com' -d '*.pximg.example.com'

Nginx

不要使用 Tengine 等 Nginx 分支版本,在某些模块上可能会有一些奇怪的差异与问题

基础配置

这里仅列出关键配置,通常配置例如listenexpirescache以及 SSL 之类的不会写出,自行添加

# *.example.com
server
{
    server_name ~^([^.]+)\.example\.com$;
    set $domain $1;

    resolver 8.8.8.8;

    location ~ .*
    {
        proxy_set_header Host $domain.pixiv.net;
        proxy_set_header Referer "https://www.pixiv.net";
        proxy_cookie_domain pixiv.net example.com;
        proxy_pass https://$domain.pixiv.net;
        proxy_ssl_server_name on;
        proxy_set_header Accept-Encoding "";
        proxy_redirect https://accounts.pixiv.net/ https://accounts.example.com/;

        sub_filter "i-cf.pximg.net" "i.example.com";
        sub_filter "pixiv.net" "example.com";
        sub_filter "pximg.net" "pximg.example.com";
        # 防止错误上报暴露站点
        sub_filter "js_error.php" "block_js_error";
        # 防止谷歌服务暴露站点,同时也可以加快网站加载
        sub_filter "www.google" "block_google";
        sub_filter_once off;
        sub_filter_types *;
    }
}

# *.pximg.example.com
server
{
    server_name ~^([^.]+)\.pximg\.example\.com$;
    set $domain $1;

    resolver 8.8.8.8;

    location ~ .*
    {
        proxy_set_header Host $domain.pximg.net;
        proxy_set_header Referer "https://www.pixiv.net";
        proxy_pass https://$domain.pximg.net;
        proxy_ssl_server_name on;
        proxy_set_header Accept-Encoding "";

        sub_filter "i-cf.pximg.net" "i.example.com";
        sub_filter "pixiv.net" "example.com";
        sub_filter "pximg.net" "pximg.example.com";
        # 防止错误上报暴露站点
        sub_filter "js_error.php" "block_js_error";
        # 防止谷歌服务暴露站点,同时也可以加快网站加载
        sub_filter "www.google" "block_google";
        sub_filter_once off;
        sub_filter_types *;
    }
}

详解

  • server_nameset
    使用正则表达式匹配以方便直接提取出我们要反代的二级域名
  • resolver
    必要,指定域名解析所用 DNS,因为在后续proxy_pass中我们要反代的域名是由$domain决定,本身是不定的,Nginx 必须被指定 DNS 才能处理域名解析
  • proxy_cookie_domain
    改变反代后返回的 header 中 set-cookie 里 cookie 对应的域名,只在*.example.com中需要,是解决登陆问题的关键,如想了解后续文章会解释
  • proxy_ssl_server_name
    由于 P 站开始上 CF 了,其 TLS 启用了 SNI,因此必须指定此项为on,否则会握手失败
  • proxy_set_header Referer
    设置 header 中的 Referer,主要目的是解决i.pximg.net的防盗链问题,以及www.pixiv.net的部分 API 的 Referer 验证问题
  • proxy_set_header Accept-Encoding
    将接受的压缩编码设为空,即不接受压缩,因为sub_filter无法对压缩过的内容起效
  • proxy_redirect
    将返回原站 302 的请求进行重定向
  • sub_filter
    将反代后得到的内容进行字符串替换,以保证链接域名等与反代域名一致
  • sub_filter_types
    必须设置为*,否则默认对于 API 返回的 json 内容等不会进行替换,会导致依靠 ajax 运作的一些功能的异常

增强隐蔽性(建议)

防止被搜索引擎收录

在 Nginx 配置中向每个 server 添加此句

    if ($http_user_agent ~* "qihoobot|Baiduspider|Googlebot|Googlebot-Mobile|Googlebot-Image|Mediapartners-Google|Adsbot-Google|Feedfetcher-Google|Yahoo! Slurp|Yahoo! Slurp China|YoudaoBot|Sosospider|Sogou spider|Sogou web spider|MSNBot|ia_archiver|Tomato Bot|^$") {  
        return 403;
    }

请加到set $domain $1;这句之后,因为该配置也使用了正则表达式,会导致$1改变

禁止大陆外IP访问

由于反代P站的受众只可能为大陆内用户,因此我们完全可以禁止大陆外IP访问反代站,同时还能防止P站检测投诉

但请注意,这个方案是对整台 VPS 的80443端口生效,这意味着你如果同时在 VPS 上布置了其他站点,他们也将无法被大陆外用户访问

如果需要仅对反代站点生效,请自行百度参考“nginx geoip”,或者使用后面所述的套 CloudFlare 的方式

参考步骤:

  1. 安装 ipset
    # Debian / Ubuntu
    apt-get -y install ipset
    # CentOS
    yum -y install ipset
  2. 创建一个 ipset 并添加大陆IP作为白名单
    ipset -N cnip hash:net
    for i in $(curl https://raw.githubusercontent.com/17mon/china_ip_list/master/china_ip_list.txt); do ipset -A cnip $i; done
    # 如果你想要添加单个IP x.x.x.x 进此白名单
    ipset -A cnip x.x.x.x/32
  3. 写入防火墙规则(顺序十分重要,请不要改变执行顺序)
    iptables -I INPUT -p tcp --dport 443 -j DROP
    iptables -I INPUT -p tcp --dport 80 -j DROP
    iptables -I INPUT -p tcp -m set --match-set cnip src -j ACCEPT

套 CloudFlare

除了上述方案外,我自己是套了层 CloudFlare,并设置了防火墙规则来阻止非国内以及搜索引擎爬虫访问

这样有个优点,一是 SSL 证书都是 Cloudflare 自动签发和续期的,因此使用 Flexible SSL 选项,然后源反代站就不需要操心证书的事了,直接使用 HTTP;二是 Cloudflare 的防火墙可以实现上面提到的屏蔽国内 IP 以及搜索引擎的功能,不需要自己去维护

当然这样是有缺点的,就是设置 DNS 记录

Cloudflare CDN不支持设置泛域名记录

因此我们只能一条一条记录加,首次部署简直是要了命,以下列出主站功能相关域名:

www.pixiv.net
accounts.pixiv.net
source.pixiv.net
imp.pixiv.net

i.pximg.net
s.pximg.net
pixiv.pximg.net

其他的例如小说、直播等等我个人使用频率很低所以我就不考虑了,当然如果你有需求就自己找域名吧(

局限性

不能使用绑定的社交账号的登录方式

帐号可能会出现需要 reCAPTCHA 验证导致无法登录,无解,只能自己将原站已登录的 cookie 导出,替换域名,然后导入反代站来进行登录

可能存在尚未发现的问题

解决登陆问题的关键

这个问题困扰我一年了,以前我尝试反代的时候,登录会提示“无效的服务器”而无法登陆,直到最近才发现真正原因

我通过搜索引擎查找了很多文章,直到遇见了这篇
模拟登录pixiv.net后续 - ことりのおやつにしてやるぞー!

之前我认为,登录时唯一要注意的只有postKey,而代码中的获取 cookie 的操作提醒了我,我的直觉告诉我登录失败是跟 cookie 有关

于是我又翻看了一下 GET 登陆页面时的 header,原来是有 set-cookie 的,而我之前一直从登录相关 js 的操作入手因此没有注意到这个细节

根据这个思路我试着自己用 Nodejs 写了个模拟登录来尝试

const Axios = require('axios');
const Qs = require('qs');

async function test() {
    let postKey, cookie = '';

    //访问登录页
    await Axios.get('https://accounts.pixiv.net/login?lang=zh&source=pc&view_type=page&ref=wwwtop_accounts_index', {
        headers: {
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"
        }
    }).then(res => {
        //获取登录页 cookie 和 postKey
        for (let set of res.headers['set-cookie']) {
            cookie += '; ' + set.split(';')[0];
        }
        cookie = cookie.substr(2);
        postKey = /"pixivAccount\.postKey":"([0-9a-z]+)"/.exec(res.data)[1];
    });

    //向登录 API 发送 POST
    await Axios.post('https://accounts.pixiv.net/api/login?lang=zh', Qs.stringify({
        pixiv_id: '邮箱',
        password: '密码',
        captcha: '',
        g_recaptcha_response: '',
        post_key: postKey,
        source: 'pc',
        ref: 'wwwtop_accounts_index',
        return_to: 'https://www.pixiv.net/'
    }), {
        headers: {
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36",
            "content-type": "application/x-www-form-urlencoded",
            "accept": "application/json",
            "cookie": cookie
        }
    }).then(res => {
        console.log(res.data);
        console.log(res.headers['set-cookie']);
    });
}

test();

返回内容与返回 header 中的 set-cookie:

可喜可贺,也就是说确实是 cookie 的锅

准确地说是因为 sub_filter 只能替换 response 中的内容,我没有想到 set-cookie 的 domain 由于是 .pixiv.net,不会被任何机制自动替换,与反代域名不同,没有 set 上,因此导致发出登录 POST 的时候没有携带上这个 cookie

知道了问题核心所在,那么解决方案自然也就不难想到了,经过搜索我找到了 Nginx 官方文档中有提到 proxy_cookie_domain

Syntax:
proxy_cookie_domain off;
proxy_cookie_domain domain replacement;

Default:
proxy_cookie_domain off;

Context: http, server, location

This directive appeared in version 1.1.15.

Sets a text that should be changed in the domain attribute of the "Set-Cookie" header fields of a proxied server response.

问题解决√

而且没想到解决方式竟如此简单,只不过是加一行配置的事

搬瓦工VPS优惠套餐,建站稳如狗,支持支付宝,循环出账94折优惠码BWH3HYATVBJW
年付$47CN2线路,1核/1G内存/20G硬盘/1T@1Gbps【点击购买
季付$47CN2 GIA线路,1核/1G内存/20G硬盘/1T@2.5Gbps【点击购买
Last modification:March 5th, 2023 at 01:11 pm
If you think my article is useful to you, please feel free to appreciate

Leave a Comment

143 comments

  1. losquare  Windows 10(Windows 10) / Google Chrome 76.0.3809.100(Google Chrome 76.0.3809.100)
    今天在检查依据您的教程搭建的反代时,发现登录时出现reCAPTCHA验证 报错,内容为:需要网站所有者处理的错误:网站密钥的网域无效 推测是反代域名与p站域名不一致导致的,请问有解决的方法吗?|´・ω・)ノ
    1. 神代綺凜  Mac OS X 10.14.6(Mac OS X 10.14.6) / Google Chrome 76.0.3809.100(Google Chrome 76.0.3809.100)
      @losquare 没有,登录时出现 reCAPTCHA 和帐号有关,而且反代域名和原域名不一致所以无法提交 reCAPTCHA,目前无解

      从帐号方面入手的话,建议访问原站并保持一定的使用频率,最好是利用你想要拿来做反代站的主机做代理节点,一段时间以后再试

      1. LYM  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 77.0.3865.90(Google Chrome 77.0.3865.90)
        @神代綺凜 reCAPTCHA 只和账号有关吗QAQ,不知道为什么老是出现这个。朋友的号也是。。感觉是服务器的问题??
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 77.0.3865.90(Google Chrome 77.0.3865.90)
          @LYM 只是猜测(
  2. kenshin  Android 9(Android 9) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
    该评论仅登录用户及评论双方可见
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 76.0.3809.87(Google Chrome 76.0.3809.87)
      @kenshin
      该评论仅登录用户及评论双方可见
      1. kenshin  Android 9(Android 9) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
        @神代綺凜 我直接用宝塔直接反代,会选跳p站
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 76.0.3809.87(Google Chrome 76.0.3809.87)
          @kenshin 当然不能直接用它的反代功能啊……

          得自己改配置

          1. kenshin  Android 9(Android 9) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
            @神代綺凜 改过了,我再检查一下
      2. kenshin  Android 9(Android 9) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
        @神代綺凜 折腾了一下,有些设置没设置好,没搞成
  3. Hakula  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.90(Google Chrome 75.0.3770.90)
    该评论仅登录用户及评论双方可见
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.100(Google Chrome 75.0.3770.100)
      @Hakula
      该评论仅登录用户及评论双方可见
      1. Hakula  Mac OS X(Mac OS X) / Safari(Safari)
        @神代綺凜
        该评论仅登录用户及评论双方可见
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.100(Google Chrome 75.0.3770.100)
          @Hakula
          该评论仅登录用户及评论双方可见
      2. Hakula  Mac OS X(Mac OS X) / Safari(Safari)
        @神代綺凜
        该评论仅登录用户及评论双方可见
  4. 安忆  Android 9(Android 9) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
    唔,是轮子|´・ω・)ノ(https://blog.anyi.in/p/wikimirror.html
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.90(Google Chrome 75.0.3770.90)
      @安忆 噗,原来这个能有轮子
  5. Ge2  Windows 10 x64 Edition(Windows 10 x64 Edition) / Firefox 67.0(Firefox 67.0)
    备注一下:
    Cloudflare似乎不支持四级域名的ssl,所以说想要cloudflare+ssl的话,还是得用新域名
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.80(Google Chrome 75.0.3770.80)
      @Ge2 感谢提醒
      1. LYM  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 76.0.3809.132(Google Chrome 76.0.3809.132)
        @神代綺凜 现在可以了QAQ
        1. LYM  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 76.0.3809.132(Google Chrome 76.0.3809.132)
          @LYM 当我没说-_-||
  6. mikusa  Android 9(Android 9) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
    该评论仅登录用户及评论双方可见
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.157(Google Chrome 74.0.3729.157)
      @mikusa
      该评论仅登录用户及评论双方可见
  7. 小纯洁  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
    我非常赞同你的那句"总结起来就一个字:菜".
    (没错,我是来水的ヾ(≧∇≦*)ゝ)
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
      @小纯洁 2333333
  8. T.O.V  Windows 10 x64 Edition(Windows 10 x64 Edition) / Microsoft Edge 17.17134(Microsoft Edge 17.17134)
    大佬,Apache有没有配置Header Referer的模块或者方法啊 原来服务器用的就是apache不想改成nginx,然后尝试自己写反代配置,一直找不到apache反代设置Referer的方法
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
      @T.O.V 不清楚,我平时也只用 Nginx
      再不济你可以把 nginx 开在别的端口上然后用 Apache 反代 (/ω\)
      1. T.O.V  Google Chrome OS x64(Google Chrome OS x64) / Google Chrome 73.0.3683.114(Google Chrome 73.0.3683.114)
        @神代綺凜 感谢大佬的文章成功反代了,用nginx做前端apache做后端,把我其他部署在apache上面的站搞定了
        不过我发现p站里面还有一个pixivision是另外的一个域名pixivision.net,那个东西要一并反代是不是就要再开一个域名
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
          @T.O.V 可以仿照 pximg.net 的反代方式,直接拿 pixivision.example.com 作为主域名
          不过 pixivision 并没有被污染和阻断,可以直连没必要反代来着……
          1. T.O.V  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 70.0.3538.102(Google Chrome 70.0.3538.102)
            @神代綺凜 p站里面pixivision的链接带的参数是包含了反代站的域名 那个玩意有暴露风险吗
            1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
              @T.O.V 这样吗,嘛不过只是个人小范围使用的话他们都懒得管你吧
              我现在给反代站套了cf,设置cf防火墙阻止所有不是来自国内的访问,要查也查不了
      2. T.O.V  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
        @神代綺凜 好的好的谢谢大佬(/ω\)
  9. Effervescence  Android 8.1.0(Android 8.1.0) / Google Chrome 73.0.3683.75(Google Chrome 73.0.3683.75)
    大佬,为什么我搭建好后访问速度超级慢,就像没网一样呀?(。•ˇ‸ˇ•。)
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.108(Google Chrome 74.0.3729.108)
      @Effervescence 自己连自己的服务器慢可怨不了别的噢 ∠( ᐛ 」∠)_
      1. Effervescence  Android 8.1.0(Android 8.1.0) / Google Chrome 73.0.3683.75(Google Chrome 73.0.3683.75)
        @神代綺凜 可是我用的是香港的呀,是否和服务器的带宽有关系?
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.108(Google Chrome 74.0.3729.108)
          @Effervescence 自然是有的
          1. Eff  Android 8.1.0(Android 8.1.0) / Google Chrome 73.0.3683.90(Google Chrome 73.0.3683.90)
            @神代綺凜 我换了微软香港来反代,然后访问的时候总是在最后时刻加载的时间很长才会显示出主页,大佬有遇到过这种问题吗?
            1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
              @Eff 没有,不过你这个情况有可能是因为网络问题被谷歌统计卡了,你可以试试根据“屏蔽P站的所有谷歌服务”处理一下
              1. Eff  Android 8.1.0(Android 8.1.0) / Google Chrome 73.0.3683.90(Google Chrome 73.0.3683.90)
                @神代綺凜 试过了,感觉还是慢,我在捣鼓捣鼓。谢大佬的耐心回复啦。ヾ(≧∇≦*)ゝ
                1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 74.0.3729.131(Google Chrome 74.0.3729.131)
  10. simon3000  Mac OS X 10.14.4(Mac OS X 10.14.4) / Safari 12.1(Safari 12.1)
    Vultr我一开始也是发现Pixiv被ban IP
    结果重开了个Instance中奖了,一个没被ban的。。。
    很曲折的方法,但是不推荐用,搞不好会被vultr ban
    (不过我另一个vultr账号申请增加instance上线写的就是"It seems like my ISP banned some IP..." 我真是天才
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.86(Google Chrome 73.0.3683.86)
      @simon3000 老段的IP被ban是P站那边ban的,不是 Vultr 这边
      原因貌似是好几年前有人用 Vultr 机器超大量爬P站,然后直接被P站整段ban
      目前新段机器没被ban的不需要担心,只要你不将反代站公开出来被P站查到投诉就行
      1. simon3000  Mac OS X(Mac OS X) / Safari 12.0(Safari 12.0)
        @神代綺凜 哦对,我说的被vultr ban是指短时间内开一大堆instance试ip这种行为
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.86(Google Chrome 73.0.3683.86)
          @simon3000 那倒不那么容易ban,我每次刷IP也是这样开满删了
    2. simon3000Unknown
      @simon3000 我就是想试试用curl发评论会怎么样呢→_→(
      1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.86(Google Chrome 73.0.3683.86)
        @simon3000 草,没有UA,UA插件炸了
        1. simon3000  Mac OS X 10.14.4(Mac OS X 10.14.4) / Safari 12.1(Safari 12.1)
          @神代綺凜 哎,应该是“curl/7.64.0”来着
          UA插件居然不支持大名鼎鼎的curl(雾
          1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.86(Google Chrome 73.0.3683.86)
            @simon3000 |´・ω・)ノ把插件改了一下,未知的就直接全显示好了(
            1. simon3000  Mac OS X(Mac OS X) / Safari 12.0(Safari 12.0)
              @神代綺凜
              该评论仅登录用户及评论双方可见
              1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.86(Google Chrome 73.0.3683.86)
                @simon3000
                该评论仅登录用户及评论双方可见
                1. simon3000  Mac OS X 10.14.4(Mac OS X 10.14.4) / Safari 12.1(Safari 12.1)
                  @神代綺凜 23333看你一个小时没回复我刚刚去contact.html测试,成功了,想着上Steam找你这边就回复了
  11. Snylonue  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.75(Google Chrome 73.0.3683.75)
    请问这个可以放在GitHub pages上吗
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.86(Google Chrome 73.0.3683.86)
      @Snylonue 不可以
  12. Clarke  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
    请问反代用三级域名可以吗?比如pximg.pixiv.xxx.com这种的
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 73.0.3683.75(Google Chrome 73.0.3683.75)
      @Clarke 随意的,只要你理解了核心思想用什么域名都可以,配置根据实际情况写
  13. MikuSama  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 72.0.3626.121(Google Chrome 72.0.3626.121)
    说出来你可能不信,登录的时候现在要谷歌验证码,而我们在上面的操作中把www.google替换成(404)了然后验证码出不来,输入帐号密码登录之后就会卡住(帐号密码框框不见了,按钮不见了,只剩 三个第三方登录按钮),如果先不把谷歌域名替换掉,验证码模块会出现,但是因为域名不是pixiv.net,又会提示:"需要网站所有者处理的错误:网站密钥的网域无效"。
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 72.0.3626.121(Google Chrome 72.0.3626.121)
      @MikuSama 我试了下我的帐号没有弹验证码,这可能是跟帐号有关吧……
      1. MikuSama  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 72.0.3626.121(Google Chrome 72.0.3626.121)
        @神代綺凜 在清除cookies的情况下,是登录不了的,最好的方法就是找一台没访问过反代站的电脑,直接登录,会发现登录不了,但是在pixiv.net登录之后,反代站又可以登录了。
        1. MoeWang  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.142(Google Chrome 75.0.3770.142)
          @MikuSama 不知道有没有这个技术...可以把www.google.com/recaptcha换成www.recaptcha.net/recapcha,这样子国内也可以免咯血使用谷歌人机验证了~
          1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 75.0.3770.142(Google Chrome 75.0.3770.142)
            @MoeWang 可以尝试加一条

            sub_filter "www.google.com/recaptcha" "www.recaptcha.net/recaptcha";

            不知道直接替换这个 js 是否能起效,因为我这里也从来没有弹过验证码……

  14. wyttle  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
    按照设置配置了,一访问就跳转到P站自己的域名,怎么解决,server的 Referer都填了
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 72.0.3626.121(Google Chrome 72.0.3626.121)
      @wyttle 没遇见过这种情况
  15. 哈曼的YY  Windows 7 x64 Edition(Windows 7 x64 Edition) / Firefox 64.0(Firefox 64.0)
    请问动态图加载不了,应该怎么修改host呢?
  16. satania  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
    我也是卡在登录,感谢大佬提供解决方案
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
  17. Starlight  Android 7.0(Android 7.0) / IBrowse r(IBrowse r)
    为什么本地反代可以绕过sni审查,大佬可以概括的提点一下吗(┯_┯),不胜感激。
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.98(Google Chrome 71.0.3578.98)
      @Starlight 我提到的那篇文章里有讲
  18. 楼顶的猫  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 69.0.3493.3(Google Chrome 69.0.3493.3)
    楼主大佬啊,我自己没钱搭建,就用用现成的好了∠( ᐛ 」∠)_
  19. WeiYuan  GNU/Linux x64(GNU/Linux x64) / Google Chrome 70.0.3538.77(Google Chrome 70.0.3538.77)
    哈哈解出来了,这个域名都被你买到了Orz
    话说大佬那个代码框怎么搞的|´・ω・)ノ
    求教
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.80(Google Chrome 71.0.3578.80)
      @WeiYuan 机密,整体想法是妨 2heng.xin 的那个主题的,然后自己稍微做了调整 |´・ω・)ノ
      1. WeiYuan  GNU/Linux x64(GNU/Linux x64) / Google Chrome 70.0.3538.77(Google Chrome 70.0.3538.77)
        @神代綺凜 羡慕大佬们做的这么好看。我这几天CloudCone欠费了,迁移到Hostinger了。然后顺便从Typecho迁移成Hexo,折腾了好久。φ( ̄∇ ̄o)已经两天没出宿舍了(除了拿外卖),还有好多东西要学习。
        1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.80(Google Chrome 71.0.3578.80)
          @WeiYuan 突然发现是同款键盘(我是侧刻小黑
          1. WeiYuan  GNU/Linux x64(GNU/Linux x64) / Google Chrome 70.0.3538.77(Google Chrome 70.0.3538.77)
            @神代綺凜 不不不,我的是辣鸡国产雷柏。如果没有记错木有側刻这种款式。才200不到的键盘Orz。只是图打字舒服一点,国产轴和车厘子轴个人觉得差别不大。 说多了都是钱的问题。话说刚才不是没有图片的吗。Orz,我还以为你的MarkDown吞了图片。
            1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.80(Google Chrome 71.0.3578.80)
              @WeiYuan 也太像了
              因为你md打错格式了我帮你改了,图片是![](),链接是[]()
              1. WeiYuan  GNU/Linux x64(GNU/Linux x64) / Google Chrome 70.0.3538.77(Google Chrome 70.0.3538.77)
                @神代綺凜 哇,太丢人了 居然打错了。我好菜.jpg
        2. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 71.0.3578.80(Google Chrome 71.0.3578.80)
          @WeiYuan 最近也在忙着准备各种面试,忙成马
  20. fvsherlock  Windows 7 x64 Edition(Windows 7 x64 Edition) / Google Chrome 69.0.3497.92(Google Chrome 69.0.3497.92)
    让人不禁感叹这就是大佬啊
    1. 神代綺凜  Windows 10 x64 Edition(Windows 10 x64 Edition) / Google Chrome 70.0.3538.110(Google Chrome 70.0.3538.110)
      @fvsherlock no,是菜鸡,发明出本地反代的才是大佬