|  |      1xfewpi      185 天前 | 
|  |      2w88975      185 天前 https 自签 转 http, 用 nginx 反代一个 http 协议的就行 你手机上访问你的自签域名, 本质还是走的 https 协议, 你加个代理, 无非就是 MIT 绕过证书校验, 还是得走 https 啊 没懂你的场景是什么 | 
|  |      3009694      185 天前 via iPhone 你反代的网站访问不了是因为浏览器不认你的证书。 根 http socks 代理无任何关系。 你不解决证书信任或者把 https 反代成 http  套几层 socks 都没用 | 
|      5ztjal OP @w88975  最理想的:我手机→nginx 反代→目标网站,解决。 因手机实在没办法装自签 CA 证书(反正网上找得到的办法我都试过了)。 但现在:我手机→ http/socks 代理转 http 协议→nginx 反代→目标网站。 | 
|  |      7derdct      185 天前 via Android 手机为什么不能装,我现在就装的是啊?( 可能你指的是 android 后面版本部分应用不信任用户态的 CA ,只信任 System CA? | 
|  |      8383394544      185 天前 via iPhone 为什么不换个思路,在内网用公网域名+公网证书? | 
|      9yinmin      185 天前 via iPhone stunnel 可以将 https 转成 http | 
|      10yuchenr      185 天前 用 clash 就好了啊 | 
|  |      11sks4728      185 天前  2 不理解 , 反代了 http 加不加 s 不是 nginx 配置的事情吗 | 
|  |      12lifei6671      185 天前 | 
|      13BenjaminSu      185 天前 v2ray 的 routing 功能,可以进行各种协议的桥接。 | 
|  |      14opengps      185 天前 https 是短链接,socks 是长连接,这个结构导致了你要的长连接转为短链接 ,已经不可能实现 | 
|  |      150x5c0f      185 天前 proxychain  或者  tun2socks ? | 
|  |      16BreadKiller      185 天前 我也不太懂  手机->nginx 如果只是内网访问,不配置证书不就完事了?现在配了自签证书又想转 http 不就多此一举了? | 
|      17Judoon      185 天前 @BreadKiller 我觉得有一种可能是此 nginx 不是他能控制的。否则就和你说的一样,多此一举。 另外 @楼主,如果如我上面猜测的话,你再起一个你的 nginx 监听 http 端口, proxy_pass https://<old_nginx> 然后 ignore 证书就行了。 如果这都不满足,我觉得是你没有把原始需求说明白,又或者是个 YX 问题 | 
|      18busier      185 天前 via iPhone 你需要的是 socat | 
|  |      19rkonfj      185 天前 via iPhone 可以的,但是需要自定义代理服务器。似乎没有现成的正向代理服务器支持这种。 | 
|      20busier      185 天前 via iPhone socat TCP4-LISTEN:<本地端口>,reuseaddr,fork PROXY:<代理服务器 IP>:<远程地址>:<远程端口>,proxyport=<代理服务器端口>  适用于 http proxy 这样访问<本地端口>,效果就是穿过 http 代理的<远程端口> | 
|  |      21rkonfj      185 天前 @rkonfj #19 这是一个用 Go 实现的简单代 http 理服务器,把所有 http 请求都代理到 backend (可以设置你自签 CA 的  https 服务器) ``` package main import ( "crypto/tls" "crypto/x509" "flag" "net/http" "net/http/httputil" "net/url" "os" ) var ( backend string caPath string ) func main() { flag.StringVar(&backend, "backend", "", "server URL") flag.StringVar(&caPath, "ca", "", "ca certificate path") flag.Parse() backendURL, _ := url.Parse(backend) caCertPool, _ := x509.SystemCertPool() if caPath != "" { caCert, err := os.ReadFile(caPath) if err != nil { panic(err) } if ok := caCertPool.AppendCertsFromPEM(caCert); !ok { panic("append CA failed") } } rp := httputil.NewSingleHostReverseProxy(backendURL) rp.Transport = &http.Transport{ TLSClientConfig: &tls.Config{ RootCAs: caCertPool, ServerName: backendURL.Hostname(), }, } http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { r.Header.Del("Proxy-Connection") r.Host = backendURL.Host rp.ServeHTTP(w, r) }) http.ListenAndServe(":3080", nil) } ``` | 
|      22chaodada      185 天前 gost | 
|      24ztjal OP 这个问题搞来搞去就回到像 3 楼说的证书问题,这关过不了。 我自签 CA ,再用 CA 签域名。 在 WIN 和 DEBIAN 上装自签 CA 都没问题。就安卓不行。 一台安卓 10 MIUI11 ,有 ROOT ,用面具刷证书模块,但没见到系统证书里出现。 一台安卓 13 MIUI14 ,没 ROOT ,装自签 CA 生成的 pfx ,揭示“无法将此文件用作 CA 证书”。 自签 CA 分别用 openssl 和 xca 生成,都试过,结果一样。 | 
|      26psllll      185 天前 如果是在局域网下,可以用 hosts 功能,先拿到 ssl 证书,hosts 让域名指向 nginx 服务器上,填 ssl 证书路径,这样你用域名访问就有 https 了,而且默认信任域名证书不需要自签 | 
|      27samIIsun      185 天前 @ztjal 看到你提到的证书格式 pfx ,是否由于安卓对证书格式的要求导致的导入失败。 “在 Android 设备安装 CA 的步骤: 1. 保证根 CA 是 PEM 或 DER 的文件格式,并且扩展名为 .crt 。如果需要,进行转换。” 引用自: https://support.hcl-software.com/csm?id=kb_article&sysparm_article=KB0098688 | 
|  |      28yougg      185 天前 不是自己购买的域名吗?, 是的话 LetsEncrypt 签证书很容易吧. | 
|  |      34mohumohu      184 天前 这不就用 sniproxy 就好了,搞这么复杂 | 
|      36szdosar      184 天前 简单讲,你希望外网访问内网 web 服务?假设你的服务器是 linux 且按照了 cloudflared ,web 服务端口是 8080 ''' sudo cloudflared tunnel --url http://localhost:8080 --edge-ip-version auto --no-autoupdate --protocol http2 > ~/argo.log 2>&1 & ps aux | grep cloudflared | grep tunnel | grep 8080 cat ~/argo.log 2>/dev/null | grep -a trycloudflare.com | awk 'NR==2{print}' | awk -F// '{print $2}' | awk '{print $1}' ''' | 
|      37yc8332      184 天前 nginx 那边不要 https 不就好了。 |