most posts in

pull/1/merge
iotcat 4 years ago
parent 09d1124188
commit 020aee6f2b
  1. 1
      _config.yml
  2. 172
      source/_posts/2018-retrospect-and-prospect.md
  3. 41
      source/_posts/arduino-operator-string-issue.md
  4. 32
      source/_posts/awesome-beef-noodle.md
  5. 71
      source/_posts/build-236-iot-platform-on-wifiduino.md
  6. 124
      source/_posts/build-nextcloud-server-on-centos7.md
  7. 103
      source/_posts/coro.md
  8. 207
      source/_posts/cpp-summary.md
  9. 49
      source/_posts/crown-place-erp.md
  10. 81
      source/_posts/economy-environment-sustainability.md
  11. 62
      source/_posts/fog-architecture-and-internet-of-things.md
  12. 111
      source/_posts/global-climate-change.md
  13. 12
      source/_posts/happy.md
  14. 16
      source/_posts/hello-hexo.md
  15. 40
      source/_posts/hello-world.md
  16. 98
      source/_posts/ivisa-checklist.md
  17. 85
      source/_posts/kms.md
  18. 107
      source/_posts/liverpool-accom-inves.md
  19. 36
      source/_posts/mail-api.md
  20. 122
      source/_posts/my-code-style.md
  21. 234
      source/_posts/rand-pic-api.md
  22. 63
      source/_posts/smart-home.md
  23. 341
      source/_posts/smartfarming-surf.md
  24. 108
      source/_posts/ssl-auto-apply.md
  25. 27
      source/_posts/trade-war.md
  26. 43
      source/_posts/traveler-cheque.md
  27. 45
      source/_posts/two-fundamental-demands-of-human-beings.md
  28. 446
      source/_posts/wiot.md
  29. 6
      source/archives/index.md
  30. 6
      source/categories/index.md
  31. 18
      source/links/index.md
  32. 6
      source/tags/index.md
  33. 2
      themes/kayo

@ -83,6 +83,7 @@ use_date_for_updated: false
## Set per_page to 0 to disable pagination
per_page: 10
pagination_dir: page
archive: 1
# Include / Exclude file(s)
## include:/exclude: options only apply to the 'source/' folder

@ -0,0 +1,172 @@
---
title: 2018 – Retrospect and Prospect
date: 2020-06-16 15:43:54
categories:
- thoughts
tags:
---
白驹过隙,挥别2018,走向2019..
作为完全独立生活的第一年,失去约束,放飞自我,狠狠地狂野了一把。然后,竟然还意外地做成了不少事情..
<!--more-->
## 代码方面:
- 最大的收获是发现并加入了Github
- 掌握了不少新语言,嗯数一数有C, C++, PHP, JavaScript, vbs, HTML, CSS, Python, shell, dos, Matlab (大致是按照熟练顺序吧)
- 经营着7台服务器,一台win2012在上海(第一台),三台cent在悉尼,亚特兰大和伦敦,国内两台Cent 在深圳和北京,再加上宿舍里的ubuntu树莓派,哈哈哈,,,
### 上半年
- 上半年帮爸爸搞万宗商业,通过ftp连上海服务器,勉强搞了个公司网站出来,可惜暑假被‘拉脱维亚’(至少IP是)的黑客朋友搞掉了,从此弃坑windows
- 5,6月份尝试搞过一个Steel15高中同学平台,但因为企划模式不切实际等原因,进度一直搁置,最终也在8月份一起被黑掉了(从此养成勤备份好习惯( •̀ ω •́ )y)
- 7月在欧朗研发部时和组员一起做了一个基于微信小程序的学生电子ID卡,我在其中算是担任后端工程师吧,并且最后还在学校和企业大佬面前做了项目答辩哦
- 暑假在家中用wifiduino搞了两个项目,太阳能自动加水和走廊灯的自感应化,设计和采购材料时接触了一些水管和电线的知识。据说目前板子仍然运行良好哦
### 9,10月份
- 9月份的话,开始进军Linux, 通过Vultr搞了不少服务器做尝试,搭建了私人的ss服务器,自此科学上网
- 9月份,基于开源的NextCloud在伦敦docker搭建了第一个私人网盘,一直使用至今,只是国内访问速度,,( ̄▽ ̄)”,,希望去英国后能好一点
- 9月份,重建了宿舍的IoT系统,目前虽然出过几次bug但总体而言运行良好
- 10月份,不爽于诸多被禁番剧,着手搭建第一代Yimian Video视频平台
- 10月份,多次尝试搞Linux Mail服务,均失败,至今沿用5月份的Windows Mail
- 10,11月份,C语言as搞了一个数据联网同步,有背景音乐的石头剪刀小游戏
- 10月份,开发了一个短信验证码login系统
- 10月,基于shell以及一系列Linux软件结合Nginx搞了一个ss服务器的端口流量管理和统计系统,然后对同学朋友开放帮助他们科学上网(不过北京朋友反应上不了,大概是北京的墙比较高吧,望今年通过增添混淆解决)
### 11,12月份
- 11月,跟着北大一个网课,尝试搞Python TensorFlow的图像识别,然后成功半途而废掉了。。不过终于对AI有了实践性的了解,理解到目前的神经网络本质是用一坨多项式去fit一个复杂的自然函数
- 11月,入手了人生第一台树莓派,搭配上红外摄像头,目前呢,可以提供流媒体视频直播服务,,
- 12月,尝试开发一个上课自动签到的微信小程序,结果被ICE强大的限制算法降伏,,失败
- 12月,基于Wordpress搭建了一个加载慢慢的Blog平台,
- 12月,偶然发现了frp,成功实现服务内网穿透,并将其应用到树莓派以及我的PC上
- 12月,和C语言小组5人一起搞了一个酒店管理系统,然后我最大的contribution是从零搭建了一个底层数据库系统,处理速度,额,炒鸡慢,尽管已经引入了哈希算法..
- 12月底,入了Github的坑,接触到了DIYgod大神
- 12月底,基于Dplayer,改良Yimian Video至第三代,支持hls,搭建了弹幕服务器,增添了弹幕功能,通过第三方API连接B站弹幕
- 12月底,基于Aplayer,开发出基于php控制的网页音乐播放插件,可直接播放网易云指定歌单
- 12月底,改良以往login页面,增添原创的防robot算法,提升为全动态页面
- 12月底,接触pjax,YimianVideo, 视频列表试点应用,并开始着手全站动态化改造
- 12月底,入手咕咕机,利用其API每晚自动打印今日站点访问统计
## 学习方面:
- 英语方面EAP课程结业,雅思互换的话大概6.5分吧,毕竟也全英授课一年半了
- 文科方面历史法律学的很开心,考得嘛,,不置评论
- 年初恶补了基础心理学,社会心理学,发展心理学,变态心理学,心理咨询学,心理测量学,本打算参加心理咨询师考试的,结果最终因为年龄不到要求挺遗憾的,但是学到了这么多喜欢的东西蛮开心的
- 电路嘛,起码能做基础的直流交流分析了
- 11月日常物理建模,然后日常最后建得解不出来..
- 选修了城市规划的课程,虽然给均分造成的影响不忍直视但是,,现在看城市越来越有感觉了哈
- 社团嘛参加了Infoco凭关系进了管理层,然后一直水偶尔参个会出点主意之类的
## 研究方面:
研究方面,主要搞了三个。上半年调查了Personality trait 对Second Language Acquisition 的影响,最终发现只有内倾型和Grammar优势有着significant 相关性。暑假在欧朗期间搞了关于物联网行业的一个调查,发现业内存在显著的客制化和去中心化发展趋势。下半年在暑期结论的基础上研究了一下Fog Computing, 基本上读遍了近两年IEEE上关于Fog 的文章,愈发坚信未来10年互联网云雾结合的趋势。一个感觉,中国会是这一场互联网架构变革中的关键
## 生活方面
### 番剧
- 追番56部,分别是
>《 刀剑乱舞-花丸 》
>《 少年锦衣卫 》
>《 四月是你的谎言 》
>《 摇曳露营 》
>《 月色真美 》
>《 擅长捉弄的高木同学 》
>《 CLANNAD 》
>《 KANON 》
>《 AIR 》
>《 可塑性记忆 》
>《 冰菓 》
>《 Charlotte 》
>《 龙与虎 》
>《 星之梦 》
>《 Angel Beats 》
>《 斩 赤红之瞳 》
>《 罪恶王冠 》
>《 言叶之庭 》
>《 樱花庄的宠物女孩 》
>《 未闻花名 》
>《 刀剑神域 》
>《 凉宫春日的消失 》
>《 某科学的超电磁炮 》
>《 紫罗兰永恒花园 》
>《 萤火之森 》
>《 声之形 》
>《 中二病也要谈恋爱 》
>《 缘之空 》
>《 东京喰种 》
>《 实力主义至上教室 》
>《 工作细胞 》
>《 绯弹的亚里亚 》
>《 从零开始的异世界生活 》
>《 埃罗芒阿老师 》
>《 我的妹妹不可能有这么可爱 》
>《 我的青春恋爱物语果然有问题 》
>《 白色相簿2 》
>《 境界的彼方 》
>《 游戏人生 》
>《 citrus 》
>《 命运石之门 》
>《 未来时在做什么?有没有空?可以来拯救吗? 》
>《 路人女主的养成方法 》
>《 fate 》
>《 进击的巨人 》
>《 玉子市场 》
>《 小林家的龙女仆 》
>《 吹响吧,上低音号 》
>《 夏目友人帐 》
>《 妖精森林的小不点 》
>《 银魂 》
>《 干物妹小埋 》
>《 魔法禁书目录 》
>《 吹响吧,上低音号第二季 》
>《 利兹与青鸟 》
>《 轻音少女第一季 》
- 观看电视剧:《lie to me》《硅谷》《谈判官》《翻译官》《非自然死亡》
### 调情易趣
- Bilibili看视频425小时,大概刷便了Jack Ma的演讲,最痴迷up主竟然是环球时报。。
- 云村听歌1017小时
- 倾听了一场交响音乐会
- 旅游五次,分别在曲阜,太湖,苏州拙政园,济南,南京
- 去过一次酒吧
- 三次卡拉OK
- 回老家探望姥姥,爷爷,陪表妹外甥玩
- 学车,科一,科二,无证驾驶从方特到山口来回
- 看了不少电影,就不数了
- 后期更加注重生活和头发,,日均2盒奶,渐渐跟上早点
## 经济方面
- 项目开销渐长,18年花销1000+,但仍可控
- 奖学金补助
- 比较稳健的投资策略,平均能把七日年化搞到4+,最高的时候到过7
- 现金流控制还可以,一年内没有发生过现金紧张情况
- 然后发现如果只是生活的话想多花点钱真的要很努力才行
## 会展:
- 参加中国开发者大会,入坑开源
- 赴上海参加世界移动大会,一窥中国物联网未来
## 反思:
- 熬夜有点小多,目测下半学期平均1点半睡觉
- 通宵次数略多,大概有15次,其中3次通宵时间超过30小时
- 运动少,只游过一次泳,没怎么跑过步
- 经常起不来所以不吃早餐
- 编起程来生活节奏就乱掉,太过急切的追求功能完善与完美
- 高二下半学期节奏不稳,数学更是基本半学期没怎么学
- 过多归因于学校课程设置问题,这本身就很有问题
## 展望2019:
- 更惬意的生活
- 更宜人的节奏
- 更真诚的人际
- 2020年Github中国区前100
- 文体两开花
---------------
本文已完结哦(๑•̀ㅁ•́ฅ)

