分类 未分类 下的文章

OK.这儿讲的是SS. 就是S.....Socks-libev
1. 服务器端
服务器端Ubuntu 16.10以上版本可以直接使用apt-get安装

sudo apt-get install sh....so...-libev

装好后, 配置/etc/sha...so...-libev/config.json, (恩,JSON is good). 如下:

{
    "server":"xxx.xxx.xxx.xxx",
    "server_port":8888,
    "password":"**********",
    "method":"aes-256-cfb"
}

Server就是服务器的IP, serverport自行修改成任意值都可以, password也请自行修改.

  1. 客户端
    客户端种类比较多,如:

2.1 windows端
windows的客户端还是挺好用,也简单. 不做介绍了, 自己去找-_-|||
配置项中,配的和服务器端一样就可以了.

2.2 openwrt端
这个麻烦些,先下载个对应版本
然后还要用opkg安装几个依赖

# 这两个依赖是一定要装的
opkg  install ip ipset
# 装ss
opkg install ./s.....s....文件名.ipk 

在OPENWRT CC版本中安装OK,可是在AA版本中会遇到问题


pkg_run_script: package "shadowsocks-libev-spec-polarssl" postinst script returned status 127. opkg_configure: shadowsocks-libev-spec-polarssl.postinst returned 127.

那是因为postinst会调用/lib/function.sh中的一个default_postinst()函数,而AA版本里面没有这个函数, 只好自己手动加了,在/lib/function.sh最后面加上:

default_postinst() {
    return 0
}

值得注意的是, ss客户端有ss-local/redir等等, 在spec版本中没有local,也就是sock5代理,这个要注意
运行下面的命令,会发现ss-local在运行就好

root@OPEN:/# ps | grep ss-local
18797 root      2652 S    /usr/bin/ss-local -c /etc/sh....socks.json -b 0.0.0.0
19474 root      1060 S    grep ss-local

当然,需要改一下 /etc/sh....socks.json, 修改为:

{
    "server":"xxx.xxx.xxx.xxx",
    "server_port":8888,
    "local_port":7654,
    "password":"***********",
    "method": "aes-256-cfb"
}

就是比服务器端多了一个local_port的定义. 当然这个是sock5的代理port了.
重启一下服务:

/etc/init.d/so....s.... restart

OK了!
如果你想实时监控一下log信息, 可以先停止服务,在命令行启动,并加上-v

/etc/init.d/so....s.... stop
cc-local /etc/s.....s.....json -b 0.0.0.0 -v

2.2.1 windows上通过openwrt sock5上网
通过代理服务器上网通常都需要软件支持. 以firefox为例,打开 "菜单 - 选项 - 高级 - 网络 - 设置(E)..." 看到对话框(藏得好深的对话框...)
再选择"手动配置代理 - sock主机",填写IP和端口, 选择 SOCKS v5, 以及"使用SOCKS V5代理 DNS", 然后"确定"
看一年y..t...的视频, 能播就说明OK咯.

然而通过系统代理却不行,主要是DNS在作怪. 因为系统的代理不会把DNS也代理过去.

虽然我习惯用mlocate,不过这个命令太高级不通用,有的linux上没装,有的linux上没有(openwrt)
所以还是用find吧

find / -name ps
find / -iname *ps

这个意思是在根目录/及其子目录下查找ps命令,额,大多数情况这样就够了
后面一条命令的意思是忽略大小写, 查找以ps结尾的文件名.

递增循环, 是start, end, step...好吧, 基本还是跟C一样,C是start, condition, cmd
枚举循环,有个ipairs/pairs是什么鬼?

for i = 0,10,1 do
  -- something cmd
end

a = {'a','b','c'}
o = {x=1,y=2}

for k,v in ipairs(a) do
  -- some code
end

for k,v in pairs(a) do
  --some code
end

原来是不同的迭代器:迭代文件每行的(io.lines),迭代table元素的(pairs),迭代数组元素的(ipairs),迭代字符串中单词的
(string.gmatch)等等
ipairs和pairs什么区别?ipairs从1开始遍历,每次递增1,也就是1/2/3/4...,遇到没有了就停止遍历。pairs遍历所有的key。

arduino在中断回调中执行的程序, 确实是无法使用delay的, delay似乎就失效了.
所以中断还是应该尽快返回, 在主程序逻辑中执行. 较长的逻辑可以通过设置标志位, 在主程序中进行检测并执行, 执行完后清除标志位即可.
如果是设置标志位的方式, 在主程序运行中, 新的中断当然会不断地重设标志位, 然而在主程序运行后将清除标志位 , 因此不会重复执行任务.
如果无论主程序是否在执行 ,每次中断任务都需要被完整执行的话, 则可以用计数器替代标志位, 中断时计数器+1, 执行一次再-1, 直到计数器为0时停止执行.

