热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

markdown[软件代理设置]

本文由编程笔记#小编为大家整理,主要介绍了markdown[软件代理设置]相关的知识,希望对你有一定的参考价值。
本文由编程笔记#小编为大家整理,主要介绍了markdown [软件代理设置]相关的知识,希望对你有一定的参考价值。




> 本文由 [简悦 SimpRead](http://ksria.com/simpread/) 转码, 原文地址 https://www.jianshu.com/p/ff4093ed893f
>
> 本文基于https://www.jianshu.com/p/ff4093ed893f 上进行修改
# 软件 Proxy 设置
Proxy 一般有2种协议,一种是 HTTP/HTTPS 协议,一种是 SOCKS 协议。**优先使用 SOCKS 协议的 SOCKS5 版本**。[2种协议的区别 待补充外部引用]
各平台的 Shadowsocks 客户端除了提供一个本地的 socks5 Proxy ,还会提供一个本地的 http Proxy 。
在 ShadowSocks 中的高级设置中查看 socks5 协议监听的端口,HTTP Proxy 设置中查看 http 协议监听的端口。
## Chrome 浏览器 Proxy 设置
* 使用 [`Proxy SwitchyOmega`](https://chrome.google.com/webstore/detail/proxy-switchyomega/padekgcemlokbadohgkifijomclgjgif?hl=zh-CN) 这个插件来管理 proxy。
* 在 chrome 使用 proxy 管理插件的时候注意为每个情景填写正确的协议名和端口。
## Sublime Text 3 PackageControl Proxy 设置(仅支持http协议)
* 打开 “Preferences -> Package Settings -> Package Control-> Settings – User”
* 在 JSON 文件中插入
```json
"http_proxy": "http://127.0.0.1:7070",
"https_proxy": "http://127.0.0.1:7070",
```
> 注意:Sublime Text 3现仅支持http协议, 所以要注意socks5和http端口号的区别
## git Proxy 设置
`git` 目前支持的三种协议`http://`和`https://`,`ssh://`,`git://`
* 对于 HTTP/HTTPS 协议(`http://`和`https://`)设置 Proxy
远程仓库链接格式类似:
```
http://github.com/cms-sw/cmssw.git
https://github.com/cms-sw/cmssw.git
```
实际调用 `libcurl` 与服务器通信,详见[curl(1)](http://curl.haxx.se/docs/manpage.html)的`--proxy`选项以及[git-config(1)](https://www.kernel.org/pub/software/scm/git/docs/git-config.html)中的`http.proxy`条目。
* 直接使用[**终端的 Proxy 设置**](#终端-proxy-设置)
* 命令行设置与取消
```sh
# 设置全域有效
git config --global http.proxy 'socks5://127.0.0.1:1080'
git config --global https.proxy 'socks5://127.0.0.1:1080'
# 取消代理
git config --global --unset http.proxy
git config --global --unset https.proxy
####
# 仅对github.com有效
git config --global http.https://github.com.proxy socks5://127.0.0.1:1080
# 取消代理
git config --global --unset http.https://github.com.proxy
```
> `--global` 全局
* 直接修改`~/.gitconfig`文件(全局)或项目文件夹中的`.gitconfig`,添加或删除
```
[http]
proxy = socks5://127.0.0.1:1080
[https]
proxy = socks5://127.0.0.1:1080
# 仅对github.com有效
[http "https://github.com"]
proxy = socks5://127.0.0.1:1080
```
* 对于 SSH 协议(`ssh://`)设置 Proxy
远程仓库链接格式类似:
```
git@github.com:cms-sw/cmssw.git
ssh://git@github.com/cms-sw/cmssw.git
```
实际调用 `ssh` 命令与服务器通信,需要配置 ssh 的 ProxyCommand 参数。
* 修改`~/.ssh/config` 文件添加
```
Host github.com
HostName github.com
############
# 如果使用git@ssh.github.com进行传输,HostName和Port设置如下,
# 详见 https://help.github.com/articles/using-ssh-over-the-https-port/
# HostName ssh.github.com
# Port 443
############
User git
# HTTP Proxy:
# ProxyCommand connect -H 127.0.0.1:7070 %h %p
# SOCKS5 Proxy:
# ProxyCommand connect -S 127.0.0.1:1080 %h %p
```
> 实际 `ProxyCommand` 需要调试过才能确定。
> 该 ssh 设置仅对 User为: `git` 的程序访问 HostName为: `github.com` 域名有效.
* 对于 git 协议(`git://`)设置 Proxy
远程仓库链接格式类似:
```
git://github.com/cms-sw/cmssw.git
```
git 协议比较特殊,需要由 `core.gitproxy` 设置一个额外的 proxy 脚本,才能使用上 socks 代理。
* 编写 git-proxy 脚本,例如:
```sh
#!/bin/sh
## Proxy wrapper for git protocol (9418).
## git config --global core.gitproxy "proxy-command"
## 仅对example.com域名有效
## git config --global core.gitproxy '"proxy-command" for example.com'
exec connect -S 127.0.0.1:1080 "$@"
```
* 设置`core.gitproxy`
命令行
```
# 设置
git config --global core.gitproxy "git-proxy"
# 仅对example.com域名有效
git config --global core.gitproxy '"git-proxy" for example.com'
# 取消
git config --global --unset core.gitproxy
```
设置文件
```
[core]
gitproxy = /path/to/git-proxy
[core]
gitproxy = "/path/to/git-proxy" for "example.com"
```
或者
```
export GIT_PROXY_COMMAND="/path/to/git-proxy"
```
> 实际 `git-proxy` 脚本需要调试后确定。
* `connect`工具
[项目页](https://bitbucket.org/gotoh/connect/wiki/Home)
* Mac 下安装
```sh
brew install connect
```
> git 三种协议的 Proxy 设置互不影响,互不冲突。
> 具体看 `man git-config`
* 参考:
1. [如何为 Git 设置代理?](https://segmentfault.com/q/1010000000118837)
1. [设置 Git Proxy ](https://imciel.com/2016/06/28/git-proxy/)
1. [Tutorial: how to use git through a proxy](http://cms-sw.github.io/tutorial-proxy.html)
## 终端 Proxy 设置
* 原理:export http_proxy、https_proxy 或 ALL_PROXY,那么wget curl 这类网络命令依据该设置进行 Proxy。
```
# 开启 Proxy
export http_proxy=socks5://127.0.0.1:1080
export https_proxy=socks5://127.0.0.1:1080
# 或者直接设置ALL_PROXY
export ALL_PROXY=socks5://127.0.0.1:1080
# 关闭 Proxy
unset http_proxy
unset https_proxy
unset ALL_PROXY
```
> 可以在终端运行,也可以写入shell配置文件`.bashrc`或者`.zshrc`。也可以设置函数或者别名,便于开/关 Proxy。
> 注意, 修改完`.bashrc`或者`.zshrc` 后重启终端或 `source` 生效。
> 可以通过`curl -i http://ip.cn`查看 IP 改变来测试是否生效
* 通过设置 alias 简写来简化操作
```
alias setproxy="export ALL_PROXY=socks5://127.0.0.1:1080"
alias unsetproxy="unset ALL_PROXY"
aliaa ip="curl -i http://ip.cn"
```
* 参考:
1. [设置socks5代理](https://www.jianshu.com/p/ff4093ed893f)
1. [设置 Git 代理](https://imciel.com/2016/06/28/git-proxy/)
1. [macOS 终端走Proxy ](http://gold.xitu.io/entry/5821840cd203090055134cc0)


推荐阅读
  • 在开发过程中遇到前端页面显示 404 Not Found 错误时,通常意味着请求的资源无法被服务器找到。本文将探讨这一错误的具体原因及解决方法。 ... [详细]
  • 本文介绍了如何在VB.NET版机房收费系统中实现数据从DataGridView导出至Excel的功能,包括环境配置、代码实现及常见问题解决方法。 ... [详细]
  • 每位开发者都应该拥有一个展示自我技能与分享知识的空间——个人技术博客。本文将指导你如何使用静态网站生成器Hexo结合GitHub Pages搭建这样一个平台。 ... [详细]
  • 本文探讨了如何利用自定义URI方案和注册表编辑,在Windows操作系统中实现从Web浏览器启动本地应用程序的方法,同时强调了这一过程中的安全考虑。 ... [详细]
  • 7000字文章一键排版技巧与实践
    本文探讨了一种高效的文章排版方法,特别适合文字密集型内容,如原创公众号文章。作者通过个人经历,分享了从学习Markdown到利用mdnice实现一键排版的过程,旨在帮助更多内容创作者提升工作效率。 ... [详细]
  • 教程:如何打造令人印象深刻的GitHub个人主页Readme
    本文将指导您如何创建一个既专业又个性化的GitHub个人主页Readme,通过添加统计数据、常用语言和最近活动等元素,让您的主页更加吸引人。 ... [详细]
  • 本文介绍了两个重要的Node.js库——cache-content-type和mime-types,它们在处理HTTP响应头时非常有用。cache-content-type是基于mime-types构建的,并且实现了缓存机制以提高性能。 ... [详细]
  • 本文提供了一个详尽的前端开发资源列表,涵盖了从基础入门到高级应用的各个方面,包括HTML5、CSS3、JavaScript框架及库、移动开发、API接口、工具与插件等。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • Python自动化测试入门:Selenium环境搭建
    本文详细介绍如何在Python环境中安装和配置Selenium,包括开发工具PyCharm的安装、Python环境的设置以及Selenium包的安装方法。此外,还提供了编写和运行第一个自动化测试脚本的步骤。 ... [详细]
  • 一个登陆界面
    预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
  • 本文介绍了如何利用Selenium和Python通过执行JavaScript代码来控制网页中的滚动条,包括垂直和水平滚动条的控制,以及特定元素的聚焦技术。 ... [详细]
  • 将基于Web的互动多媒体体验引入手机和平板电脑历来面临诸多挑战,如性能瓶颈、API兼容性和HTML5音频及视频播放限制等问题。本文探讨了如何克服这些障碍,为《霍比特人:史矛革之战》打造了一个移动优先的沉浸式网络体验。 ... [详细]
author-avatar
编舞木煜率_841
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有