@ -0,0 +1,41 @@
title: Arduino中[]=重载导致的String调用问题
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
最近在物联网开发中使用Arduino搭建LoRa网关和节点,发现在调用String时总遇到一些奇奇怪怪的现象。经过排查,发现是由于其它地方[]=运算符的重载所导致。
<!--more-->
为了方便,在开发节点时,我们使用了[LoRa-Socket](https://github.com/iotcat/lora-socket)和[ArduinoJSON](https://arduinojson.org/)作为依赖。我们发现这两个依赖分别使用时表现良好,但如果在同一个项目文件中使用,则会导致一些怪异的问题。
## 情况一
通过指针调用函数时String参数传递异常。代码如下:
```C
inline static void _onReceived(const String& msg, const String& from, const String& to, const String& type){
(*_f)(msg, from, to, type);
};
```
在这个案例中,我们发现msg等String在此函数中的数值是一切正常的,可是却没有能够成功传递到_f中。经过一系列骚操作,我们得出如下结论:
- 发现如果将String换成int或其它类型,则参数传递至_f一切正常。有问题的只有String和char类型。
- 我们尝试过将String转换为其它类型,再转回,但是没有效果。
- String或char类型全局变量的声明会使单片机崩溃。
- 当我们将ArduinoJSON依赖删去,String参数的传递则一切正常。
我们从而可以得出,这种怪异现象是由于与ArduinoJSON包的冲突所致。
## 情况二
在使用[ArduinoVector](https://github.com/tomstewart89/Vector)制作String类型Vector时,我们也发现了String类型的不稳定现象。神奇的是,这种现象只出现在String的使用中,其它如int类型运作良好。
这些不稳定现象可以总结如下:
- 赋值时被截断
- String值局部乱序
- String值部分乱码
- 作为参数传给函数时会失败,读取出来是空(与案例一类似)
## 综述
通过上述两个案例,我们可以初步总结出,这是由于[]=赋值运算符的重载与String有冲突。只要使用[]=重新定义String,即有可能出现String怪异的问题。

@ -0,0 +1,32 @@
title: 香辣牛肉面
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
## 材料准备(两人份)
- 面条
- 两个鸡蛋
- 两根英国大葱切末
- 两片姜切末
- 适量牛肉切丁
- 准备小碗放一个八角,桂皮,白扣,少许白胡椒粒
<!--more-->
## 预备步骤
- 热锅植物油香油煎鸡蛋
- 热水焯一下牛肉
## 核心步骤
- 热锅植物油香油,放入葱白部分炝锅
- 加入开水和牛肉粒,加入碗中的调料,焖3分钟
- 加入一勺生抽,半勺老抽,一勺蚝油
- 加入适量鸡精和盐调鲜
- 加适量红油藤椒油调辣
- 放入面条,煮到熟
## 后续
- 面条添至碗中,盖上鸡蛋
- 加剩下的葱绿末
## 配图
![香辣牛肉面-2020-01-19](https://api.yimian.xyz/img/?path=imgbed/img_6dff3385_3648x2736_8_null_normal.jpeg)

@ -0,0 +1,71 @@
---
title: wifiduino搭建236宿舍物联网平台
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
重新搭建236的IoT底层平台,并通过Blinker手机控制,实现操控监视。平台拥有很强的扩展性及可移植性,目前实现了夜间自动灯光,火灾烟雾报警,床帘内:上床小夜灯开,自动通风,LED自动感应阅读状态等设计。
<!--more-->
## 搭建缘由
早在大一上学期,意外接触Arduino,开始了解单片机。17年11到12月份,曾利用Arduino uno 3搭建了一台功能简易的自动控制平台,主要实现了由红外遥控器控制床帘Light以及小夜灯的功能。在运行一个半月后,由于一次上传代码时意外短路,导致单片机烧毁,自此系统报废,但线路依旧保留。
考虑到第一次搭建完全新手,代码缺少必要注释,更有通向床帘的数十根线路完全缠绕在一起,无法分清具体那几根控制什么传感器或设备,故设重建计划暂时搁置。
半年后的暑假,参加欧朗中国的IETE项目,课程中与公司研发组的软件和硬件工程师愉快得体验了一些单片机的应用研发,了解了单片机及物联网的基础组成及发展现状,在工作闲余,对原有线路进行了测试,分类,贴标签,使其得以正常使用。
8月份,项目结束,回到家中。考虑到家中原有太阳能需加水后需手动关闭,时常发生晚上洗澡后加水忘关情况,造成大量水资源浪费。于是结合欧朗所学,以及自己的实践经验,搭建了一套基于wifiduino和电磁阀的太阳能自动加水系统。为了照顾年老的姥姥方便夜间上厕所,在走廊过道利用原有废弃有线网络线路,搭建了与手动开关密切集合的自动感应开灯系统。由此收获了许多关于家用线路的架设经验。
回到苏州,考虑到一年来的相关经验,认为是时候尝试搭建一套可长期使用的商品级的强扩展性的IoT系统,于是…start搞事情
## 搭建经历
搭建初期,一切还算顺利。但是随着系统逐渐趋于完善,代码逐渐复杂,经典的Arduino式软硬件兼容问题又逐渐开始捣乱啦~
首先遇到的问题是(大概是由于esp8266与wifiduino的一些神奇的勾当)当把代码通过usb传给wifiduino的时候,代码运行是正常的,但是在断电重启或者Reset后,它就死掉了。。。而且,这个问题只在上传占用了大约十个左右Digital通信口的程序之后才出现,如果只是上传简单的示例程序则运行正常,,最后从淘宝钓了一只路由器用的USB-DC9V升压线,用其持续供电,才确保了板子的正常运行。
遇见的第二个问题也是很神奇。就是,wifiduino在连接tx与rx后竟然无法上传代码!!!当时我一直以为是板子坏掉了
本来是只有一块板子的,但是当他装载了太多控制端之后,大概是死掉了,wifi无法正常连接Blinker..于是我只用它作为控制器,然后将另一块板子连接wifi,将接受信息通过串口传递给主板子执行。于是,运行终于正常了,,,莫名想到了欧朗当时考试的译码器
## 主要功能
功能的话目前看来也不是很多,4只传感:2只超神波测距,1只光敏,1只烟雾,4个控制端:1只床外探照灯ledB, 1只小夜灯,1只床头灯,1个小风扇。实现的话,无非就是其相互配合,目前可以准确识别我的存在位置4个,室友的存在位置1个。然后配合行为习惯编程调整灯与风扇。
未来的话,还打算逐步实现–传感层:对室内是否有人的识别 智能层:对室友在宿舍时间规律的学习(神经网络) 控制层:空调红外控制,基于esp8266的微型继电器对宿舍大灯的控制,以及,快乐的话考虑自动养一株辣椒什么的…
## 最后
最后附上两个板子的代码,,还会更新的哦//祝生活愉快啦~
代码:https://uk.cloud.yimian.xyz/index.php/s/YbPwdkt2mANYoiS
--------------------
## 2019.2.19更新:
板子运行超过150天,一切运行正常。
出现过几次分钟级别的控制失效事件,怀疑宿舍电网供压不稳导致,事后均自动修复。
-------------------
## 2019.2.28更新
上文代码链接已弃用,如有兴趣,可查看由其代码开发的[wIoT项目][1]!
------------
## 2019.6.12更新
稳定运行611天18小时32分钟,正式退役!
-------------
已完结
[1]: https://github.com/iotgod/wIoT

@ -0,0 +1,124 @@
---
title: Build Nextcloud Server on Centos 7.5
date: 2020-06-16 15:43:54
categories:
- tech
tags:
- docker
- php
- nginx
---
Nextcloud is an open-source software project coded with PHP. It had provided a ideal private cloud-storage solution which was considered to be reliable and stable. This blog aims to present a Nextcloud Building instruction step by step for the purpose of helping freshman and future reviewing. Nextcloud is an open-source software project coded with PHP. It had provided a ideal private cloud-storage solution which was considered to be reliable and stable. This blog aims to present a Nextcloud Building instruction step by step for the purpose of helping freshman and future reviewing. Nextcloud is an open-source software project coded with PHP. It had provided a ideal private cloud-storage solution which was considered to be reliable and stable. This blog aims to present a Nextcloud Building instruction step by step for the purpose of helping freshman and future reviewing.
<!-- more -->
## Change linux core to BBR vision
If your server is a new one, it is strongly recommended to update it to an upper version supporting bbr mode, which is a senior centos system core provide by google and it could make your server more efficient.
Firstly download and install bbr core from github.
```bash
$ wget -N --no-check-certificate https://github.com/teddysun/across/raw/master/bbr.sh &&\
$ chmod +x bbr.sh && \
$ bash bbr.sh
```
Use the code to check the core version. If it’s large than 4.9.0 it’s OK.
```bash
$ uname -r
```
Expected return:net.ipv4.tcp_available_congestion_control = bbr cubic reno
```bash
$ sysctl net.ipv4.tcp_available_congestion_control
```
Expected return: net.ipv4.tcp_congestion_control = bbr
```bash
$ sysctl net.ipv4.tcp_congestion_control
```
Expected return: net.core.default_qdisc = fq
```bash
$ sysctl net.core.default_qdisc
```
Expected return: xxxxxxxx tcp_bbr
```bash
$ lsmod | grep bbr
```
## Install Nginx Service
Pull nginx package from nginx orginzation website.
```bash
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
```
Install Nginx.
```bash
$ yum install -y nginx
```
Start nginx service.
```bash
$ systemctl start nginx.service
$ systemctl enable nginx.service
```
Set preference file of nginx. Click here to get recommended nginx.conf file.
```bash
$ cd /etc/nginx
$ vi nginx.conf
```
Apply ssl certification. Rename it with your_domain.crt(key) and download it to your server: /etc/nginx/ssl/
```bash
$ //Use scp -r (my ssl file route on my windows)/your_domain.crt \root@(your server ip): /etc/nginx/ssl
$ //Use scp -r (my ssl file route on my windows)/your_domain.crt root@(your server ip): /etc/nginx/ssl
$ //On WINDOWS BASH
```
Check and restart nginx service.
```bash
$ nginx -t
$ //If the return is successful it is ok, othervise there exists error in your nginx.conf file.
$ systemctl restart nginx
```
## Install docker
Pull and install docker service from official website.
```bash
$ curl -sSL https://get.docker.com/ | sh
```
Start docker service.
```bash
$ systemctl start docker
$ systemctl enable docker.service
```
Pull nextcloud and mariadb(simplified mysql database on centos ) images from github.
```bash
$ docker pull rootlogin/nextcloud && docker pull mariadb:10
```
Start image mariadb with docker.
```bash
$ docker run -d --name nextcloud_db -v /data/mysql:/var/lib/mysql -e \
$ MYSQL_ROOT_PASSWORD=YOUR_PASSWD -e MYSQL_DATABASE=nextcloud \
$ -e MYSQL_USER=nextcloud -e MYSQL_PASSWORD=YOURPASSWD mariadb:10
```
Start image nextcloud with docker.
```bash
$ docker run -d --name nextcloud --link nextcloud_db:nextcloud_db -p 127.0.0.1:9001:80 -v /data/nextcloud:/data rootlogin/nextcloud
```
That is the last step on server. Now let’s start http://YOUR_DOMAIN/ with your explorer.
Recommend to substitute the “localhost” to “nextcloud_db”.
-------------
Reference List:
[https://www.moerats.com/archives/420/][1]
[https://my.oschina.net/yule526751/blog/799004][2]
[https://www.moerats.com/archives/420/][3]
[1]: https://www.moerats.com/archives/420/
[2]: https://my.oschina.net/yule526751/blog/799004
[3]: https://www.moerats.com/archives/420/

@ -0,0 +1,103 @@
title: 部署新型冠状病毒API
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
一分钟快速部署你自己的新型冠状病毒API ୧(๑•̀⌄•́๑)૭
<!--more-->
# coro-api
新型冠状病毒 实时数据 api
项目Git地址: [iotcat/coro-api](https://github.com/iotcat/coro-api)
项目npm地址: [iotcat/coro-api](https://www.npmjs.com/package/coro-api)
## API示例
### 获取全部
[https://api.yimian.xyz/coro](https://api.yimian.xyz/coro)
### 根据省份
[https://api.yimian.xyz/coro?province=山东](https://api.yimian.xyz/coro?province=%E5%B1%B1%E4%B8%9C)
### 根据城市
[https://api.yimian.xyz/coro?city=泰安](https://api.yimian.xyz/coro?city=%E6%B3%B0%E5%AE%89)
### 根据省和城(推荐)
[https://api.yimian.xyz/coro?province=山东&city=泰安](https://api.yimian.xyz/coro?province=%E5%B1%B1%E4%B8%9C&city=%E6%B3%B0%E5%AE%89)
## 快速部署
### 环境要求
- `nodeJS`支持`express`任意版本
- `git`任意版本
### 下载文件
```
$ git clone https://github.com/iotcat/coro-api.git & cd coro-api
```
### 安装依赖
```shell
$ npm install
```
### 启动
```shell
$ node index.js
```
### 访问
```
http://localhost:17676
```
## 进阶
### GET参数
参数 | 描述 | 示例
:--: | :--: | :--:
province | 省份(国家) | 山东
city | 城市 | 泰安
### 修改端口
从`index.js`第9行修改默认端口。
### 禁止跨域
注释掉`index.js`第13行。
### 使用pm2守护进程
```shell
$ npm i -g pm2
$ pm2 start index.js --name coro-api -o /var/log/coro/api.out -e /var/log/coro/api.err --watch
```
### Nginx配置
将以下内容加入`server{}`中
```nginx
location / {
proxy_pass http://127.0.0.1:17676;
}
```
如果你不是从根目录映射,记得去`index.js`中第11行`app.get('/', f)`修改成你的路径。
### 爬虫配置
爬虫使用[coro-py](https://github.com/iotcat/coro-py), 请参考其文档。
## 开源协议
本项目使用MIT协议,允许非署名商业非商业使用。武汉加油!中国加油!!❤

@ -0,0 +1,207 @@
---
title: C++建库中遇到的坑
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
由于学校课程安排,作为一只电气狗第一次正经的开始搞Cpp ::aru:shy::
特记录一些建库过程遇到的坑,,→_→
<!--more-->
## 关于.h文件
作为头文件,.h中一般放有相应类及函数的声明。
一个典型的.h文件如下:(FileName: yimian.h)
````C++
#ifndef YIMIAN_H //防止本文件被多次编译
#define YIMIAN_H //'YIMIAN_H'的值需自定义
//.h中可能用到的lib
#include<iostream>
#include<string>
using namespace std; //使用std命名空间,这样下面就可以不用写如std::cout了
//声明yimian类
class yimian{
public: //公共域(可外界直接调用)
void hi();
static string version;
private: //私有(不对外公开)
};
#endif //与文件开头防多次编译相对应
````
为了安全起见,函数以及变量的初始化一般不放在.h文件中进行。而是习惯于建一个新的同名.cpp文件。
下面是一个与上午相对应的.cpp文件示例:(FileName: yimian.cpp)
````C++
#include"yimian.h" //需要指向yimian.h
string yimian::version = "Version 0.0.1"; //为字符串变量赋值
void yimian::hi(){ //定义yimian类中hi()函数内容
cout << "Hellow Yimian~" << endl; //输出"Hellow Yimian~\n"到屏幕
}
````
有了以上文件,一个简单的C++库就建成了φ( ̄∇ ̄o)
于是我们新建一个test.cpp文件用来放置main()
````C++
#include<iostream> //要用到的lib声明
#include<stdio.h>
#include"yimian.h" //引入自定义lib
using namespace std; //使用std命名空间
int main(){
yimian $; //定义一个名字为$的新yimian类
$.hi(); //调用yimian类中hi()函数
cout << $.version<< endl; //将yimian类version变量输出到屏幕
return 0; //主函数结束
}
````
然后便可以愉快的使用g++编译啦,指令如下:(win如何搭建GNU环境)
````
$ g++ test.cpp yimian.cpp -o [目标文件的名称]
````
之后命令行启动编译好的程序 (什么是命令行⌇●﹏●⌇)
````
$ ./目标文件名称.exe
````
如你所料,以上程序的运行结果为:
> Hellow Yimian~
> Version 0.0.1
----------
**坑** ::aru:meditation::
- 头文件中声明定义好的类貌似一定要在main()中实例化(调用)才行,不然会报错
------------
## 总结一下类相关知识
### 类访问修饰符
- **public: **类内外皆可访问的内容
- **private: **类外不可访问,仅可自己和友元访问,子类不可访问
- **protected: **外部不可访问,自己、友元和子类可访问
### 特殊函数类型
- **构造函数:**每次创建对象时会执行,即初始化
````C++
class Line{
public:
void setLength( double len );
double getLength( void );
Line(); // 这是构造函数
private:
double length;
};
````
- **析构函数:**删除对象时执行的函数,即善后
````C++
class Line{
public:
void setLength( double len );
double getLength( void );
Line(); // 这是构造函数声明
~Line(); // 这是析构函数声明
private:
double length;
};
````
- **拷贝构造函数: **实现复制对象时同一类对象间传参
````C++
class Line{
public:
int getLength( void );
Line( int len ); // 简单的构造函数
Line( const Line &obj); // 拷贝构造函数
~Line(); // 析构函数
private:
int *ptr;
};
·········
Line::Line(const Line &obj){
cout << "调用拷贝构造函数并为指针 ptr 分配内存" << endl;
ptr = new int;
*ptr = *obj.ptr; // 拷贝值
}
·········
int main( ){
Line line1(10);
Line line2 = line1; // 这里也调用了拷贝构造函数
return 0;
}
````
- 构造与拷贝构造区别:
````C++
A x(2);  //直接初始化,调用构造函数
A y = x;  //拷贝初始化,调用拷贝构造函数
````
### 友元函数/类
- **友元:**友元就像老邻居啦,家里东西随便拿
````C++
class INTEGER{
friend void Print(const INTEGER& obj);//声明友元函数
};
void Print(const INTEGER& obj){
//函数体
}
void main(){
INTEGER obj;
Print(obj);//直接调用
}
````
### 内联函数
- 总之行数很少,功能很简单,没有循环和开关语句,想提高函数效率,就用内联(╯‵□′)╯︵┴─┴
````C++
inline int Max(int x, int y){
return (x > y)? x : y;
}
// 程序的主函数
int main(){
cout << "Max (20,10): " << Max(20,10) << endl;
cout << "Max (0,200): " << Max(0,200) << endl;
cout << "Max (100,1010): " << Max(100,1010) << endl;
return 0;
}
````
### this指针
- 类似js中this,指向参数对象本身
###
----------
To Be Continued..

@ -0,0 +1,49 @@
title: 公共开支计划系统
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
在英国留学与4个室友合租,为了更好的控制和监管公共支出,以及维持彼此之间的公共支出平衡,我利用迎新周三天时间设计并开发除了此ERP公共开支计划系统。希望此系统能够便捷接下来一年的生活,减少大家之间的矛盾,促使充满幸福感的公共支出项目持久化OωO
<!--more-->
## 1.功能介绍
- 统计日均周均流水,让公共支出可视化
- 用户申报一次公共支出,并提交发票照片留证
- 监视各成员间支出不均衡程度,计算方差,并可视化显示
- 对比本周与上周的开支,给出增减比例
- 当存在一人支出超出均值阈值,并且存在至少一人支出少于均值阈值,则会邮件这两个人产生一次内部交易
- 当上例中收款人收到款项后,需要到平台确认收到
- 平台所有历史公共开支及发票可查
## 2.系统架构
### 2.1 前端
前端基于一个网上找到的比特币网站平台模板,深度改造实现。值得一提的是,前端使用[Ushio-js项目](https://github.com/iotcat/ushio-js)作为安全及日志插件,并得到了[Ushio](https://ushio.xyz)系统做背后支持。
### 2.2 后端
后端使用php语言编写。提供5个接口,分别提供获取账户事件,获取内部流通信息,获取公共支出信息,获取周报表,操作的功能。
mail系统使用[Yimian Mail API](https://www.eee.dog/tech/mail-api.html)快速构建。
### 2.3 数据库
数据库使用yimian-db/mysql。构建了三个表,分别用于存储流水,公共支出详情,内部流通。
### 2.4 图片上传
直接引用[呓喵酱の图床](https://imgbed.yimian.xyz)代码,少量改写。
### 2.5 用户系统
目前用额外网页简单实现,等待[ushio-auth项目](https://github.com/iotcat/auth)完成后统一整合。
## 3. 外观
没啥可说的,摆图,自己看
![imgbed_ed08c497](https://api.yimian.xyz/img/?path=imgbed/img_ed08c497_1080x6654_8_null_normal.jpeg)
![imgbed_ea04ad82](https://api.yimian.xyz/img/?path=imgbed/img_ea04ad82_1080x5082_8_null_normal.jpeg)
![imgbed_a8b3adb0](https://api.yimian.xyz/img/?path=imgbed/img_a8b3adb0_1080x2160_8_null_normal.jpeg)

@ -0,0 +1,81 @@
---
title: Economy, Environment &amp; Sustainability
date: 2020-06-16 15:43:54
categories:
- thoughts
tags:
---
经济学是一门研究选择的学问。人们活在世上总是在进行着各种选择。发展落后的国家希望尽快工业化发展经济,来改善自己的生存环境。而工业化后的国家则希望发展同时兼顾环境。于是落后国家需要50年来发展工业,搞基建,破坏环境。之后的50年则拼命治理环境,发展生态。由于地球生态是一个整体,发达国家非常不爽落后的国家搞工业化污染环境,于是各种矛盾。不过在21世纪,有望利用信息数字科技打破50-50年法则,为新一批的国家崛起提供蹊径( ๑´•ω•) "
<!--more-->
## 为什么追求发展
自然环境较为恶劣,不完全适合人类生存。于是具备主观能动性的人类开始由改造环境的冲动。这一心理行为逐步早就了名为“发展”的宏伟故事,大家都对其深信不已。就像故事中所描述的一样,人们为了实现这一目标开始减少内耗(战争),社会趋于高度分工化。
人类有一种基本心理效应叫蔡格尼克效应,讲的是人如果开始做一件事情便会难以在中途停下来。这一效应在群体行为中则会变本加厉的体现。当人们开始追求发展,并且得到了一定的激励(生活的确更舒适了,至少人们是这样认为的),于是这个势头便不会轻易停下来了,于是人类进入了千年级别的发展时期。
发展初期,太多的基础设施需要建设,太多的工业需要发展,最重要的是这个时候大家都很穷,都只是在一个信念的支撑下在向着发展的目标努力搞生产。而且一般当这个时候,往往会有其他强国对你虎视眈眈,所以这个时候,大家都会很团结,但不会像祖先以及后辈一样在乎什么环境生态的。只有一个想法便是希望发展起来。
经过大约50年的发展,生活好了,底气足了,开始关注一些更长久的事情,比如教育和环境。于是接下来的50年,开始拼命治理环境,搞教育。于是渐渐的环境好了,下一代也成长起来了。于是年轻一代们便利用他们头脑中的书本知识,开始批判祖先们破坏环境这不好那不好,开始投科研资金,股市凡是跟环保相关的板块开始居高不下,可持续发展开始成为许多人的口头禅。而这时,当时那些破坏环境的罪魁祸首们正退休在家里乐呵呵的看着这一切的发生。大概就是这么一个过程了。
## Environmental Kuznet Curve
![Environmental Kuznet Curve][1]
上图的曲线非常科学地向我们展示出了一个国家在发展与环境之间摇摆的必然趋势。在这一图表的背后,反应出了以下几点:
- 人们倾向于只考虑自己的假设
- 不同于个体的人群特性
- 生存资源稀缺
- 生产资料流通低效
这意味着,如果能够改变上述的任何一个条件,Kuznet 诅咒便有希望得以改变,从而减小摆动周期和幅度,控制环境重建与修复成本,真正在宏观上实现人们所希望的高效率可持续发展。而新一代的数字信息技术正是这一可能性得以实践的关键。
## 概念图
{% raw %}
<!-- 引入mermaid制图-->
<div class="mermaid">
graph TD
A{Environment}
B{Economy}
C{Society}
D[GDB Based]
E[NNI** HDI]
F[Kuznet Curve]
G[Env Kuznet Curve]
H((Human Nature))
I[Human Behavior]
J[Improve Living Environment]
K[Request for Dev]
A --> J
J --> K
K --> B
B --> |measured by| D
D --> |neglect| C
B --> |predicted by| F
F --> C
D --> |foments| I
D --> |spoils| A
G --> C
H --> I
E --> |consider| A
B --> E
A --> H
I --> |caused by| C
I --> A
</div>
{% endraw %}
--------------------------------
**参考课件:**
[Economic Development and The Environment.pdf][2]
[1]: https://yimian-image.obs.myhwclouds.com/blog/70-1.png
[2]: https://yimian-attachment.obs.myhwclouds.com/ppt/lan104/Week%202%20Economic%20Development%20%20The%20Environment.pdf

@ -0,0 +1,62 @@
---
title: Fog Architecture and Internet of Things
date: 2020-06-16 15:43:54
categories:
- thoughts
tags:
---
In the past few decades, Internet has been rapidly expanding and it plays an increasingly important role in people’s life. After the involvement of nearly all humans on the earth [1], developers, inevitably, expected to make more things available for the internet, which then generated the idea of the Internet of Things (IoT). Regrettably, in the case that a considerable number of things connect to the internet, its current architecture seems not to be a so efficient solution for IoT. Bonomi et al. [2] from Cisco firstly noticed this issue and they then put forward a revolutionary concept of Fog to satisfy the access of a surging number and variety of devices in the coming IoT era. This essay will argue that the Fog concept can have considerable impact on promoting IoT construction.
<!--more-->
Internet’s architecture had been widely controverted concerning whether it should be centralized or distributed. In the past few years, centralization, which is also regarded as the Cloud, has been gradually applied to the practical structure for modern internet. Under this concept, it has become a popular trend to move functions such as computing, storage and control from end-user devices to Cloud servers [3].Different from the Cloud, the Fog proposes to distribute these functions from servers to the users and let users share them with each other.
Fog can be classified into three dimensions: Fog computing, Fog storage, and Fog control. According to Bonomi et al. [2], Fog computing means to make full use of the computing resources not only from the user devices, but from the location anywhere between users and traditional Cloud servers.An ideal example is that, video game players’ smartphone can access the idle computing resource such as the Central Processing Unit (CPU) of players’ laptop to improve their game experience. Similar to the Fog computing, Fog storage,the second dimension, proposes to distribute user’s data from single storage to many storage devices through certain algorithm [3]. One brave practice for this is Google Spanner [4], which is a public database functioning by distributing user’s data to data centers all around the world to protect these data from being attacked. Shi et al. [5] indicated that the third dimension of Fog, Fog control, tends to split a traditional control system into many small independent and interactive fog systems which only concentrate on providing single function. In this case, if a fog light control system breaks down, the host system can still get the command of the light through another similar fog control system to keep the service incessantly in a Smart Home.
One reason why the Fog contributes to the construction of IoT is that the internet under the concept of Fog can meet the challenging minimized delay requirement of IoT. Prof. Chiang & Zhang [3] indicated that, IoT applications such as Virtual Reality(VR) games, vehicle-to-vehicle communications and unmanned aerial vehicle (UAV)control applications appear to require latencies, the time spent between one device sending a message and the target device receiving the message, lower than tens of milliseconds, which the Cloud services cannot achieve. However, in a Fog computing model proposed by Yousefpour, Ishigaki & Jue [6], the low-level service delay character of Fog architecture had been proved to be persistent and stable. This may mean that latency-sensitive IoT applications can benefit from their delay-minimizing policy.
Another factor of why the Fog facilitates IoT construction is that a Fog structured internet can provide uninterrupted services, which IoT applications are desirous of. In a Fog structure a control behavior is achieved by several parallel control systems working together while each system has the potentiality to support the whole control behavior independently. This makes it possible that a Fog service can still function when devices disconnect with the server or part of the Fog net is updating or even broken [3]. This trait becomes crucial for Connected Vehicle [2] to ensure its operation when it is offline or meet with an accident.
Apart from these reasons,comparing to the current Cloud internet, the architecture of a Fog internet seems to be more eco-friendly, especially for the coming IoT era. In the 21stcentury, environmental protection has been becoming a comparatively important agenda for policy making and business activity. Consumers expect fewer environment-harmful elements in the product or generated from its manufacture. However, accordingto Aazam et al. [1], in the future, everything such as a bottle of cola or a leaf of a tree can be part of Internet, which may require a considerable number of new electrical equipment while each one of them might hurt the environment to some extent. However, this may mean that the ecological environment would be protected if the amount of necessary electrical products could be decreased. Researchers had assessed the suitability of Fog computing and they pointed that a Fog internet can result in less power consumption and lower CO2 emission in the context of IoT [7]. Apparently, these may transform the internet closer to a green net.
One argument is that the Fog architected IoT was questioned in privacy and security [3]. Since the important internet functions and resources are near the users, it becomes risky for a Fog device of being attacked. However, this might be solved by collaborating with other technics. For example, Zyskind and Nathan [8] designed a decentralized personal data management algorithm basing on blockchain, a powerful encoding method. This algorithm might be one possible solution to cover the data security shortage of Fog net and keep the system safe.
To conclude, although the IoT based on Fog concept may be currently doubted in privacy and system security, it has satisfactory performance in respect of latency, system reliability and eco-friendliness, which are crucial factors on facilitating IoT construction. However, Fog is still a new concept and nearly all of the relevant research was conducted in the past two years. It is still a long way to go before the Fog concept can be actually applied into the framework of IoT.
-----------------
**Reference (IEEE)**
[1] M. Aazam, I. Khan, A. A. Alsaffar and E. Huh, “Cloud of Things: Integrating Internet of Things and cloud computing and the issues involved,” Proceedings of 2014 11th International Bhurban Conference on Applied Sciences & Technology (IBCAST) Islamabad,Pakistan. [Online]. 14th – 18th January, 2014, Islamabad, 2014, pp. 414-419.Available: https://uk.cloud.yimian.xyz/index.php/s/PAbkLC5bqoWFcJi
This is an early peer-reviewed article introducingthe concept of Cloud and IoT. It provides me the scope of how researcherslooked at Cloud and how they understood IoT in 2014 (when Cloud Computing beganto be popular). I have used this to provide some background about Cloud inintroduction.
[2] F. Bonomi, R. Milito, J. Zhu and S. Addepalli, “Fog computing and its role in the internet of things” In Proceedings of the first edition of the MCC workshop on Mobile cloud computing. [Online]. August, 2012, pp.13-16. Available: https://uk.cloud.yimian.xyz/index.php/s/ZnyXdJKk84dR2QD
Thispaper firstly pointed out the Fog concept. Its writers were all from Cisco, which is considered the most powerfulcompany on providing Internetworking solution. I have used this sourceto introduce some background of Fog and Fog computing and the Connected Vehicle,one of their imaginary Fog-IoT application.
[3] M. Chiang and T. Zhang, “Fog and IoT:An Overview of Research Opportunities” in IEEE Internet of Things Journal. [Online]. vol. 3, no. 6, pp.854-864, Dec. 2016. Available: https://uk.cloud.yimian.xyz/index.php/s/Fi7KELbjE7kR3qq
This is an invited paper published by IEEE, the most influential organization for Engineer. Chiang is from Princeton and Zhang is from Cisco. After this paper, more researchers began to notice Fog. I have used this source to introduce, evaluate and query Fog because this is a rare high-quality paper.
[4] J.C. Corbett, J. Dean, M. Epstein, A. Fikes, C. Frost,J.J. Furman, S. Ghemawat, A. Gubarev, C. Heiser, P. Hochschild and W. Hsieh, “Spanner:Google’s globally distributed database”, ACM Transactions on Computer Systems (TOCS). [Online].vol. 31, no. 3,pp. 8, Aug. 2013. Available: https://uk.cloud.yimian.xyz/index.php/s/oxj4EAm6M78GPN8
This paper detailly introduced Google Spanner. Google Spanner was designed based on this paper. I include this source because I think Google Spanner is are volutionary attempt of Fog storage. And I have used this as an example when I try to describe the concept of Fog storage.
[5] W. Shi, J. Cao, Q. Zhang, Y. Li and L. Xu, “Edge Computing: Vision and Challenges” in IEEE Internet of Things Journal. [Online]. vol. 3, no. 5, pp. 637-646, Oct. 2016.Available: https://uk.cloud.yimian.xyz/index.php/s/p4QGJA6AWPDKEK4
This is a journal from IEEE and have been cited 8422 times. It provides several novel ideas concerning how would the Fog be applied in computing field. I have summarized the Fog control concept from this source and cited their questioning concerning the privacy and security issue of Fog IoT.
[6] A. Yousefpour, G. Ishigaki and J. P. Jue, “Fog Computing: Towards Minimizing Delay in the Internet of Things” 2017 IEEE International Conference on Edge Computing (EDGE), Honolulu, HI. [Online]. 2017, pp. 17-24. Available: https://uk.cloud.yimian.xyz/index.php/s/EsDjHnHHGND2SoD
The authors were from Texas University and they are not famous in Fog field. As it is the only paper which evaluated latency, the most significant trait of Fog IoT, mathematically and got a seemly reliable result, I have used this to support my low latency argument.
[7] S. Sarkar, S. Chatterjee and S. Misra, “Assessment of the Suitability of Fog Computing in the Context of Internet of Things”in IEEE Transactions on Cloud Computing.[Online]. vol. 6, no. 1, pp. 46-59, Jan.-March 2018. Available: https://uk.cloud.yimian.xyz/index.php/s/m7of3EjZ6Tji7jF
This paper was just published a few month ago. It was written by two students and one doctor, which makes it not so authoritative. However, since there are few Fog research, I finally decide to use its modeling result to support that Fog IoT is more environment friendly than Cloud.
[8] G. Zyskind, O. Nathan and A. ‘. Pentland,”Decentralizing Privacy: Using Blockchain to Protect Personal Data” 2015 IEEE Security and Privacy Workshops,San Jose, CA. [Online]. 2015, pp. 180-184. Available: https://uk.cloud.yimian.xyz/index.php/s/7FirJsrD93wzDxN
This paper was published by IEEE. Zyskind was from MIT, which makes the source seems to be credible. I am interested in the blockchain algorithm which is theoretically absolutely safe as it mentioned and I think it is one ideal method to deal with the security problem of Fog IoT.
----------------------
Attachment
Fog and IoT PPT: https://uk.cloud.yimian.xyz/index.php/s/GbLfqxX2CBTDdRR

@ -0,0 +1,111 @@
---
title: 气候变化与全球环境
date: 2020-06-16 15:43:54
categories:
- thoughts
tags:
---
全球气候变化与人类行为有着显著的相关性,人类行为又会改变气候的自然变化。通过研究Ice core等Archive,发现地球历史中温度与$CO_{2}$浓度有着显著正相关性。如今,人类行为使大气$CO_{2}$含量远超其正常水平,其可能引起全球变暖,冰川融化等,但仅为可能..
<!--more-->
## 概念简介
### 天气与气候
天气是指一段较短时间段内的大气状态,而气候研究的主要使更长时间中周期行动大气状态规律。简言之,气候是周期变化的天气。气候具备地域性,随纬度与海陆分布密切相关。在更长的时间维度上,我们发现地球的气候变迁也呈现出显著的周期性。
![地球历史温度变迁][2]
上图描述了地球的历史温度,其具有明显的周期性。值得注意的是,每当全球气候变暖,便会激发物种爆炸。而现在,正处于一次小规模的温度上升期,且温度上升速度与历史数据并无太大异常,因此无法确凿证明其与人类二氧化碳排放有关。
## 研究方法
### 直接法(研究现代)
1. 记录温度
2. 记录降雨量 (Precipitation)
3. 研究植被 (Vegetation)
4. 海平面
5. 冰川 (Glaciers) :: 主要通过研究冰盖融化与生成的Balance
### 间接法(研究历史)
1. Proxy
2. Archive e.g. "Ice Core" ::从冰层(Ice Sheet)中提取的分层的冰棍标本
### Ice Core分层原因
积雪后,随着时间推移,积雪会经历以下几种状态:
1. Snow (几小时,主要成分是空气)
2. Firn (几天,粒雪)
3. Glacial Ice (数年)
### 时间追溯方法
由于积雪时的温度不同,因此冰层中会以年为单位周期变化,通过计数层数即可获得某一冰层的所属年代。
![冰层][3]
### 历史温度研究方法
大气中${}^{18}O/{}^{16}O$比值与温度密切相关,因此通过测量冰层中相应位置的同位素比值即可间接推得当时的温度。
此外,还可以通过类似的方法测得各历史时期的$CO_{2}$浓度。
## 研究发现
### 二氧化碳浓度与温度密切相关
![历史二氧化碳与温度][4]
由上图可看出,地球历史上,二氧化碳浓度与温度具备密切的相关性。直到近150年,这一规律被打破,大气二氧化碳浓度极具上升。人表示慌得一批⌇●﹏●⌇
## 与人类
### 一个公式
$$Increase CO_{2} = Increasing Population + \Delta Emission per Person + Efficiency of CO_{2} Use$$
这个公式也可以转译为:
$$碳排量 = 人口 + 经济 - 科技$$
### 一个组织
Intergovernmental Panel on Climate Change (IPCC) 制定了一个小目标来限制各国温室气体排放,表示到2050年,全球二氧化碳排放量要卡一半。。这其实等同于将排放量和钱联系起来,给每个国家分一部分排放量,如果多排就要交钱来买。结果已经工业化完的发达国家切走了超过40%的蛋糕,国科大校长老丁表示这不能忍啊,发展中国家的人到底还有没有人权啊ヾ(´・ ・`。)ノ"
## 气候变暖影响
### Good
- 数据表明温度越高,世界范围战争数量越少
- 实验表明,温度高时,粮食等植被产量更高
### Bad
- 南方动物(虫子)比植物北迁的快,北方无天敌,植物被虫子吃光
- 海平面上升,淹没苏州
{% raw %}
<!-- 引入mermaid制图-->
<div class="mermaid">
graph TD
A{Climate Change}
B[Economy]
C[Politic]
D[Tech]
E[Agriculture]
F[Human Health]
A --> |influence| E
E --> |change| B
E --> |change| C
B --> |change| C
B --> |determine| D
C --> |determine| D
B --> |influence| F
D --> |affect| F
D --> A
C --> A
D --> E
E --> |Green Plant| A
E --> F
F --> E
</div>
{% endraw %}
-------------
参考课件:
[Climate change - From past to Future - Yi Zou-2019.pdf][1]
[1]: https://www.eee.dog/usr/uploads/2019/02/3411175553.pdf
[2]: https://yimian-image.obs.myhwclouds.com/blog/34-1.png
[3]: https://yimian-image.obs.myhwclouds.com/blog/34-2.jpg
[4]: https://yimian-image.obs.myhwclouds.com/blog/34-3.png

@ -0,0 +1,12 @@
title: 今天很开心,在这里留个空
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
先在这里留个空,以后慢慢填~
<!--more-->
φ( ̄∇ ̄o)

@ -0,0 +1,16 @@
---
title: hello hexo
date: 2020-06-16 15:43:54
tags:
---
## 神奇的事情
神奇的事情开始发售了
![](https://api.yimian.xyz/img)
```js
const home = cooo;
var ee = 1;
```

@ -2,42 +2,4 @@
title: Hello World
type: post
---
Welcome to [Hexo](https://hexo.io/)! This is your very first post. Check [documentation](https://hexo.io/docs/) for more info. If you get any problems when using Hexo, you can find the answer in [troubleshooting](https://hexo.io/docs/troubleshooting.html) or you can ask me on [GitHub](https://github.com/hexojs/hexo/issues).
## Quick Start
### Create a new post
$$
\frac{d_r}{j_k}
$$
``` bash
$ hexo new "My New Post"
```
More info: [Writing](https://hexo.io/docs/writing.html)
### Run server
``` bash
$ hexo server
```
More info: [Server](https://hexo.io/docs/server.html)
### Generate static files
``` bash
$ hexo generate
```
More info: [Generating](https://hexo.io/docs/generating.html)
### Deploy to remote sites
``` bash
$ hexo deploy
```
More info: [Deployment](https://hexo.io/docs/one-command-deployment.html)
Hello World

@ -0,0 +1,98 @@
title: 意大利申根签攻略
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
在英国留学,圣诞去欧洲旅游,DIY了意大利申根签证。现在游完归来,总结一份申根签攻略。
<!--more-->
## 大致流程
- 仔细阅读[官网](https://www.vfsglobal.com/Italy/UK/London/tourist.html)条件,查看自己是否满足所有要求
- 尽早在线[面签预约](https://www.vfsglobal.com/Italy/UK/London/Schedule_an_Appointment1.html)(之后可以修改时间)
- 认真研究[需要的材料](https://www.vfsglobal.com/Italy/UK/London/tourist.html)(务必以官网为准)
- 生成visa申请表([在线生成](https://www.vfsvisaonline.com/OnlineVaf-Italy?Country=QcpCgYPkPBcUOc3/C92SWQ==))
- 准备其它材料
## 材料类别
### 常规签证材料
- Visa申请表
- 身份证明
- 居住证明
- 照片
### 附加签证材料
- 工作证明
- 财产证明
- 旅行证明
- 住宿证明
- 保险证明
## 材料CheckList
- visa申请表原件(在线生成后打印)
- 护照原件+复印件(黑白)
- BRP原件+复印件(黑白)
- 一张证件照-与英国签证一致([要求](https://www.vfsglobal.com/Italy/UK/London/tourist.html#tourist_photoSpecs))
- student letter
- 旅行支票原件+复印件或三个月银行流水
- 往返机票(姓名,日期,to&from)
- 火车票(姓名,日期,to&from)
- 住宿证明(姓名,日期,地址)
- 同行者名单
- 旅行保险证明(姓名,地理范围,保额)
- 面签预约证明复印件
-------------------------
- 旅行行程单(方便跟签证官解释)
- joint travel confirmation letter(如果某个车票或住宿证明上没有你的名字)
- 买票者的护照签名页复印件(如果某个车票或住宿证明上没有你的名字)
## 材料说明
### visa申请表
- 在线填写完第一页记得点SAVE, 记下页面右上角的Reference Number ::aru:shy::
- 下一次登录后点击上方[RETRIEVE INCOMPLETE FILLED VAF](https://www.vfsvisaonline.com/OnlineVAF-Italy/Applicant/Search)即可继续填写
- 填写参考[这篇攻略](https://travel.uk2hand.com/ukvisa/italy-schengen-visa/)
- 单面黑白A4打印
- 打印好不要填写,不要签字,不要贴照片,到现场签证官会告诉你怎么办
- 不要装订,建议用环形针
### Student Letter
- 去学校FB开
- 需要有人签名,电子打印的签名不行
- 抬头需要写`Italy Consulate`
### 旅行证明
- 需要提供付过款的机票和跨城市的火车票
- 票的底部需要有网站链接
- 所有票上需要有你的名字
- 如果某张票没有你的名字,需要票上有名字的人提供签过字的`joint travel confirmation letter`和`护照复印件`
- 可参考我们的`joint travel confirmation letter`
![joint letter](https://api.yimian.xyz/img/?path=imgbed/img_65e72a51_634x740_8_null_normal.png)
### 住宿证明
- `Booking Confirmation`上需要有`paid`字样
- 底部需要有网站链接
- 所有材料上需要有你的名字
- 如果没有你的名字,需要有名字的人提供签过字的`joint travel confirmation letter`和`护照复印件`
- 建议从`Booking`等知名网站订购
### 保险证明
- 一定要覆盖旅程
- 保期越长,签证时间越长。。
- 我们选择的太平保险申根应急签证,供参考
### 预约证明
- 到楼下前台拿着预约信挂号
- 之后预约信就没用了
--------------------------------------------
## 成果
最后展示一下我拿到的签证 ::aru:cheer::
![visa](https://api.yimian.xyz/img/?path=imgbed/img_f5690b2c_3968x2976_8_null_normal.jpeg)

@ -0,0 +1,85 @@
title: 一键激活win10
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
一键激活win10家庭版,专业版,企业版,教育版 φ( ̄∇ ̄o)
<!--more-->
## 方法一(自动安装)
- 使用此方法请先**关闭所有杀毒软件**
- 使用此方法请先**关闭所有杀毒软件**
- 使用此方法请先**关闭所有杀毒软件**
> p.s. 如果不放心,请使用 方法二-源码安装
------------------------------------------
- 点击[这里](https://github.com/IoTcat/kms/releases/download/v1.0/kms.exe)下载`exe`程序
-------------------------
- 运行刚下载的程序。(**请不要修改解压路径**)
- 运行刚下载的程序。(**请不要修改解压路径**)
--------------------
- 点击 更多信息`->`仍然运行
![](https://api.yimian.xyz/img/?path=imgbed/img_f8f91201_532x498_8_null_normal.png)
![](https://api.yimian.xyz/img/?path=imgbed/img_5e6b7101_532x498_8_null_normal.png)
- 输入数字进行选择。(可输入数字`4`获取汉语翻译!!)
![](https://api.yimian.xyz/img/?path=imgbed/img_6f4f0165_609x226_8_null_normal.png)
----------------------------------------------
- 耐心等待激活完成~ ::aru:proud::
> 脚本已发送到桌面`kms.bat`,如果不需要您可以删除它~
## 方法二(源码安装)
- 点击[这里](https://github.com/IoTcat/kms/archive/master.zip)下载压缩文件。
-----------------------------------
- **解压压缩文件**(请**务必解压**,否则无法运行)
- **解压压缩文件**(请**务必解压**,否则无法运行)
- **解压压缩文件**(请**务必解压**,否则无法运行)
--------------------------------
- 双击运行文件夹中的`kms`或`kms.bat`。
![压缩文件示例](https://api.yimian.xyz/img/?path=imgbed/img_c8d641e0_908x257_8_null_normal.png)
- 点击 更多信息`->`仍然运行
![](https://api.yimian.xyz/img/?path=imgbed/img_f8f91201_532x498_8_null_normal.png)
![](https://api.yimian.xyz/img/?path=imgbed/img_5e6b7101_532x498_8_null_normal.png)
- 输入数字进行选择。(可输入数字`4`获取汉语翻译!!)
![](https://api.yimian.xyz/img/?path=imgbed/img_6f4f0165_609x226_8_null_normal.png)
----------------------------------------------
- 耐心等待激活完成~ ::aru:proud::
## 进阶
### 激活码
您的激活码将保存在`C:\Windows\kms.key`
### 运行日志
- 激活日志 `%temp%\kms.log`
- 在本机尝试过的激活码 `%temp%\kms.tried_keys`
- kms服务器配置 `%temp%\kms.skms`
- ato输出信息 `%temp%\kms.ato`
### 恢复未激活状态
- 进入`kms.bat`选择`3`
- 等待完成卸载!!!
## 源码
- 项目地址:[iotcat/kms](https://github.com/iotcat/kms)

@ -0,0 +1,107 @@
title: Liverpool 学生公寓条件调研
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
为了更清晰更直观的选择出明年居住的公寓,本文汇总了网络上对各公寓的评价信息,供决策参考。
<!--more-->
[scode type="green"]大家积极在评论区补充哦,评论推荐使用qq邮箱[/scode]
[scode type="yellow"]持续更新中...[/scode]
[scode type="blue"]望大家能够**补充**更多房源,以便调查[/scode]
## Dover Court
+ `步行距离`: 8 min (西北)
+ `google地图`: [Dover Court](https://www.google.com/maps/dir/53.4060943,-2.9635088/dover+court/@53.4073115,-2.9710734,16z/data=!3m1!4b1!4m9!4m8!1m1!4e1!1m5!1m1!1s0x487b2117f02af11d:0xa8248cb9d60eb03d!2m2!1d-2.9700754!2d53.408129)
+ `Official Guide`: [Dover Court](https://www.youtube.com/watch?v=lMyNP1edztE)
+ `优点`: 距Lidl近,安静,管理好,安全,定期有人清洁,social place好,楼下自习室很安静
+ `缺点`: 房间隔音一般,部分房间小,有的地方天花板低
+ `价格`: £155.54 pw (Last Year)
## Horizon Heights
+ `步行距离`: 14 min (西)
+ `google地图`: [Horizon Heights](https://www.google.com/maps/place/Unite+Students+-+Horizon+Heights/@53.4063639,-2.9762904,14.73z/data=!4m5!3m4!1s0x0:0xeb3661ed145a9ca6!8m2!3d53.4068673!4d-2.9785214)
## St Luke's View
+ `步行距离`: 13 min (西南)
+ `google地图`: [St Luke's View](https://www.google.com/maps/place/Unite+Students+-+St+Luke's+View,+Liverpool/@53.4032851,-2.9832055,15.1z/data=!4m5!3m4!1s0x487b2123d300f157:0x7aa4464b82196264!8m2!3d53.4026763!4d-2.975033)
## Apollo Court
+ `步行距离`: 11 min (西北)
+ `同学反映`: 不安静(雷嘉恒)
## Capital Gate
+ `步行距离`: 7 min (西北)
## Grand Central
+ `步行距离`: 12 min (西)
## Philharmonic Court
+ `步行距离`: 12 min (南)
## The Railyard
+ `步行距离`: 9 min (东)
## Myrtle Court
+ `步行距离`: 9 min (东)
## Larch House
+ `步行距离`: 7 min (西)
## IQ
+ `步行距离`: 9 min (西北)
+ 人脉: 老叶,灯泡
## The Arch
+ `步行距离`: 18 min (西南)
## Albert Court
+ `步行距离`: 10 min (北)
## St Andrews Place
+ `步行距离`: 10 min (西南)
## The Ascent
+ `步行距离`: 13 min (西)
## Lee Court
+ `步行距离`: 10 min (北)
## X1 Liverpool One
+ `步行距离`: 18 min (西)
## X1 The Edge
+ `步行距离`: 12 min (西北)
## Cambridge Court
+ `步行距离`: 8 min (南)
+ `google地图`: [Cambridge Court](https://www.google.com/maps/dir/53.4060907,-2.963637/Cambridge+Ct,+Liverpool/@53.4043312,-2.9678762,17z/data=!3m1!4b1!4m9!4m8!1m1!4e1!1m5!1m1!1s0x487b2118d373aed7:0x8824353bb8192424!2m2!1d-2.967738!2d53.4026346)
## Vita Student Liverpool
+ `步行距离`: 21 min (西)

@ -0,0 +1,36 @@
---
title: 自动发邮件API
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
重整自己先前的mail模块,顺便封装了一个API出来,欢迎大家调用~
<!--more-->
## 方法
### 参数(接受GET和POST)
- `to`收信人邮箱地址
- `subject`邮件主题
- `body`邮件内容(建议使用html格式)
- `from`发件人名称
### 请求地址
````
https://api.yimian.xyz/mail
````
### 示例
````
https://api.yimian.xyz/mail/?to=收信邮箱&subject=邮件主题&body=邮件内容&from=发件人名称
````
[scode type="yellow"]如遇到GET传递邮件内容错误,请尝试使用POST[/scode]
### 返回值(json格式)
- 参数`state`::`true`(成功)或`false`(失败)
[scode type="dangerous"]每个IP每天请求上限50个[/scode]

@ -0,0 +1,122 @@
---
title: 总结一下我的代码风格
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
我的代码风格大致有以下几种情况:组织中追随组织领导,公司里老板说的都对,学校里大佬教的都好╮(╯▽╰)╭ 仅其它一些自己的开源小项目则遵循以下风格→_→
<!--more-->
## 关于强迫症
首先说好,
四个空格的Tab缩进大法好!!!
四个空格的Tab缩进大法好!!!
四个空格的Tab缩进大法好!!!
大括号不换行!!!
大括号不换行!!!
大括号不换行!!!
## 关于命名
命名以让别人一眼就能明白为佳,理想中看你的代码就像读一首英语小诗般惬意 ::aru:insidious::
### 常/变量命名
编译器常量全大写,字符间用单下划线连接。如:
````C
#define WIFI_PASSWD 12345
````
变量基本采用小驼峰命名,规则是单词之间直接连接(无需下划线),第一个单词全小写,之后的单词首字母大写。如:
````C++
String usrName = "IoTgod";
````
频繁调用的变量名称不易过长,但却要表意清晰。
要实现这一点,可以尝试部分省略单词中的非首字母元音,如 user 可以简写为 usr,password 可省略为 passwd 或 psswd。但简化后的名字仍需容易辨识。
全局变量使用 g_ 加变量名称命名,如
````C++
global int g_isLightOn = 0;
````
局部静态变量使用 s_ 加变量名称,如
````C++
static int s_errorCounter = 0;
````
常量变量,命名与普通变量一致,如
````C++
const float pi = 3.14159265;
````
### 函数命名
函数命名技巧偷师自大名鼎鼎的[Nginx][1],并在其基础上稍有变动。
基本法则为 *小写标签名+__(双下划线)+小写动词+小写名词()*
名词与名词间用单下滑线链接。
例如:
````php
function db__get_usr_info();
````
其中db意为Database, 提示这个函数属于数据库操作标签,作用是获取用户信息。
如果你不需要标签(比如在一些面向对象的语言中),你可以肆意省略标签。如:
````php
function get_usr_info();
//or
function db::get_usr_info();
````
与变量命名不同,函数命名不必要很短,以表达清楚函数功能为目标
## 关于注释
其实如果能把变量函数命名做好,便不需要什么注释了,但遗憾的是,,我们还是不得不注释。。
### 文件注释
文件注释主要用于声明一些文件功能,分类名,文件名,版权等信息,一个样式如下:
````php
/**
* cookie支持 #文件功能
*
* @category typecho #文件所属的分类
* @package Cookie #文件名称
* @copyright Copyright (c) 2008 Typecho team (http://www.typecho.org) #作者及版权信息
* @license GNU General Public License 2.0 #开源协议
* @version 2.1.1 #版本
*/
````
### 类注释
类注释用于声明类的一些基本信息,如类功能,作者姓名、所属分类、所属文件。例如:
````php
/**
* 数据库支持 #功能说明
*
* @author qining #作者
* @category typecho #所属分类
* @package Cookie #所在文件名称
*/
````
### 函数注释
函数注释在函数前,主要包含函数功能,函数修饰符,其各参数的类型、名称、以及文字说明,返回值的类型及文字说明。
````php
/**
* 获取指定的COOKIE值 #函数功能
*
* @access public #函数修饰符,即函数是否可被外界访问
* @param string key 指定的参数 #参数1,类型为string, 名称为key, 功能描述为 指定的参数
* @param string default 默认的参数 #参数2,类型string,名称default,功能描述 默认的参数
* @return int #返回整形返回值
*/
````
## 一些小细节
- 赋值等号两边要有空格,如``b = c; b = 15;``
[1]: https://nginx.org

@ -0,0 +1,234 @@
---
title: 随机图片API
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
本API基于华为云对象存储,使用华为CDN云加速,全球平均下载速度达10MB/s。API中已收录1100+张二次元图片,20+张Bing壁纸(每日自动抓取),150+张二次元头像,10+张图床上传图片。
<!--more-->
[scode type="red"]本API不承诺**永久**维护,使用前请务必斟酌**使用风险**!![/scode]
## 1 API地址
- `https://api.yimian.xyz/img`
## 2 快速入门
***随机二次元图片***
- `GET/POST /img?type=moe`
- 示例:[https://api.yimian.xyz/img?type=moe](https://api.yimian.xyz/img?type=moe)
***随机Bing壁纸***
- `GET/POST /img?type=wallpaper`
- 示例:[https://api.yimian.xyz/img?type=wallpaper](https://api.yimian.xyz/img?type=wallpaper)
***随机二次元头像***
- `GET/POST /img?type=head`
- 示例:[https://api.yimian.xyz/img?type=head](https://api.yimian.xyz/img?type=head)
***随机图床图片***
- `GET/POST /img?type=imgbed`
- 示例:[https://api.yimian.xyz/img?type=imgbed](https://api.yimian.xyz/img?type=imgbed)
***随机1920x1080尺寸二次元图片***
- `GET/POST /img?type=moe&size=1920x1080`
- 示例:[https://api.yimian.xyz/img?type=moe&size=1920x1080](https://api.yimian.xyz/img?type=moe&size=1920x1080)
## 3 参数列表
名称 | 描述 | 格式 | 示例
:---:| :---: | :---: | :---:
**type** | 图片种类 | `moe`/`wallpaper`/`head`/`imgbed` | `type=moe`
**size** | 根据图片大小筛选 | `??x??`;<br>`*x??`;<br>`*x*`;<br>`??-??x??`;<br>`??-??x??-??`;<br>`??-??x*` | `display=1920x1080`;<br>`display=1920x*`;<br>`display=1920-1950x230-500`;<br>`display=1920-1950x*`;
**range** | 尺寸误差范围 | number | `range=100`
**id** | 根据图片id筛选| number | `id=15`
**path** | 根据路径提取图片| abs path | `path=wallpaper/img_··mal.jpg`
**display** | 是否以网页格式展示 | `true`/`false`(default) | `display=true`
**R18** | 是否显示18禁图片 | `true`/`false`(default) | `R18=true`
## 4 参数详解
### 4.1 type
***二次元(默认)***
- `GET/POST /img?type=moe`
- 图片来源: 呓喵酱的日常收藏(Pivix, Twitter)
- 示例:[https://api.yimian.xyz/img?type=moe](https://api.yimian.xyz/img?type=moe)
***bing每日壁纸***
- `GET/POST /img?type=wallpaper`
- 图片来源: Bing每日壁纸
- 示例:[https://api.yimian.xyz/img?type=moe](https://api.yimian.xyz/img?type=wallpaper)
[scode type="green"]每日自动更新中[/scode]
***二次元头像***
- `GET/POST /img?type=head`
- 图片来源: 从二次元图片中选择性截取
- 示例:[https://api.yimian.xyz/img?type=head](https://api.yimian.xyz/img?type=head)
***呓喵酱图床***
- `GET/POST /img?type=imgbed`
- 图片来源: [呓喵酱图床](https://imgbed.yimian.xyz)
- 示例:[https://api.yimian.xyz/img?type=imgbed](https://api.yimian.xyz/img?type=imgbed)
***こいぬちゃん***
- `GET/POST /img?type=koino`
- 图片来源: @九条だんぼ(Twitter, Pivix, Google)
- 示例:[https://api.yimian.xyz/img?type=koino](https://api.yimian.xyz/img?type=koino)
***EasyVer人机验证***
- `GET/POST /img?type=easyver`
- 图片来源: 呓喵酱优化整理
- 示例:[https://api.yimian.xyz/img?type=easyver](https://api.yimian.xyz/img?type=easyver)
### 4.2 display
如果本参数置为true,则会禁用302跳转,直接返回完整图片编码。本方法**效率极低**,速度很慢,请慎用。
**false(默认)**
- `GET/POST /img?display=false`
- 描述: 302跳转返回图片,建议使用
- 示例:[https://api.yimian.xyz/img?display=false](https://api.yimian.xyz/img?display=false)
**true**
- `GET/POST /img?display=true`
- 描述: 直接返回图片,速度慢
- 示例:[https://api.yimian.xyz/img?display=true](https://api.yimian.xyz/img?display=true)
### 4.3 size
使用本参数限制图片尺寸。本参数支持以下格式:
***??x??***
- `GET/POST /img?size=??x??`
- 描述: 宽度x高度
- 示例:[https://api.yimian.xyz/img?size=1920x1080](https://api.yimian.xyz/img?size=1920x1080)
***??x\****
- `GET/POST /img?size=??x*`
- 描述: 宽度x任意高度
!!!
<li>示例:<a href="https://api.yimian.xyz/img?size=1920x*" target="_blank">https://api.yimian.xyz/img?size=1920x*</a></li>
!!!
***\*x??***
- `GET/POST /img?size=*x??`
- 描述: 任意宽度x高度
!!!
<li>示例:<a href="https://api.yimian.xyz/img?size=*x1080" target="_blank">https://api.yimian.xyz/img?size=*x1080</a></li>
!!!
***\*x\****
- `GET/POST /img?size=*x*`
- 描述: 任意宽度x任意高度(默认)
!!!
<li>示例:<a href="https://api.yimian.xyz/img?size=*x*" target="_blank">https://api.yimian.xyz/img?size=*x*</a></li>
!!!
***??-??x??***
- `GET/POST /img?size=??-??x??`
- 描述: 宽度范围x高度
- 示例:[https://api.yimian.xyz/img?size=1910-1930x1080](https://api.yimian.xyz/img?size=1910-1930x1080)
***??x??-??***
- `GET/POST /img?size=??x??-??`
- 描述: 宽度x高度范围
- 示例:[https://api.yimian.xyz/img?size=1920x1070-1090](https://api.yimian.xyz/img?size=1920x1070-1090)
***??-??x??-??***
- `GET/POST /img?size=??-??x??-??`
- 描述: 宽度范围x高度范围
- 示例:[https://api.yimian.xyz/img?size=1910-1930x1070-1090](https://api.yimian.xyz/img?size=1910-1930x1070-1090)
***??-??x\****
- `GET/POST /img?size=??-??x*`
- 描述: 宽度范围x任意高度
!!!
<li>示例:<a href="https://api.yimian.xyz/img?size=1910-1930x*" target="_blank">https://api.yimian.xyz/img?size=1910-1930x*</a></li>
!!!
***\*x??-??***
- `GET/POST /img?size=*x??-??`
- 描述: 任意宽度x高度范围
!!!
<li>示例:<a href="https://api.yimian.xyz/img?size=*x1070-1090" target="_blank">https://api.yimian.xyz/img?size=*x1070-1090</a></li>
!!!
### 4.4 range
本参数规定允许的size的误差,需搭配size使用,默认为0。
***对于??型size参数***
- `GET/POST /img?size=??x??&range=100`
- 描述: 宽度±100 x 高度±100
- 示例:[https://api.yimian.xyz/img?size=1920x1080&range=100](https://api.yimian.xyz/img?size=1920x1080&range=100)
***对于??-??型size参数***
- `GET/POST /img?size=??-??x??-??&range=100`
- 描述: 最小宽度-100|最大宽度+100 x 最小高度-100|最大高度+100
- 示例:[https://api.yimian.xyz/img?size=1910-1930x1070-1090&range=100](https://api.yimian.xyz/img?size=1910-1930x1070-1090&range=100)
***对于*型size参数***
- `GET/POST /img?size=*x*&range=100`
- 描述: range无效
### 4.5 id
每一个种类都有自己的id系统,同一种类下不同图片id唯一。
***二次元***
- `GET/POST /img?type=moe&id=15`
- 描述:提取id为15的二次元图片
- 示例:[https://api.yimian.xyz/img?type=moe&id=15](https://api.yimian.xyz/img?type=moe&id=15)
***bing每日壁纸***
- `GET/POST /img?type=wallpaper&id=2019-07-28`
- 描述:提取2019-07-28的壁纸图片
- 示例:[https://api.yimian.xyz/img?type=wallpaper&id=2019-07-28](https://api.yimian.xyz/img?type=wallpaper&id=2019-07-28)
***二次元头像***
- `GET/POST /img?type=head&id=15`
- 描述:提取id为15的头像
- 示例:[https://api.yimian.xyz/img?type=head&id=15](https://api.yimian.xyz/img?type=head&id=15)
***呓喵酱图床***
- `GET/POST /img?type=imgbed&id=529745e0`
- 描述:提取id为529745e0的图床图片
- 示例:[https://api.yimian.xyz/img?type=imgbed&id=529745e0](https://api.yimian.xyz/img?type=imgbed&id=529745e0)
### 4.6 path
使用绝对路径直接提取图片,优先级高于type,**效率最高**。
- `GET/POST /img?path=xx/xx.xx`
- 路径格式:`种类/图片文件名`
- 路径格式示例:`imgbed/img_529745e0_900x900_8_null_normal.jpeg`
- 描述:提取在xx/xx.xx的图片
- 示例:[https://api.yimian.xyz/img/?path=imgbed/img_529745e0_900x900_8_null_normal.jpeg](https://api.yimian.xyz/img/?path=imgbed/img_529745e0_900x900_8_null_normal.jpeg)
### 4.7 R18
是否显示18禁图片,默认为false。
- `GET/POST /img?type=xx&R18=true`
- 描述:随机提取xx类别中包含R18内容在内的图片
- 示例:[https://api.yimian.xyz/img/?type=koino&R18=true](https://api.yimian.xyz/img/?type=koino&R18=true)
## 5 报错格式
### 5.1 找不到指定type类型
若找不到指定的type类型,将会自动返回一个moe类型的图片。
### 5.2 找不到符合条件的图片
返回JSON
```js
{
"err": "错误信息"
}
```
[scode type="yellow"]每台设备每天**全局**调用上限500次!![/scode]

@ -0,0 +1,63 @@
title: 在家中部署智慧家庭系统
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
基于Home Assisstant搭建综合家庭照明系统,多媒体系统,水流系统的智慧家庭。技术点:天猫精灵交互,LoRa通信,MQTT协议,frp内网穿透,NAS存储,拨动开关电路改造。
<!--more-->
结合所学知识,运用前沿技术,造福生活,是我长期以来的不懈追求。为了让家人体验到更加稳定、舒适智能的生活方式,同时也为了巩固憨实先前在学校smartfarm项目和我自己的ushio系统中所积累的技术基础以及架构经验,我决定在出国前,使用20到23整天时间,重构家中老旧的物联网系统。采用分层架构和面向接口、面向测试、**面向文档**开发原则,以**稳定性(Available)**,**可靠性(Reliable)**为最优先指标,搭建一个运行目标3年以上的高度模块化的,易于远程操控的,开源的家庭软件硬件智能传感控制系统。
## 0 架构综述
## 1 硬件设计
### 1.1 单片机选材
使用Arduino UNO作为计算单元。一方面,Arduino Uno拥有高可靠性,我之前的智慧窗帘系统使用Arduino Uno作为主控板,平稳运行1年半未出现硬件问题。另一方面,Arduino Uno拥有较大的RAM,无需为了争夺RAM而在单片机编程上煞费苦心。
Arduino UNO的缺陷主要是价格高,但是为保障长期稳定运行,这个成本是必要的。
### 1.2 WiFi通信模块选材
使用ESP-01作为WiFi的通信模块。主要原因是之前学校课程使用过ESP-01搭建遥控小车,对其工作方式和性能比较了解,降低开发成本。
### 1.3 LoRa通信模块选材
使用**安信可 LORA RA-02 LORA**作为LoRa节点和LoRa网关通信模块。原因是surf项目使用的就是这个模块,比较了解它。
### 1.4 智能音箱选材
智能音箱作为此物联网系统人机交互的最主要界面,发挥着举足轻重的作用。经研究,我使用天猫精灵方糖R作为家用智能音箱。一方面,天猫精灵的性价比摆在那里,非常便宜。第二,与小米开发小爱同学不同,阿里开发天猫精灵的目的是提供平台,它运行开发者以各种形式接入其网络,这一点对我至关重要。
### 1.5 灯拨动开关
初期设想: 单向控制+复位器。
实际实现:将原有单开改造为双开,一路与继电器串联,另一路与两个pin口相连。
## 2 通信设计
![网络拓扑图](https://api.yimian.xyz/img/?path=imgbed/img_43b85bd4_1096x660_8_null_normal.png)
采用WiFi+LoRa两种通信模式。在需要高速高质量通信的场景,如天猫精灵,手机,笔记本,使用WiFi作为通信手段。在WiFi信号不稳定的地方,使用LoRa进行通信。
## 3 主控系统设计
使用python3开源项目Home Assistant 为基础搭建本项目的主控系统。
## 4 多媒体系统设计
多媒体主要由天猫精灵提供。此外,通过小米盒子,家庭网盘中的视频,图片,音乐实现了电视与音响上的播放。
## 5 云端支持系统设计
dns.yimian.xyz提供dns解析服务。
## 6 NAS存储系统设计
通过挂载从老电脑上拆卸的闲置500G机械硬盘到老IBM服务器,实现存储系统的搭建。
对局域网内,由于家里都是win系统,使用smb作为共享协议实现文件传输,支持局域网内挂载。速度稳定,全网读写10MB/s左右。对外网访问,通过http,frp反代实现,但速度较慢。

@ -0,0 +1,341 @@
title: 2019 SURF SmartFarming Proj 架构说明
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
本文详细介绍了XJTLU大学2019暑期科研SmartFarming Proj物联网架构的设计思路,实施情况以及缺陷反思。
<!--more-->
## 1 背景
### 1.1 需求
为了探究农业物联网技术的可行性,Alam Mohammed导师希望我们能够提供一个**稳定(Available)**并**可靠(Reliable)**的物联网系统,以实现对农田的智能监控和管理。这个系统将能够适时地探测土壤以及空气中与植物健康相关的参数,处理并存储这些数据(由Alam提出)。同时,自动化控制的灌溉功能(由Caleb提出)以及一些数据展示方法(由Alam提出的可选需求)也被期待由本系统提供。
### 1.2 定位
由于是针对农业物联网设计的小型科研项目,项目的目标是对农业物联网的可行性进行探究,愿景是模拟最普遍的小型农业物联网应用场景。因此本架构的定位是**适用于大部分具备感知,控制和展示功能的小型农业物联网工程**。
## 2 名词解释
> + `MQTT`: MQTT消息队列遥测传输(Message Queuing Telemetry Transport)是ISO 标准(ISO/IEC PRF 20922)下基于发布/订阅范式的消息协议。它工作在 TCP/IP协议族上,是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议[1]。
> + `LoRa`: LoRa是当前市场上的一种新兴技术,其在1 GHz以下的公共频段中运行,用于远距离低功耗通信[2]。
## 3 设计目标
### 3.1 实现功能
本架构功能性需求主要包括土地数据采集,气象数据采集,灌溉系统控制,与无人机小组系统进行交互,网页控制台(可查看实时和历史传感数据,指标数据;能够控制系统)。
### 3.2 性能指标
+ `通信范围(测试)`:半径不低于1km
+ `通信范围(生产)`:半径不低于3km
+ `延时`:平均小于1s
+ `超时率`:不超过5%
+ `资源占用`:节点RAM不超过2k
+ `运行周期`:1分 (测试) | 15分 (生产)
## 4 系统环境
### 4.1 相关软件及硬件
!!!
<table>
<tr>
<td style="vertical-align: middle;text-align: center;"><strong>节点名称</strong></td>
<td style="vertical-align: middle;text-align: center;"><strong>硬件设施</strong></td>
<td style="vertical-align: middle;text-align: center;"><strong>软件集群</strong></td>
</tr>
<tr>
<td rowspan="6" style="vertical-align: middle;text-align: center;">土地节点<br/>Ground Nodes</td>
<td>Arduino Nano</td>
<td>Arduino.h</td>
</tr>
<tr>
<td><a href="https://item.taobao.com/item.htm?spm=a230r.1.14.11.58a54915TdUHKS&id=556174103413&ns=1&abbucket=14#detail">SX1278 LORA模块</a></td>
<td>SPI.h</td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a230r.1.14.20.161f53ed47xg5U&id=41414863412&ns=1&abbucket=10">LM35DZ 温度传感</a></td>
<td><a href="https://github.com/sandeepmistry/arduino-LoRa">LoRa.h</a></td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a1z10.3-b-s.w4011-21581912015.41.6c425535FUUqU7&id=37365775741&rn=b1c1a8a7f17260619669f001aa3241bf&abbucket=14&skuId=4138700612305">土壤湿度传感</a></td>
<td><a href="https://github.com/IoTcat/LoRa-socket">LoRa-Socket.h</a></td>
</tr>
<tr>
<td><a href="https://item.taobao.com/item.htm?spm=a230r.1.14.16.21461532U3rUws&id=541730394024&ns=1&abbucket=14#detail">四分电磁阀</a></td>
<td><a href="https://github.com/IoTcat/LoRa-mqtt">LoRa-mqtt.h</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://github.com/tomstewart89/Vector">vector.h</a></td>
</tr>
<tr>
<td rowspan="7" style="vertical-align: middle;text-align: center;">气象站节点<br/>Air Station</td>
<td>Arduino Nano</td>
<td>Arduino.h</td>
</tr>
<tr>
<td><a href="https://item.taobao.com/item.htm?spm=a230r.1.14.11.58a54915TdUHKS&id=556174103413&ns=1&abbucket=14#detail">SX1278 LORA模块</a></td>
<td>SPI.h</td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a220m.1000858.1000725.1.1b456f1dTRXYJd&id=576191025158&areaId=320500&user_id=738263294&cat_id=2&is_b=1&rn=14dcb16f28668aa5ca15c5be0f88d092">BME280 温度,湿度,大气压强传感</a></td>
<td><a href="https://github.com/sandeepmistry/arduino-LoRa">LoRa.h</a></td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a1z10.3-b-s.w4011-21581912015.32.2fe555358wswJr&id=521238059334&rn=233756c78897999fd97ca2dd4f649071&abbucket=14">GY-30 光强传感</a></td>
<td><a href="https://github.com/IoTcat/LoRa-socket">LoRa-Socket.h</a></td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a1z10.3-b-s.w4011-21581912015.52.23e05535hDDYEB&id=13302081252&rn=ced14f01f4a9179e7b090c544cf5836a&abbucket=14">MQ-135 空气质量传感</a></td>
<td><a href="https://github.com/IoTcat/LoRa-mqtt">LoRa-mqtt.h</a></td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a1z10.3-b-s.w4011-21581912015.52.270b5535itNYUg&id=13673403530&rn=418dfd01fe7ae4ce8b775fc271d9886a&abbucket=14">MQ-7 一氧化碳传感</a></td>
<td><a href="https://github.com/tomstewart89/Vector">vector.h</a></td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a1z10.5-b-s.w4011-21581825912.37.16ca535042HtRT&id=41536690942&rn=a0912ce05addd045044d65bc796797e8&abbucket=14">雨量传感</a></td>
<td></td>
</tr>
<tr>
<td rowspan="8" style="vertical-align: middle;text-align: center;">LoRa 网关<br/>LoRa Gateway</td>
<td><a href="https://item.taobao.com/item.htm?spm=a230r.1.14.58.6c20435c9AhMz2&id=555750159003&ns=1&abbucket=14#detail">SX1278</a></td>
<td>Arduino.h</td>
</tr>
<tr>
<td></td>
<td>SPI.h</td>
</tr>
<tr>
<td></td>
<td>WiFi.h</td>
</tr>
<tr>
<td></td>
<td><a href="https://github.com/sandeepmistry/arduino-LoRa">LoRa.h</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://github.com/IoTcat/LoRa-socket">LoRa-Socket.h</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://github.com/IoTcat/LoRa-mqtt">LoRa-mqtt.h</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://github.com/tomstewart89/Vector">vector.h</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://github.com/knolleary/pubsubclient">PubSubClient.h</a></td>
</tr>
<tr>
<td rowspan="5" style="vertical-align: middle;text-align: center;">内网控制器/MQTT代理<br/>Controler/MQTT Proxy</td>
<td>树莓派3B - RASPBIAN</td>
<td>Python3.7</td>
</tr>
<tr>
<td><a href="https://detail.tmall.com/item.htm?spm=a230r.1.14.9.791b1000Beu0tp&id=555610012670&cm_id=140105335569ed55e27b&abbucket=14">直流变频水泵</a></td>
<td>NodeJS</td>
</tr>
<tr>
<td></td>
<td><a href="https://www.npmjs.com/package/sf-mqtt-proxy">sf-mqtt-proxy@npm</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://www.npmjs.com/package/sf-pump">sf-pump@npm</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://www.npmjs.com/package/forever">forever@npm</a></td>
</tr>
<tr>
<td rowspan="6" style="vertical-align: middle;text-align: center;">云服务器<br/>Cloud Server</td>
<td>华为云主机 - Centos7.4</td>
<td>Nginx/1.12.2</td>
</tr>
<tr>
<td></td>
<td>NodeJS/12.4.0</td>
</tr>
<tr>
<td></td>
<td>Redis/3.2.12</td>
</tr>
<tr>
<td></td>
<td><a href="https://www.npmjs.com/package/sf-mqtt-broker">sf-mqtt-broker@npm</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://www.npmjs.com/package/sf-web-api">sf-web-api@npm</a></td>
</tr>
<tr>
<td></td>
<td><a href="https://www.npmjs.com/package/forever">forever@npm</a></td>
</tr>
<tr>
<td rowspan="1" style="vertical-align: middle;text-align: center;">数据库<br/>Database</td>
<td>华为云数据库</td>
<td>MySQL 5.7.23</td>
</tr>
</table>
!!!
### 4.2 数据规模预估
按照生产场景预估,每15分钟产生一组数据集合,一组数据集合约占用253-291字节。按照291计算,每天将新增27.93KB数据。
## 5 设计思路
### 5.1 理念
- 面向文档
- 面向接口
- 面向测试
### 5.2 关键问题
- 土地节点RAM资源稀缺,只有2K
- LoRa通信采用433MHz,单信道收发,干扰多
- 服务器需要采集聚合来自多节点的散列数据
- 预留与无人机AI小组的交互方法
- 实时消息向前端浏览器推送
### 5.3 方案选择
为了**优先**确保通信以及服务的**稳定性**和**可拓展性**,我们选取**分层模型**作为架构的设计模式。整个系统分成多个层级,层级之间具备必要的交互行为。每个层级都独立运行,崩溃时会迅速重启,具备高度的可靠性。
安全上,采取**内外网隔离**的方法。内网中考虑到部分设备计算资源稀缺,与内网服务器的交互采用不加密的通信模式。内网服务器通过SSL加密的方式与云服务器进行交互。为了确保客户端的资料安全,云服务器API只接受具备SSL加密的HTTP和WebSocket请求。
## 6 架构设计
### 6.1 基础介绍
本架构的主要目的是提供一个**稳定(Available)**并**可靠(Reliable)**的物联网系统,通过采集农田中的实时数据,结合通过无人机采集的图片以及CNN判断的植物健康情况,实现对灌溉系统以及植物健康状况的智能管理。本架构理论上适用于大部分农场环境。测试环境半径2~5km(取决于天线)以内,风力3级以下。本系统通过传感器获取农田数据,通过晶体管电路,继电器等控制灌溉系统,通过网页与API与管理者进行交互。
### 6.2 系统层级图
![Smart Farm 系统分层结构图](https://api.yimian.xyz/img/?path=imgbed/img_c46f5639_577x906_8_null_normal.jpeg)
此图展示了此架构的抽象层级结构。正如其所指出的,此分层架构可明确为**感知层**,**网络层**,**应用层**三个横向操作层以及一个纵向**错误处理层**。
其中,**感知层**又可细化为**环境层**以及**硬件层**。环境层中包含植物,土壤,空气,水流等我们要检测和控制的自然物体,硬件层通过传感器、控制器等人造电气设备为系统对自然要素的交互行为(检测,控制)提供了底层技术可行性。当感知层实现对自然信息的交互后,相应的数字信息被传往网络层进行通信。相应的,感知层也会从网络层接受相应的控制信息,并根据这些指令做出相应的控制行为。
**网络层**分为三层。其中最低一层为**预处理层**,它的主要任务是对感知层采集的数据进行打包处理,转变成网络流通所适合的形式,如套接字。因此,预处理层需要少量的计算存储资源,比如单片机,EEPROM等。经过预处理层的封装后,数据被传往**物理层**。基于物理层中的网关、路由器等设备,这些数据包得以被有秩序的分发和传递。**通信层**中的MQTT协议的应用,使得这些数据包分发的管理更加高效与便利。此外,通信层中QoS服务质量检测体系的实施也使得网络层的性能更加的容错和可靠。
**应用层**主要负责一些应用层面的服务于业务逻辑,比如数据分析,事件处理等。在应用层的最底端,**服务层**在长期的运转着。服务层是应用层中最近接网络层的部分,它的主要目的是实时处理从网络层传入的数据,并对相应的请求及错误事件进行快速响应。同时,服务层也负责将传感器采集的数据进行整理分析并传递到**数据库**层进行存储。为了保证服务的可靠性,服务层的实现程序被注册为系统服务并由专门的守护进程进行守护。与服务层的长期运行不同,**业务层**则是按需唤起。当界面层有新的请求传入或服务层发生特定的事件时,业务层将会被调用并处理它们。除了一些基础的数据分析外,业务层也有权限向AI层进行分析请求。**AI层**通过分析从无人机传回的图像数据后,会传回一个判断结果给业务层。根据请求的具体内容,业务层会将图像识别结果,历史传感器数据等进行整理,并传递到界面层。**界面层**则主要用来提供不同形式的接口,比如HTTP接口和WebSocket接口,以方便客户端调用。
### 6.3 系统拓扑图
![Smart Farm 系统拓扑图](https://api.yimian.xyz/img/?path=imgbed/img_27df1756_1426x710_8_null_normal.png)
从拓扑结构来看,如上图所示,整个系统物理上可划分为土地节点,气象节点,LoRa网关,内网服务器,云服务器,数据库和用户终端。
从功能机制上看,整个系统包含:传感器模块,LoRa通信模块,LoRa网关模块,MQTT-Proxy代理模块,水泵控制模块,MQTT+数据处理模块,web接口模块,守护进程模块和数据库模块。
***土地节点***
土地节点部署于不同区域的农田中,用于探测土壤温度,湿度参数,并能够提供对相应位置水流电磁阀的控制。土地节点使用Arduino Nano作为计算单元,使用LoRa作为通信方式连接LoRa网关(和其它节点),使用电池供电。其数量较多,工作环境恶劣,无线通信不稳定,是系统中最大的不确定性来源。
***气象节点***
气象节点部署于农田特定位置,用于探测空气温度,湿度,大气压,降雨量,光照,NH3浓度,CO浓度等气象参数。气象节点使用Arduino Nano作为计算单元,使用LoRa作为通信方式连接LoRa网关(和土地节点),使用电池或有线供电。其工作环境较为恶劣,无线通信质量一般。
***LoRa网关***
LoRa网关部署于室内,为扩大有效通信半径,其天线可延伸至室外。LoRa网关通过LoRa连接各土地节点和气象节点,通过WiFi连接内网服务器。LoRa网关能够将通过LoRa传入的socket包转换为mqtt消息并传递给内网服务器,以及将内网服务器传来的mqtt消息转换为socket包通过LoRa发送至指定节点。
***内网服务器***
内网服务器是一个树莓派3B,它包含三个功能模块:MQTT-Proxy代理模块,水泵控制模块以及守护进程模块。
*MQTT-Proxy代理模块*能够接收由LoRa网关通过WiFi发送的mqtt消息,对其进行SSL加密并转发至云服务器。同时,MQTT-Proxy代理模块也将接受指定的来自云服务器的mqtt消息,将其解密并转发至LoRa网关。
*水泵控制模块*通过树莓派的GPIO通过继电器控制水泵的状态。与水泵控制模块直接与云服务器进行mqtt通信,不经过MQTT-Proxy代理。
*守护进程模块*运行在Linux上,用于监视MQTT-Proxy代理模块和水泵控制模块。当探测到模块停止运行时,守护进程模块会及时重启这些模块,以确保服务的稳定性和连续性。
***云服务器***
云服务器运行在位于北京的华为云上,包含MQTT+数据处理模块,web接口模块和守护进程模块。
*MQTT+数据处理模块*包含了层级结构中的Service层和Business层。这个模块通过mqtt与内网进行通信,通过mqtt, redis与web接口模块(和AI模块)进行交互。当收到来自内网的各种散列的数据后,本模块会自动对它们进行聚合,整理成一条一条的数据,存入数据库,并通过redis推送给web接口模块。此外,本模块会定时向各节点发送请求以获取它们的数据,这些请求将被追踪以计算延时。
*web接口模块*提供一系列的HTTP和WebSocket接口。这些接口可用于获取数据,发送指令,刷新数据以及获取推送消息。
*守护进程模块*运行在Linux上,用于监视MQTT+数据处理模块和web接口模块。当探测到模块停止运行时,守护进程模块会及时重启这些模块,以确保服务的稳定性和连续性。
## 7 模块说明
### 7.1 LoRa通信模块
LoRa通信模块用于在单信道情况下实现稳定可靠的socket通信。本模块包含LoRa-socket和LoRa-mqtt。
LoRa-socket是在LoRa-Arduino的基础上进行了数据包的封装,实现了简单的udp和tcp通信,让传统的LoRa通信更加可靠。通过在数据包的head添加收发ip地址,以及在数据包的最后添加hash校验值,LoRa-socket支持点对点通信和广播通信,并且具有强大的噪音处理能力和数据防篡改能力。
***项目地址***:[iotcat/LoRa-socket](https://github.com/IoTcat/LoRa-socket)
LoRa-mqtt是在LoRa-socket基础上对mqtt协议进行的一个简单再现。基于udp和tcp,LoRa-mqtt支持qos为0和1的mqtt通信。
***项目地址***:[iotcat/LoRa-mqtt](https://github.com/IoTcat/LoRa-mqtt)
### 7.2 MQTT-Proxy代理模块
本模块运行在内网服务器,实现了对内网mqtt的加密转发。
***项目地址***:[iotcat/sf-mqtt-proxy](https://www.npmjs.com/package/sf-mqtt-broker)
### 7.3 水泵控制模块
本模块运行在内网服务器,实现了通过GPIO对继电器水泵的控制。
***项目地址***:[iotcat/sf-pump](https://www.npmjs.com/package/sf-pump)
### 7.4 mqtt+数据处理模块
本模块运行在云服务器,实现了对来自底层mqtt消息的数据聚合,处理和存储。
***项目地址***:[iotcat/sf-mqtt-broker](https://www.npmjs.com/package/sf-mqtt-broker)
### 7.5 web接口模块
本模块运行在云服务器,实现了功能性接口的提供。
***项目地址***:[iotcat/sf-web-api](https://www.npmjs.com/package/sf-web-api)
## 8 开发文档
### 8.1 mqtt主题
- [mqtt主题列表](https://doc.smartfarm.yimian.xyz/#/home?id=mqtt)
### 8.2 http接口
- [http接口文档](https://doc.smartfarm.yimian.xyz/#/home?id=api-http)
### 8.3 websocket接口
- [websocket接口文档](https://doc.smartfarm.yimian.xyz/#/home?id=api-websocket)
## 9 运行状态
### 9.1 系统延时
![qos](https://api.yimian.xyz/img/?path=imgbed/img_b36d5030_1806x546_8_null_normal.png)
上图展示了土地节点(左),气象节点(右),水泵(下)的延时统计折线图。由图可以看出,土地节点的平均延时在730ms左右,气象节点延时在900ms左右,水泵的延时较低,在45ms左右。
### 9.2 传感器数据
[点击这里查看2019-7-31的气象传感器数据](https://smartfarm.yimian.xyz/chart-station.html?f=1564484461&t=1564570861)
<br>
-------------------------------
**Reference List:**
[1] OASIS, (2015,12.10). MQTT Version 3.1.1 Plus Errata 01 [Online]. Available: https://docs.oasis-open.org/mqtt/mqtt/v3.1.1/errata01/os/mqtt-v3.1.1-errata01-os-complete.html
[2] Sinha, R.S., Wei, Y. and Hwang, S.H., "A survey on LPWA technology: LoRa and NB-IoT", in Ict Express, 3(1), pp.14-21, 2017.

@ -0,0 +1,108 @@
---
title: Centos7下 Nginx 配置ssl证书自动续期
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
断断续续玩web已经一年了,一些之前从腾讯云申的TrustAsia证书已经陆陆续续开始过期,很方..于是开始尝试申请Let's Encrypt的免费证书,并实现自动续期|´・ω・)ノ
<!--more-->
## 前提条件
- 必须是Centos7系统,其它未测试,不保证有效
- 有自己的域名
- 确认dns已将域名指向服务器
- 防火墙放行80与443端口
- 已配置好nginx代理,并``可以通过http访问域名``(一定确定能访问)
## 安装certbot
通过yum安装certbot
````
$ yum update #更新yum源
$ yum install -y epel-release #安装epel源
$ yum install -y certbot #安装certbot
````
## 初次申领证书
### 初次申领某域名证书
格式为
````
$ certbot certonly --webroot -w [Web站点目录] -d [站点域名] -m [联系人email地址] --agree-tos
````
例如
````
$ certbot certonly --webroot -w /opt/www/demo.yourdomain.com -d demo.yourdomain.com -m yourname@gmail.com --agree-tos
````
### 证书位置
证书存放在``/etc/letsencrypt/live/demo.yourdomain.com/``文件夹中。
一共有4个文件,你可能要用到的是`fullchain.pem`和`privkey.pem`。
### 配置nginx
在相应的``server{}``中加入以下内容:
````
listen 443 ssl;
ssl_certificate /etc/letsencrypt/live/demo.yourdomain.com/fullchain.pem; #2
ssl_certificate_key /etc/letsencrypt/live/demo.yourdomain.com/privkey.pem; #3
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
error_page 404 = /404.php;
````
例如
````
server {
listen 443 ssl;
listen 80;
server_name demo.yourdomain.com; #1
root /opt/www/demo.yourdomain.com;
index index.html;
client_max_body_size 1000M;
ssl_certificate /etc/letsencrypt/live/demo.yourdomain.com/fullchain.pem; #2
ssl_certificate_key /etc/letsencrypt/live/demo.yourdomain.com/privkey.pem; #3
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
error_page 404 = /404.html;
}
````
配置成功后执行如下指令:
````
$ nginx -t #检查nginx conf语法
$ systemctl restart nginx #重启nginx
````
## 配置自动续期
编辑crontab规则:([初次配置crontab][1])
````
$ crontab -e
````
键入以下内容(每月1号5时刷新证书并重启nginx)保存并退出
````
00 05 01 * * /usr/bin/certbot renew --quiet && /bin/systemctl restart nginx
````
重启crontab
````
$ systemctl restart crond.service
````
-------------------
参考链接:
[https://blog.csdn.net/sheng119/article/details/72956717][2]
[1]: https://www.cnblogs.com/p0st/p/9482167.html
[2]: https://blog.csdn.net/sheng119/article/details/72956717

@ -0,0 +1,27 @@
title: 中美贸易战-解
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
中美贸易战的解不在美国,而是在我们自己身上。
<!--more-->
关于谈判,党内争议比较大,但最终很有可能会拒绝做出让步。
当美关税抬升,国内相关产业链将大批转移至台湾及东南亚国家,累计将造成1亿人口的就业问题。与前几次的危机不同,这一次我们不但要提防房市泡沫的激化,也没有那麽多的基建可提供就业。从另一方面看,近几年来,中国的产能过剩问题主要通过出口得以解决,拿着贸易顺差来发展国内经济,以实现不可思议的经济增长。如今特朗普政府征加关税,将使得这一策略不再行得通。
如果在谈判中妥协,中方将丧失好不容易占来的第四次工业革命先机,并经济将会想日本,韩国一样任人摆布。
我认为,在不妥协的前提下,中共有三个破局之法。
1. 武统台湾
这个需要看明年台湾大选,是否能找到正当的武统理由。但的确有助于缓解国内社会焦点问题。
2. 房市改革
可能性极大,把泡沫危机转变成创造就业机会的资本。
3. 游戏
将社会上的过剩劳动力转移进游戏产业空转,以缓解社会矛盾的形成。
为了缓解失业冲击的强度,央行将通过印人民币使人民币贬值来增进出口,吸引他国来补充美资撤离的空缺。
以上。。

@ -0,0 +1,43 @@
title: 旅行支票兑换攻略
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
之前去欧洲旅游办签证,由于没有三个月的银行流水,不得已购买了旅行支票作为资金证明。可是到了欧洲才发现旅行支票很难使用,如果不了解行情会被骗收15%-20%的手续费。这篇Blog记录了我们发现的兑换旅行支票的坑和Tips!
<!--more-->
[scode type="info"]**经验一**: 尽可能**不使用**旅行支票[/scode]
[scode type="info"]**经验二**: 旅支兑换**最低手续费**在4%左右[/scode]
> 若不想看经历,可直接调至文末兑换旅行支票的Tips处哦!
## 我的经历
圣诞假和室友一行四人一起DIY游欧洲,去了意大利和奥地利两个国家,共5个城市。由于英国的银行卡还没有使用到三个月,无法通过打印流水来办签证,我们选择了另一种方法—购买American Express的欧元的旅行支票。殊不知啊,兑换和使用旅行支票真真是一个大坑。
最开始据旅行支票的官网上所说,欧洲很多城市的店铺里都能直接使用旅行支票,照这样来说,旅游时花掉它肯定比回英国后把它换回英镑划算的多(换回英镑的过程需要损失8%)。然鹅,出发前我们通过看他人的游记发现,欧洲现在很多店都无法直接花旅行支票(按我们后来实际旅行情况来看,只在威尼斯的好几家店看到了旅行支票的标识),于是我们决定去了就在机场红色标识的Change那里将它们全数换成欧元。
![Change](https://api.yimian.xyz/img/?path=imgbed/img_6ae04a26_721x412_8_null_normal.png)
可到了第一站罗马找到了红色的Change后(如图),却发现700欧元只能给我们590多欧元。这可真的亏的不是一丁半点儿。我对象现场查到了American Express的电话,打过去发现人家现在在意大利没有设点,不过对方建议去银行换,说是可以毫无亏损(注意这也是个坑,,,)。由于有两人已经换了,为了止损,我们决定先不换剩下两人的700欧旅行支票,留着去银行换。
到了第三天,我们去了梵蒂冈那块儿玩,顺便去了附近American Express工作人员推荐的银行,还给中国银行打电话,结果均被告知不接受旅支。这可咋整?
这时刚好发现梵蒂冈周围有一堆change,于是又去问了问报价。其中有一家本来只报590多的,听见我们说另一家给了610多的价,说他们能给我们一个student discount,然后还算了算,报了个640。这下可好,我们开始发现这里面的门道了:其实哪有什么折扣,不过想找个借口吸引你罢了。这些change都是盈利性质的,你把旅支给了他们,他们再通过自己的途径卖给别的地方的American Express,中间可能有一点税收,但只要他们以比扣掉税收低的价格从你这里买下,他就一定能赚(一般还赚不少),不过是多赚点少赚点的区别罢了。而且当地有好几家change,我们主要发现了红色change标识的一家和蓝色的一家。若这家嫌你要求高不接受,那钱就让别家赚了呗。
所以这种时候,我们要想拿到高点的报价,就要掐准人家能接受的度(真的逼太狠了断了人家财路那就没辙了呀),然后通过让他们产生危机意识而提高报价。可以先问个几家,看他们一般会给多少,然后跟他说,别家给我了一个多少的价格。接下来这人可能就会开始打电话给上面的看能给个什么更高的价,叭叭一堆后给你一个略高一点的价格哈哈,你如果不太满意,可以再去找一家问问(不过要注意,如果是同一家的不同店面,要稍微注意点,毕竟他们上面的人可能是一个,说不定就记住你了)。一般来说,大致估估,如果说税可能是百分之二或三,那你起码还是得让人赚个20或30磅(当然你想试试再砍砍也可以,但可能难度会更大)。
于是我们最后两笔分别换的是640欧和645欧(645欧换了一家用类似方法换到的)。
## Tips
- 现在意大利可用旅支消费的地方真不太多,我们去的罗马,佛罗伦萨,威尼斯中,只有威尼斯有几家;
- 去意大利想兑换欧元旅支,只能在标有change牌子的地方换(当然有的change是不接受旅支的,但很少)。American Express的直接兑换点,至少在意大利应该是没有了,所以没法无损失地换。但意大利的change的确不少,梵蒂冈附近就尤其多;
- 不要遇见一家,他报个很低的价你就接受了,也不要太信他的话,要知道这很可能是在坑你不清楚内情;
- 可以先问个两家,了解一下情况。大致估估如果说税可能是百分之二或三,那你起码还是得让人赚个20或30磅,先问问他们的报价,你可以把这个价格说成别家给你的价,去问他们能不能给你高点的价格。当然如果你脸皮薄不好意思胡扯,也可以就只是在这家价格比别家低的情况下把别家价格拿出来激激他们。
## 总结
以上就是所有关于旅支兑换的一些个人经历和小tips啦,当然这只是结合我们的个人体会总结的一些东西,还是要结合具体情况分析了。出去游玩肯定主要还是想多走走看看感受下,所以在经济条件允许的状况下也不建议大家在这件事上浪费太多时间,只要你自己觉得差不多能接受就行了。最后,还是想说,去意大利玩能不用旅行支票就还是别用了,毕竟真的挺麻烦还处处是坑!

@ -0,0 +1,45 @@
---
title: Two Fundamental Demands of Human Beings
date: 2020-06-16 15:43:54
categories:
- thoughts
tags:
---
人类的需求可以总结为两类,创造需求的需求,与解决需求的需求。
<!--more-->
## 历史缘由
在过去的几亿年中,由于生存资源的稀缺,自然界不断通过“物竞天择,适者生存”的法则筛选物种。这使得“一切为了生存”成为了几乎所有物种的“目标函数”。在众多存活下来的物种中,只有人类创造并有效利用了语言这一工具。语言使得人类能够进行更加复杂的推理思维(想象)以及更加有效的个体间信息交流。得益于语言,人类机智地通过预测潜在的自然选择要求提前准备必要的生存资源并建立了协调资源创造(分工)与资源分配的有效体制(市场,贸易)。不可避免地,基于“一切为了生存”这一习惯以及想象与预测这一种能力,人类形成了自主创造需求以及解决需求的行为模式,由此产生了两种基本行为动机,即创造需求的需求与解决需求的需求。
## 理论验证
观察现有人类社会架构,无论社会群体形态是政府,社会组织还是企业(公司),其本质都是一个协调不同人类创造需求的需求与解决需求的需求的闭环生态中的一环。如果一个政府,社会组织或企业无法再继续充当好一个协调人类需求中的闭环生态的一个环节,它将迅速的被其它能更高效发挥其角色的同类或非同类社会群体替代掉。
马云是一位伟大的企业家与战略家,他一手缔造的淘宝电商平台与移动快捷支付使得人们创造需求的需求与解决需求的需求的协调变得更加高效。这使阿里巴巴获得了极大的群众的信任,表现出来就是阿里具备的极高的资源支配权,也就是其极高的市值。
## 理论预测
当人类内部的资源因为某种原因(生产或流通环节出问题)不足以支持所有人的生存时,多余出的人类数量总会以某种形式被抹掉,也就是著名的马尔萨斯陷阱。当一个国家或民族自身遭遇马尔萨斯陷阱时,它总会选择向外发动战争来解决。因为既然要抹掉的人口数量是相对固定的,那么如果向外发动战争就会有更多的本族或本国人能够活下来,只是要将部分的死亡转移至外邦人口。古时的匈奴,二战的德国和日本都是非常典型的例子。
观察历史上的战争,有两次规模很大,我们称之为第一,二次世界大战。第一次世界大战是由于大批量机器取代人力,使得大量原有人力劳动力需要转移。但是劳动力太多没办法短时间转移,表现出来就是失业率飞涨,太多的人无所事事,没有收入,难以生存。为了防止这部分劳动力失控闹事,只得转移其注意力向外发动战争。这就是协调人创造需求的需求与满足需求的需求的市场体制出问题所导致的资源流通停滞所导致的。二战亦是如此,当电力驱动将以往的蒸汽驱动取代,大量劳动力亟需转型。1933年美国率先出现此类问题,罗斯福政府因为有多年发展积累下来的资本,因此可以通过新政建设大量民用设置强行修正资源流通生态链。但是刚因为一战被洗劫一空的德国和国土狭小资源稀缺的日本就没这么幸运了,只得将自身不可避免的马尔萨斯陷阱向犹太人和东亚转移。
如今计算技术充分发展,出现了可以通过建立多项式来fit自然复杂函数(自然规律)的人工智能算法。这就使得大多数非创造型的脑力劳动具备被取代的趋势。那么,这部分原脑力劳动力将何去何从?尤其是在中国和印度这种人口大国,一旦劳动力转型过渡不好,产生的马尔萨斯陷阱代价都将是巨大的,并最终总会由全球承担。
我的想法是,得益于数字技术的发展,如果如今的我们能够创造出一个能够协调人们创造需求的需求与解决需求的需求的闭环生态系统呢?如果当脑力劳动力被替代时这些原有劳动力能够迅速进入并适应我们创立好的闭环生态系统呢?也许我们便能够避开可怕的马尔萨斯陷阱了。
经过几千年文明的发展,当代人类已经不再满足于单单解决自然界所需要的要求,而开始尝试并创造一些非常炫酷有意思但并不怎么有利于生存的需求。也就是说,我们并不在需要所有的人类都要努力工作来确保人类能够生存,我们可以空余出好大一部分人类来探索一些新的有意思的领域。
一个可能的想法是,沉浸型网络游戏。这种网络游戏不同于现有的大部分网络游戏。现有的游戏的商业模式大都是通过程序上限制用户的部分功能体验,只用交了钱的用户才能够使用这些功能。但是我所设想的游戏更像一个平台,玩家可以从中提出自己创造的(游戏中的)需求也可以解决其他人的需求(即交易)。这就意味着一个游戏中可以出现虚拟货币,并且游戏的公众认可度会通过游戏货币与现实货币的汇率得以体现。游戏的开发者将通过开源社区而非企业进行开发,这就意味着开发者与游戏一定程度上非利益相关,从而确保了游戏的纯洁与高效,使之可能具备成为社会基础架构形式的潜能。
游戏的低门槛性并且游戏符合脑力工作者的思维习惯,使脑力劳动力能够比较轻易的从原有职业转移至相应的沉浸式游戏中。并且,由于是虚拟化技术,游戏有充分的弹性容纳大量新增的人们。不同与现在,届时社会舆论与社会思维也将会掀起一股以转入游戏为荣的热潮,以规避危害更大的战争。
有点类似于编程中的函数封装观点,现实社会类似于main函数,各个浸入式网络游戏类似于子函数。现在的社会就像是一个只有main函数的程序,所有的功能都在main函数中实现。这就使得当程序功能越复杂,越有可能发生各种bug,表现出来就是冲突甚至战争。而未来的社会更像是包含好多子函数(沉浸式游戏)的main函数。各个函数都是相互独立而又相互依赖的,每个游戏可以协调好自己的闭环生态,同时又与main函数发生部分交互。这样的社会架构将会变的去中心化并且看上去更加稳定与高效。
-----------------
注:部分想法启发自[知乎][1]
[1]: https://www.zhihu.com/

@ -0,0 +1,446 @@
title: wIoT - 轻松物联
date: 2020-06-16 15:43:54
categories:
- tech
tags:
---
基于NodeJS搭建的物联网系统,配合D1 MINI单片机,帮助你灰常快速实现物联~
<!--more-->
[scode type="green"]正式开发文档见[**这里**](https://wiot.eee.dog)[/scode]
## wIoT for NodeJS
适用于NodeJS的wIoT服务器控制组件,轻松物联
## 先觉条件
- 拥有烧录好[wIoT固件](https://wiot.yimian.xyz/ota/get.php)的**D1 MINI**单片机
- 一台或多台无线WiFi路由器2.4G/5G
- 局域网内拥有一台装有**NodeJS**的服务器或电脑 (NodeJS装法非常简单, 请自行Google或百度)
- 配置好**npm**
## 快速开始
### 单片机接入
1. 使用MicroUSB, 5V, 或3V pin脚给单片机供电
2. 用一根导线连接D0脚与3V3脚,持续一秒以上拔出,以重置单片机
3. 用手机或电脑搜索它的WiFi热点,名称格式`wiot-xx:xx:xx:xx:xx:xx`
4. 连接上此热点,密码为`1234567890`
5. 用浏览器打开网址`http://192.168.0.1`,记录网页中的MAC地址,这将用于识别此单片机
6. 配置你无线路由器的ssid(即wifi名称,注意不能有非ASCII字符,比如汉字)和密码
7. 配置完成后热点将自动断开,单片机将连接到你的无线路由器
### 依赖安装
在你的项目文件夹下打开命令行,输入以下指令安装wiot:
````shell
$ npm install wiot
````
### 使用方法
在你的项目文件夹中新建一个app.js文件,输入以下内容:
```js
var wiot = require('wiot'); //引入wiot依赖包
// 新建一个单片机对象
// 这里使用了两个参数,MAC是单片机的MAC地址,pin中指定需要OUTPUT输出的端口
// 请自行修改MAC地址的值
var MyMCU = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx", pin: {D4: wiot.OUTPUT}});
// 以下代码将实现,板载led亮1秒,灭1秒的循环
// 等待所有单品即准备就绪
wiot.begin([MyMCU], ()=>{ // 第一个参数为要等待的单片机对象数组,第二个参数为要执行的函数
// 设置计时器,每隔2000毫秒, MyMCU的3号pin口将拉高一次电平
setInterval(()=>{
MyMCU.write(wiot.D4, wiot.HIGH);
}, 2000);
// 设置计时器,延时1000毫秒后开始执行大括号中指令
setTimeout(()=>{
// 设置计时器,每隔2000毫秒,MyMCU的3号pin口将拉低一次电平
setInterval(()=>{
MyMCU.write(wiot.D4, wiot.LOW);
}, 2000);
}, 1000);
});
```
### 开始执行
在项目文件夹中打开命令行,输入以下指令:
````shell
node app.js
````
### 预期结果
如果一切顺利,你现在应该会发现你的板载led在闪烁了
### 社区支持
也许你会觉得上述代码难以理解,这是正常的,由于delay功能在JS中难以实现。但是不用担心,这些问题将会由社区中的其它开发者帮你解决。
wIoT在实现基本的单片机控制同时,也提供了丰富的[扩展功能](#传感器扩展模块)。更神奇的是,任何人都可以在wIoT中编写自己的扩展并与全世界共享它们。在这里我们可以使用wIoT官方提供的led扩展轻松实现上例功能!
```js
var wiot = require('wiot'); //引入wiot依赖包
// 新建一个单片机对象
var MyMCU = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx", pin: {D4: wiot.OUTPUT}});
// 新建一个led模块
var led = new wiot.led(MyMCU, wiot.D4);
// 以下代码将实现,板载led亮1秒,灭1秒的循环
// 等待所有单品即准备就绪
wiot.begin([MyMCU], ()=>{
// 调用led模块构建亮1秒灭1秒的动作
led.set([wiot.HIGH, wiot.LOW], [1000, 1000]);
});
```
## 进阶设置
### wiot.client
#### 参数说明
名称 | 默认值 | 描述
----|-------|----
MAC | "" | 单片机的MAC地址
pin | {D1: 0, D2: 0, D3: 0, D4: 0, D5: 0, D6: 0, D7: 0, D8: 0} | pin脚的模式, 0为INPUT, 1为OUTPUT, 2为INPUT_PULLUP
hint | true | 是否显示状态提示
debug | false | 是否开启debug模式
ip | "default" | 指定单片机IP, 请在长时间搜索不到IP时尝试此选项
port | 8848 | Client的TCP Socket通信端口,默认8848
ip_range | "192.168.0" | IP搜索字段,请在长时间搜索不到IP时尝试此选项
localIP | "127.0.0.1" | 本机IP
OnlyHTTP | false | 是否仅使用HTTP模式连接单片机
errDelayTime | 2000 | 遇到网络错误时重试间隔时间(毫秒)
okDelayTime | 30 | 收到网络请求后延时等待时间(毫秒)
resetDelayTime | 4500 | 向单片机发送重置指令后多久不再发送新消息(毫秒)
noTryMaxTime | 15000 | 经过此时间单片机仍未响应则重新发送消息(毫秒)
IntervalTime | 2000 | 监听行为心跳间隔
MaxToReScanTime | 180000 | 经过此事件单片机无响应则从新扫描IP地址(毫秒)
MinResearchTime | 5000 | 搜索IP经过一此轮询后间隔时间(毫秒)
IpScanTimeout | 1 | IP扫描时的Ping检测超时时间(秒)
pingTimeout | 2 | 心跳Ping检测的超时时间(秒)
MaxTraceBackTimes | 8 | 判断连接状态所向前追溯的历史心跳个数
例如:
```js
var MyMCU = new wiot.client({
MAC: "xx:xx:xx:xx:xx:xx",
pin: {
D1: 0,
D2: 0,
D3: 1,
D4: 1,
D5: 0,
D6: 1,
D7: 0,
D8: 0
},
hint: true,
debug: false,
ip: "192.168.0.55",
port: 6666,
ip_range: "192.168.0",
localIP: "127.0.0.1",
errDelayTime: 2000,
okDelayTime: 30,
resetDelayTime: 4500,
noTryMaxTime: 15000,
IntervalTime: 2000,
MaxToReScanTime: 180000,
MinResearchTime: 5000,
IpScanTimeOut: 1,
pingTimeout: 2,
MaxTraceBackTimes: 8
});
```
#### 方法列表
+ `.write(pin: wiot.pin/number, state: iot.state/number)`: 向指定pin口输出状态指令,状态可以是wiot.HIGH/wiot.LOW或PWM调制(0-255数字)
+ `wiot.read(pin: wiot.pin/number)`: 读取指定pin口状态,数字pin返回wiot.HIGH/wiot.LOW,模拟pin返回0-1024数值
#### 事件绑定
`.on(event, handler)`
**client事件列表**
- `begin` 开始于单片机正常交互
- `disConnected` 与单片机断开连接
- `reConnected` 与单片机恢复连接
```js
var MCU = new wiot.client({"MAC": "xx:xx:xx:xx:xx:xx"});
MCU.on('disConnected', function () {
// 当与MCU失联时会执行此处指令
console.log('Disconnected with MCU!!');
});
```
`.pinOn(pin, event, handler)`
**pin事件列表**
- `on` pin口电位从低到高
- `off` pin口电位从高到低
- `change` pin口电位变化
```js
var MCU = new wiot.client({"MAC": "xx:xx:xx:xx:xx:xx"});
MCU.pinOn(wiot.D2, 'on', function () {
// 当MCU的D2电位由低到高时会执行
console.log('D2 from LOW to HIGH!!');
});
```
### API
+ `wiot.begin()`: 单片机准备完成后开始执行
```js
MCU0 = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx", pin: {D4: wiot.OUTPUT}});
MCU1 = new wiot.client({MAC: "xx:xx:xx:xx:xx:ww"});
wiot.begin([MCU0, MCU1], ()=>{
//这里放你要执行的指令
//这些指令将会在MCU0和MCU1准备就绪后开始执行
});
```
+ `wiot.loop()`: 循环执行的指令,适合于条件控制语句
```js
MCU0 = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx", pin: {D4: wiot.OUTPUT}});
MCU1 = new wiot.client({MAC: "xx:xx:xx:xx:xx:ww"});
// 以下代码将实现: 当MCU0的D5接收到HIGH,MCU1的D4将会输出HIGH
// 当MCU0的D5接收到LOW, MCU1的D4将会输出LOW
// 本函数接受两个参数: 第一个是MCU对象数组, 第二个是参数为MCU对象数组的函数
wiot.loop([MCU0, MCU1], () => {
if(MCU1.read(wiot.D5) == wiot.HIGH){
MCU0.write(wiot.D4, wiot.HIGH);
}else{
MCU0.write(wiot.D4, wiot.LOW);
}
});
```
### 注册表
+ `wiot.register.set(status1, status2, function)`: 向注册表中添加一条规则, status可以是值或函数,当status1==status2时会触发function。
注册表的设计是为了方便协调各扩展模块的使用,详见下文[扩展模块](#传感器扩展模块)。
+ `wiot.register.set(status, function)`: 你也可以传入两个函数,其中status的返回值是bool型,变为true时触发function
```js
var myLED = wiot.led(MyMCU, wiot.D4);
var pir = wiot.pir(MyMCU, wiot.D2);
//注册一条规则,当pir探测到人时,myLED亮
wiot.register.set(pir.getStatus, wiot.HIGH, ()=>{
myLED.set(wiot.HIGH);
});
//注册一条规则,当人离开时,myLED灭
wiot.register.set(()=>{
return (wiot.LOW == pir.getStatus);
}, ()=>{
myLED.clear();
});
```
## 传感器扩展模块
### LED
+ `wiot.led(MCU, pin)`: 声明一个led模块
+ `wiot.led.getStatus()`: 获取led状态
+ `wiot.led.set(status, time = 0, isSmooth = false)`: 设置led状态,起始状态,中间状态,最终状态,周期
+ `wiot.led.breath(period)`: 设置一个呼吸灯
+ `wiot.led.clear()`: 重置led
```js
MCU0 = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx", pin: {D4: wiot.OUTPUT}});
var myLED = wiot.led(MCU0, wiot.D4); //新建一个led对象,使用MCU0上的D4口
/* 如果myLED不亮,则点亮它 */
if(!myLED.getStatus()){
myLED.set(wiot.HIGH);
}
/* 设置一个周期为2秒的呼吸灯 */
myLED.breath(2000);
/* 设置一个亮三秒,灭四秒的led */
myLED.set([wiot.HIGH, wiot.LOW], [3000, 4000]);
/* 设置一个呼1秒吸3秒的呼吸渐变灯 */
myLED.set([wiot.LOW, wiot.HIGH], [1000, 3000], true);
/* 自定义一个先半亮2秒再全亮3秒再熄灭2秒的led灯 */
myLED.set([100, wiot.HIGH, wiot.LOW], [2000, 3000, 2000]);
/* 熄灭led */
myLED.clear();
```
### PIR 红外人体传感器
+ `wiot.pir(MCU, pin)`: 声明一个PIR模块
+ `wiot.pir.getStatus()`: 获取PIR状态,返回值wiot.HIGH(有人),wiot.LOW(无人)
**事件触发器**
+ `wiot.pir.on(event, handler)`
**事件列表**
- `detected` 探测到人
- `undetected` 人体移动出探测范围
- `change` 状态改变,包括有人到无人和无人到有人
```js
MCU0 = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx"});
var myPIR = wiot.pir(MCU0, wiot.D2); //新建一个pir对象,使用MCU0上的D2口
/* 输出pir状态到控制台 */
console.log(myPIR.getStatus());
/* 当探测到人,打印 "Detected People!" 到控制台 */
myPIR.on("detected", ()=>{
console.log("Detected People!");
});
/* 人移动出探测范围,打印 "No People!!" 到控制台 */
myPIR.on("undetected", ()=>{
console.log("No People!!");
});
/* 当状态改变,执行指令 */
myPIR.on("change", ()=>{
/* 你的指令 */
});
```
### IR 红外循迹/障碍传感器
+ `wiot.ir(MCU, pin)`: 声明一个IR模块,pin可以是模拟或数字端口
+ `wiot.ir.getStatus()`: 获取IR状态,返回值wiot.HIGH(有障碍),wiot.LOW(无障碍),或者0-1024数值(限模拟端口)
**事件触发器**
+ `wiot.ir.on(event, handler)`
**事件列表**
- `detected` 探测到障碍
- `undetected` 障碍消失
- `change` 状态改变
```js
MCU0 = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx"});
var myIR = wiot.ir(MCU0, wiot.D2); //新建一个ir对象,使用MCU0上的D2口
/* 输出ir状态到控制台 */
console.log(myIR.getStatus());
/* 当探测到物体,打印 "Detected Object!" 到控制台 */
myIR.on("detected", ()=>{
console.log("Detected Object!");
});
/* 物体移动出探测范围,打印 "No Object!!" 到控制台 */
myIR.on("undetected", ()=>{
console.log("No Object!!");
});
/* 当状态改变,执行指令 */
myIR.on("change", ()=>{
/* 你的指令 */
});
```
### lightSensor 光敏传感器
+ `wiot.lightSensor(MCU, pin)`: 声明一个lightSensor模块, pin可以是模拟或数字端口
+ `wiot.lightSensor.getStatus()`: 获取lightSensor状态,返回值wiot.HIGH(有光),wiot.LOW(无光),或者0-1024数值(限模拟端口)
**事件触发器**
+ `wiot.light.on(event, handler)`
**事件列表**
- `light` 由暗到明
- `dark` 由明到暗
- `change` 状态改变
```js
MCU0 = new wiot.client({MAC: "xx:xx:xx:xx:xx:xx"});
var myLightSensor = wiot.lightSensor(MCU0, wiot.D1); //新建一个pir对象,使用MCU0上的D2口
/* 输出LightSensor状态到控制台 */
console.log(mylightSensor.getStatus());
/* 当由暗到明,打印 "Light!!!" 到控制台 */
myLightSensor.on("light", ()=>{
console.log("Light!");
});
/* 由明到暗,打印 "Dark!!" 到控制台 */
myLightSensor.on("dark", ()=>{
console.log("Dark!!");
});
/* 当状态改变,执行指令 */
myLightSensor.on("change", ()=>{
/* 你的指令 */
});
```
## 网络扩展模块
### mail 邮件模块
使用本模块向指定邮箱发送邮件。自豪地引用[Yimian API](https://api.yimian.xyz/)构建!
+ `wiot.mail(to, from = "wIoT")`: 声明一个mail模块,参数收件地址,发件人名称
+ `wiot.mail.send(subject, body)`: 发送邮件,需传入主题,邮件内容
```js
var mail = wiot.mail("i@iotcat.me", "wIoT Test");
mail.send("Test", "Test from wiot!!");
```
### guguji 咕咕机模块
使用本模块向指定咕咕机发送消息。咕咕机是一款便携式私人打印机,详见[官网](https://www.memobird.shop/)。使用本模块需要在官网提前申请好自己的开发者ak, 详见[这里](https://api.yimian.xyz/gugu/intro.php)。自豪地引用[Yimian API](https://api.yimian.xyz/)构建!
+ `wiot.guguji(ak, userID, memobirdID)`: 声明一个guguji模块,参数: 开发者ak, 用户id, 咕咕机id
+ `wiot.guguji.send(msg)`: 发送消息,需传入待发送的消息
```js
var gugu = wiot.guguji("9e55121803474371bfa25d20e554b31f", "832598", "b3ee06a8bd9b49e1");
gugu.print("This is from wIoT!!");
```

@ -0,0 +1,6 @@
---
title: archives
date: 2020-06-16 18:16:41
layout: archives
comments: false
---

@ -0,0 +1,6 @@
---
title: categories
layout: categories
date: 2020-06-16 18:09:37
comments: false
---

@ -0,0 +1,18 @@
---
title: 小伙伴们
date: 2020-06-22 12:25:40
comments: true
---
![first-day-of-fall](https://api.yimian.xyz/img/?path=imgbed/img_72abe08_1092x430_8_null_normal.gif)
## 「 小伙伴们 」
> [矢澤にこ](https://blog.ni-co.moe "矢澤にこ") —— ,,,
> [haoziの窝](https://haozi.moe "haoziの窝") —— ,,,
> [番茄树](https://tomatotrees.xyz "番茄树上智慧果") —— 春风又绿番茄树~
-------------------------------

@ -0,0 +1,6 @@
---
title: tags
date: 2020-06-16 18:12:20
layout: tags
comments: false
---

@ -1 +1 @@
Subproject commit d9859f299d85526009b2a745d7603ddd9902b239
Subproject commit 49ef3bd908d6b7e0f3ee8747b5c4e8766ee92fa3
Loading…
Cancel
Save