很多人说毛带兵成功治国失败,不理解他的三反五反十年浩劫。然而毛确实是一个共产主义者,理想主义者,甚至是完美主义者。他所做的确实是消灭阶级,消灭不公平,将整个国家高出中农以上的阶级全部铲平,在生前建立共产乌托邦。只是我们后来才注意到,乌托邦世界的问题。

人类发展技术,个体让后代学习技术,意图让他们过上更美好的生活,甚至走上“共同富裕”。然而,个体更美好其实只是个概率问题,好的技术并不能一定保证好的生活,也无法让你过得更轻松,也无法共同富裕,而总是一部分富裕了另一部分没有,而后代只能像赌博一样压宝,总盘子就这么大,看你们的运气。心理学说人人都会做出对他来说最好的选择,而他们只是选择了自己最好的押宝。
当技术不起作用了,人类说你还得努力,未成年努力还不够,还得终身努力。然后你就放弃了舒适的生活,去过“好的生活”,房车票子上流社会之类。大家都努力,总盘还这么大,你就只有更加辛苦才能获得跟以前差不多的生活。
最终,你努力学了技术,又努力工作,生活却还是不如意,感叹或咒骂人生究竟如此苦逼的时候, 人类给你三个选择:一,宗教,人生就是痛苦,这辈子幸福是不可能了, 不过下辈子可以, 只要你信教, 就能上天堂,得永生;二,你自己是不可能了, 但你的子女可以, 总得让自己子女过得好一些,轻松一些, 所以继续努力吧,希望在未来;三,人生得有理想,得改变世界什么的, 万一实现了呢, 所以继续努力吧。每个人需求不同, 有的要救自己, 有的要救后代, 有的要救世界, 总有一个满足你. 不过相对来说, 宗教这个没让你继续过度疲劳, 所以还是划算些, 这门生意从图腾时代开始也就兴旺了几万年不衰. 中国皇帝最大, 宗教最多当过老二, 于是只好寄托后代, 所以不孝有三无后为大, 所以传宗接代重男轻女, 因为只有男性能代表我实现幸福生活.
至于理想主义, 是一个适合文青的方式, 古代受教育的少, 文青也少, 所以一直是个配角, 现代纷纷读起了大学博士研究生, 才变得更加流行起来了. 现代文青受教育多了, 一是导致家族观念淡薄, 都想实现个自我价值; 二是广告和小时代看得多了, 要买要用的东西多, 生活压力大, 就不愿意多生孩子养家. 所以只有理想主义能拯救他们. 他们喜欢乔帮主的"卖个糖水还是拯救世界"的段子, 纷纷开始实现王健林的"1个亿小目标". 其实理想主义也是贯穿古代的文青圈, "穷则独善其身, 达则兼济天下". 只是比较起来, 古代人还是现实一些, 穷了还就只管自己了, 有钱了也只是"兼"济天下, 顺带地救一下世界. 现代文青就不一样, 我穷也要或者更要救天下,救不了天下也得在天底下扬名立万, 并时时以救天下的各种鸡汤段子鞭策自己, 鞠躬尽瘁死而后已.
最后谁赢了?只是那物竞天择的自私基因。

仿真一般都用Proteus, 原理图到PCB都能搞定;
MCU这么几个系列:
C51, 开发环境Keil for C51. 著名开发公司Atmel, 还有国内的STC.
MSP430, TI公司的, 主流两个, 一个是TI自己的CCS编译环境, 另一个是IAR Embedded Workbench for MSP430
AVR, Atmel的芯片, 自家的编译环境有Atmel Studio/toolchain, v5版本以前叫做AVR studio.
ARM, 一般是Keil For MDK. STM32也是基于ARM的Cortex M3的.
STM8, 一般是IVR for STM8, ST公司自家的STVD也可以
PIC, Microchip公司,用 MPLAB X IDE

如果用Vue属性做v-for的话, 注意它不能检测对象属性的直接增删, 而是要用Vue.set来增删对象属性.
另外, 在v-for场景下, 数组可以很方便的只显示部分或者做过滤/排序等, 对象就不行了. 所以使用v-for尽量将数据类型设计为数组.

vue-router默认是需要将项目放在服务器的根目录下的, 在浏览器里输入域名是这样:

