树莓派通过Shadowsocks科学上网方法

本文所有操作的前提是,你在非大陆地区拥有vps服务器并配置好了shadowsocks服务器,或拥有某个shadowsocks服务的账号密码
如何搭建shadowsocks服务器不在本文讨论范围

一、更改软件安装源(非必须)
此操作主要为了下载软件包更快,这里使用阿里云提供的源

$ sudo vi /etc/apt/source.list

在行前添加#注释掉默认的源
在最后添加两行:
deb http://mirrors.aliyun.com/raspbian/raspbian/ stretch main non-free contrib rpi
deb-src http://mirrors.aliyun.com/raspbian/raspbian/ stretch main non-free contrib rpi
注意上面的stretch对应系统的版本,可以直接在该文件默认源中看到,也可以通过lsb_release -a查看
保存并推出vi

二、安装shadowsocks
方法1:

$ sudo apt-get install shadowsocks

方法2:

$ sudo pip install shadowsocks

两种方法安装的版本可能不同,可选择版本较高的一个来安装
建议在stretch版本上通过apt-get安装,在jessie版本上通过pip安装

三、配置参数

$ sudo vi /etc/shadowsocks/config.json
{
    "server": "代理服务器的IP,如1.2.3.4",
    "server_port": "代理服务器的端口,如8388",
    "local_address": "127.0.0.1", // 本地IP
    "local_port": "1080", // 本地端口
    "password": "密码",
    "timeout": 300,
    "method": "aes-256-cfb", // 加密方式,根据服务器的配置填写
    "fast_open": false,
    "workers": 1
}

注意,如果vi在编辑模式下使用方向键不能移动光标,而是显示成字母,则需要对vi编辑器进行一下配置

$ sudo vi /etc/vim/vimrc.tiny

set compatible改为set nocompatible

退格键无法使用则在上面的文件中添加set backspace=2
保存退出之后,再进入vi编辑器就可以正常使用

四、启动shadowsocks
apt-get方式安装启动方法:

$ sudo /usr/bin/sslocal -c /etc/shadowsocks/config.json -d start

pip方式安装启动方法

$ sudo /usr/local/bin/sslocal -c /etc/shadowsocks/config.json -d start

如果提示-d参数无效的问题,说明shadowsocks版本比较低,尝试通过第二节中的另一种方式安装

五、设置开机启动
sudo权限编辑/etc/rc.local
在最后exit 0的上一行添加sudo /usr/bin/sslocal -c /etc/shadowsocks/config.json -d start
注意不同方式安装的文件位置不同,请将/usr/bin/sslocal用实际的位置替换,可以用which sslocal来查看文件位置

六、使用
1.https://www.switchyomega.com/download.html 下载chrome插件
2.安装插件:需要打开Chromium进入chrome://extensions页面,然后将下载的crx文件拖动到页面中间安装
3.安装成功后会打开插件设置页面,点击左侧导航情景模式的autoswitch,删除原有默认的规则
4.点击导入在线规则列表下添加规则列表按钮
5.列表格式为AutoProxy,规则列表网址https://raw.githubusercontent.com/gfwlist/gfwlist/master/gfwlist.txt
6.点击立即更新情景模式
7.更新成功后在上面的切换规则中默认情景模式和默认规则列表选择proxy,然后点击左侧导航中的应用选项按钮
8.点击左侧导航情景模式下的proxy,代理协议选择socks5、代理服务器为127.0.0.1、端口为1080
9.点击左侧应用选项
10.访问https://www.facebook.com确定是否正常

Javascript类型转换-ToString

基本转换规则:
1. Undefined -> “undefined”
2. Null -> “null”
3. Boolean -> ture(“true”), false(“false”)
4. String -> 返回原值
5. Symbol -> 抛出TypeError异常
6. Object -> 先通过toPrimitive(argument, hint String)转为原始值,然后对原始值再进行ToString转换

Number转String规则:
假设待转换的Number类型变量为m,则有如下转换步骤:
1.若m是NaN,返回“NaN”

2.若m是+0或-0,返回“0”

3.若m<0,返回字符串“-”和ToString(-m)的值

4.若m是+∞,返回“Infinity”

5.若上面4条都不符合,则执行下述算法:

5.1 设三个整数变量n、k、s,令k>=1,10^(k-1)<=s<10^k,s*10^(n-k)的值为m,且k的值尽量小,其中s不可被10整除
举个例子,若待转换的m为12345,则根据规则s=12345、k=5、n=5;m=123.45时,s=12345、k=5、n=3;m=1230时,s=123、k=3、n=4

5.2 若k<=n<=21(m此时是位数不大于21位的整数),则返回s的十进制表示形式的k个数字的字符串(无前导0),然后是n-k个“0”

5.3 若0<n<=21(由于5.2中的条件符合就已经返回结果,所以,此时可知n<k),返回s的十进制表示形式的前n位的字符串,加上“.”,然后跟着s十进制表示形式的其余k-n位数字的字符串

5.4 若-6<n<=0,返回“0.”跟着-n个“0”,然后是十进制s的k位字符串 举个例子,若m=0.002,则s=2、k=1、n=-2;结果为”0.”+2(-n)个”0″+s的1(k)位=”0.002″

6.若上面5条仍然不符合,则执行下面的步骤:

6.1 如果k=1,返回s的第一位的字符串,跟着字母“e”,然后是“+”或“-”(根据n-1的正负性决定),后面是abs(n-1)的字符串形式 举个例子,若m=0.0000001,则s=1,k=1,n=-6; 可知,1~4规则不符合,规则5.2由于k>n不符合;规则5.3由于n<0不符合;5.4由于n=-6范围不在(-6,0]之间;
此例中,k=1,所以转为字符串为”1″(s)+”e”+”-“(n-1=-7是负号)+”7″(n-1的绝对值)

7.最后,上述条件都不符合,返回由s的十进制表示形式的最高有效位数的字符串,后跟”.”,接着是s的十进制表示形式的其余k-1个数字的字符串形式,随后是”e”,随后是”+”或”-“,判断方法同6.1,最后是abs(n-1)的字符串形式

注意事项:
由于浮点数精度问题,可能由于精度的丢失导致数字类型的位数改变,最终转换的结果与预期不符
整数超过21位会变成科学计数法的方式表示,小数小于0.000001会使用科学计数法,负数会先返回“-”然后再将其余的部分转成字符串(见第3条规则),所以5~7中都是针对正数