http://mydomain.com/

vue怎么确认去服务器取数据还是在本地取数据呢? 其实借助的是井号"#", 井号在url中指向的是自己, 而不会去服务器取数据. 如下url, 是在根目录下的vue应用中, 也就是在vue-router中被导航.

http://mydomain.com/#/login

而如下url,将会到服务器上去取数据

http://mydomain.com/login

但如果要放置在子目录下呢, vue应用放在productinfo目录中:

http://mydomain.com/productinfo/#/login

需要两步:
1. 需要配置 router的config:

const RouterConfig = {
    base: 'productinfo'
};
const router = new VueRouter(RouterConfig);
  1. vue-router一般都是用vue-cli或者webpack, 做多个文件打包的, 也就是运行:

    npm run build

可以打包app. 当然, package.json中需要有对应的build配置, 如下:

  "scripts": {
    "build": "webpack --progress --hide-modules --config webpack.prod.config.js",
  },

那么在webpack.prod.config.js中, 也需要配置路径, 否则默认应用的打包文件就会出错.
以前是

    output: {
        publicPath: '/dist/',
    },

现在改为:

    output: {
        publicPath: '/productinfo/dist/',
    },

重新打包npm run build就好了.

附webpack.prod.config.js完整文件:

const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const merge = require('webpack-merge');
const webpackBaseConfig = require('./webpack.base.config.js');
const fs = require('fs');

fs.open('./src/config/env.js', 'w', function(err, fd) {
    const buf = 'export default "production";';
    fs.write(fd, buf, 0, buf.length, 0, function(err, written, buffer) {});
});

module.exports = merge(webpackBaseConfig, {
    output: {
        publicPath: '/productinfo/dist/',
        filename: '[name].[hash].js',
        chunkFilename: '[name].[hash].chunk.js'
    },
    plugins: [
        new ExtractTextPlugin({
            filename: '[name].[hash].css',
            allChunks: true
        }),
        new webpack.optimize.CommonsChunkPlugin({
            name: 'vendors',
            filename: 'vendors.[hash].js'
        }),
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: '"production"'
            }
        }),
        new webpack.optimize.UglifyJsPlugin({
            compress: {
                warnings: false
            }
        }),
        new HtmlWebpackPlugin({
            filename: '../index_prod.html',
            template: './src/template/index.ejs',
            inject: false
        })
    ]
});

超微型接口, 一般是IPX/IPEX/IPAX/AMC/UMCC/MHF/Hirose H.FL... 哦, 真搞不清楚这么个接口居然有如此之多的名字... 这是日本公司Hirose的专利接口, 不过用的实在是太多了...
尺寸上似乎有多种类型. 淘宝常见的似乎是331.5MM的. 阻抗50Ω.传输频率 0~6GHz.

普通结构, 一般是SMA, 是SubMiniature version A的简称, 传输频率 0~18GHz, 阻抗50Ω.直径约6mm.

SMA容易和F头(F connector)混淆. F头阻抗75Ω,直径9.5mm. 典型传输频率0~0.75GHz. 不过到2.2GHz似乎也没有问题.

Q9/BNC接口也常用于接天线.

TNC(Threaded Neill–Concelman)接头, 是BNC接头的螺纹版. 50Ω/0~11GHz. 微波段比BNC表现好. 公口1.5厘米,母口1厘米.

N接头(N Connector), 0~11GHz,有50Ω和75Ω版本. 公口直径有2.03厘米, 母口直径有1.57厘米, 是比较大的接口.

其他:
1. J一般表示公头, K表示母头.
2. SMA和TNC都有RP版. RP是Reverse Polarity的简称,即"反极性".
* 正常版内螺纹端(公头)有针, 外螺纹端(母头)无针.
* RP版的内螺纹端无针, 外螺纹端有针.

pug与stylus虽然看起来写起来都很简洁,然而由于像sublime text这样的编辑器已经对html自动补全支持得很好了, pug和stylus在还没有自动补全的时候, 书写效率未必比原生html和css更快

pug示例:

div.className1.className2(style='font-size:37px') test ok!

stylus示例

.className1
    color: green
.className2
    background-color: red

1、npm install xxx-loader --save-dev,如:以前叫jade现在叫pug的:

npm install pug-html-loader

2、在webpack.base.config.js中加入配置:

module:{
  rules: [{
              test: /\.pug/,
              loader: ['raw-loader', 'pug-html-loader']
  }]
}

3、使用。如在vue的模板中: