<!DOCTYPE html>
< html lang = "" >
< head >
< title > EEE.DOG< / title > < meta charset = "UTF-8" / >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge" / >
< meta name = "viewport" content = "width=device-width, initial-scale=1, maximum-scale=1" / >
< meta http-equiv = "Cache-Control" content = "no-transform" / >
< meta http-equiv = "Cache-Control" content = "no-siteapp" / >
< meta name = "theme-color" content = "#f8f5ec" / >
< meta name = "msapplication-navbutton-color" content = "#f8f5ec" >
< meta name = "apple-mobile-web-app-capable" content = "yes" >
< meta name = "apple-mobile-web-app-status-bar-style" content = "#f8f5ec" >
< meta name = "description" content = "跻身世外,随欲而安!- We see what we thought." / > < meta name = "keywords" content = "iotcat,yimian,blog" / > < link rel = "alternate" href = "/atom.xml" title = "EEE.DOG" > < link rel = "shortcut icon" type = "image/x-icon" href = "/favicon.ico?v=1.0.0" / > < script > lang = [ 'zh' , 'en' ] ; < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/ushio-js/ushio-head.min.js" > < / script >
< script > page . proj = 'iotcat/eee.dog-public' ; < / script >
<!-- <link rel="stylesheet" type="text/css" href="https://cdn.yimian.xyz/kayo/lib/iziModal/iziModal.min.css" /> -->
<!-- <link rel="stylesheet" type="text/css" href="https://cdn.yimian.xyz/kayo/lib/iziToast/iziToast.min.css" /> -->
< link rel = "stylesheet" media = "none" onload = "this.media='all'" type = "text/css" href = "https://cdn.yimian.xyz/shaky/shaky.css" >
< link rel = "canonical" href = "https://www.eee.dog/" / >
< link rel = "stylesheet" media = "none" onload = "this.media='all'" type = "text/css" href = "https://cdn.yimian.xyz/kayo/lib/fancybox/jquery.fancybox.css" / > < script type = "text/x-mathjax-config" >
MathJax.Hub.Config({ tex2jax: { inlineMath: [['$','$'], ['\\(','\\)']] } });
< / script >
< script type = "text/javascript" async src = "https://cdn.yimian.xyz/ajax/libs/mathjax/2.7.5/MathJax.js?config=TeX-MML-AM_CHTML" > < / script >
< link rel = "stylesheet" type = "text/css" href = "https://cdn.yimian.xyz/kayo/css/style.css?v=1.0.0" / >
<!-- Global site tag (gtag.js) - Google Analytics -->
< script async src = "https://www.googletagmanager.com/gtag/js?id=UA-169276192-1" data-pjax > < / script >
< script >
pjax_google_analytics = () => {
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'UA-169276192-1');
}
< / script > < script id = "baidu_push" >
(function(){
var bp = document.createElement('script');
var curProtocol = window.location.protocol.split(':')[0];
if (curProtocol === 'https') {
bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
}
else {
bp.src = 'http://push.zhanzhang.baidu.com/push.js';
}
var s = document.getElementsByTagName("script")[0];
s.parentNode.insertBefore(bp, s);
})();
< / script >
< script >
window.config = {"leancloud":"","toc":true,"fancybox":true,"pjax":{"enable":true,"loadingbar":true},"latex":true};
< / script >
< meta name = "generator" content = "Hexo 4.2.1" > < link rel = "alternate" href = "/atom.xml" title = "EEE.DOG" type = "application/atom+xml" >
< / head >
< body > < div id = "mobile-navbar" class = "mobile-navbar" >
< div class = "mobile-header-logo" >
< a href = "/." class = "logo" > EEE.DOG< / a >
< / div >
< div class = "mobile-navbar-icon" >
< span > < / span >
< span > < / span >
< span > < / span >
< / div >
< div class = "loading-bar" >
< div class = "progress" > < / div >
< / div >
< / div >
< nav id = "mobile-menu" class = "mobile-menu slideout-menu" >
< ul class = "mobile-menu-list" > < div id = "mobile-menu-Home" >
< a href = "/" >
< li class = "mobile-menu-item" > < span class = ".en" > Home< / span > < span class = ".zh" > 主页< / span >
< / li >
< / a > < / div > < div id = "mobile-menu-Archives" >
< a href = "/archives/" >
< li class = "mobile-menu-item" > < span class = ".en" > Archives< / span > < span class = ".zh" > 归档< / span >
< / li >
< / a > < / div > < div id = "mobile-menu-Categories" >
< a href = "/categories/" >
< li class = "mobile-menu-item" > < span class = ".en" > Categories< / span > < span class = ".zh" > 分类< / span >
< / li >
< / a > < / div > < div id = "mobile-menu-Projects" >
< a href = "#" >
< li class = "mobile-menu-item" > < span class = ".en" > Projects< / span > < span class = ".zh" > 项目< / span >
< / li >
< / a > < ul class = "sub-menu" style = "display: none;" >
< li >
< a href = "https://fp.js.org/" target = "_blank" rel = "noopener" >
< span class = ".en" > fp< / span > < span class = ".zh" > fp< / span >
< / a >
< / li >
< li >
< a href = "https://wiot.js.org/" target = "_blank" rel = "noopener" >
< span class = ".en" > wIoT< / span > < span class = ".zh" > wIoT< / span >
< / a >
< / li >
< li >
< a href = "https://github.com/iotcat/kms" target = "_blank" rel = "noopener" >
< span class = ".en" > kms< / span > < span class = ".zh" > kms< / span >
< / a >
< / li >
< li >
< a href = "https://ushio.cool/" target = "_blank" rel = "noopener" >
< span class = ".en" > ushio< / span > < span class = ".zh" > Ushio< / span >
< / a >
< / li >
< / ul >
< script > $ ( ' # m o b i l e - m e n u - P r o j e c t s ' ) . c l i c k ( f u n c t i o n ( ) {
$("#mobile-menu-Projects ul").toggle();
})< / script >
< / div > < div id = "mobile-menu-Map" >
< a href = "#" >
< li class = "mobile-menu-item" > < span class = ".en" > Map< / span > < span class = ".zh" > 导航< / span >
< / li >
< / a > < ul class = "sub-menu" style = "display: none;" >
< li >
< a href = "https://api.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > APIs< / span > < span class = ".zh" > 接口< / span >
< / a >
< / li >
< li >
< a href = "https://img.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > Imgs< / span > < span class = ".zh" > 图库< / span >
< / a >
< / li >
< li >
< a href = "/" >
< span class = ".en" > Imgbed< / span > < span class = ".zh" > 图床< / span >
< / a >
< / li >
< li >
< a href = "https://share.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > Fileshare< / span > < span class = ".zh" > 文件分享< / span >
< / a >
< / li >
< li >
< a href = "https://monitor.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > Monitor< / span > < span class = ".zh" > 监控< / span >
< / a >
< / li >
< li >
< a href = "https://acg.watch/" target = "_blank" rel = "noopener" >
< span class = ".en" > ACG.WATCH< / span > < span class = ".zh" > 视频< / span >
< / a >
< / li >
< li >
< a href = "https://onedrive.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > Oneindex< / span > < span class = ".zh" > 网盘< / span >
< / a >
< / li >
< li >
< a href = "https://proxy.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > Proxy< / span > < span class = ".zh" > 下载代理< / span >
< / a >
< / li >
< li >
< a href = "https://shorturl.yimian.xyz/" target = "_blank" rel = "noopener" >
< span class = ".en" > ShortenURL< / span > < span class = ".zh" > 短链< / span >
< / a >
< / li >
< / ul >
< script > $ ( ' # m o b i l e - m e n u - M a p ' ) . c l i c k ( f u n c t i o n ( ) {
$("#mobile-menu-Map ul").toggle();
})< / script >
< / div > < div id = "mobile-menu-About" >
< a href = "#" >
< li class = "mobile-menu-item" > < span class = ".en" > About< / span > < span class = ".zh" > 关于< / span >
< / li >
< / a > < ul class = "sub-menu" style = "display: none;" >
< li >
< a href = "/links/" >
< span class = ".en" > links< / span > < span class = ".zh" > 友链< / span >
< / a >
< / li >
< li >
< a href = "https://iotcat.me/" target = "_blank" rel = "noopener" >
< span class = ".en" > Me< / span > < span class = ".zh" > 关于我< / span >
< / a >
< / li >
< li >
< a href = "https://cv.yimian.xyz/contact.html" target = "_blank" rel = "noopener" >
< span class = ".en" > Contact< / span > < span class = ".zh" > 留言板< / span >
< / a >
< / li >
< / ul >
< script > $ ( ' # m o b i l e - m e n u - A b o u t ' ) . c l i c k ( f u n c t i o n ( ) {
$("#mobile-menu-About ul").toggle();
})< / script >
< / div > < / ul >
< / nav >
< div class = "container" id = "mobile-panel" >
< header id = "header" class = "header" > < div class = "logo-wrapper" >
< a href = "/." class = "logo" > EEE.DOG< / a >
< / div >
< nav class = "site-navbar" > < ul id = "menu" class = "menu" > < li class = "menu-item" >
< a id = "menu-Home" class = "menu-item-link" href = "/" >
< span class = ".en" > Home< / span > < span class = ".zh" > 主页< / span >
< / a >
< / li >
< li class = "menu-item" >
< a id = "menu-Archives" class = "menu-item-link" href = "/archives/" >
< span class = ".en" > Archives< / span > < span class = ".zh" > 归档< / span >
< / a >
< / li >
< li class = "menu-item" >
< a id = "menu-Categories" class = "menu-item-link" href = "/categories/" >
< span class = ".en" > Categories< / span > < span class = ".zh" > 分类< / span >
< / a >
< / li >
< li class = "menu-item" >
< a id = "menu-Projects" class = "menu-item-link" href = "#" >
< span class = ".en" > Projects< / span > < span class = ".zh" > 项目< / span >
< / a >
< script >
$("#menu-Projects").click(function(){
tips.question({
timeout: 20000,
close: false,
overlay: true,
displayMode: 'once',
//id: 'question',
zindex: 999,
title: 'Projects',
message: '',
position: 'center',
buttons: [
['< button > < b > '+((page.tran.getLang() != 'zh')?'fp':'fp')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://fp.js.org/");
else
window.location.href="https://fp.js.org/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'wIoT':'wIoT')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://wiot.js.org/");
else
window.location.href="https://wiot.js.org/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'kms':'kms')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://github.com/iotcat/kms");
else
window.location.href="https://github.com/iotcat/kms";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'ushio':'Ushio')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://ushio.cool/");
else
window.location.href="https://ushio.cool/";
}, true],
['< button > < b > close< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
}, true],
]
});
});
< / script >
< / li >
< li class = "menu-item" >
< a id = "menu-Map" class = "menu-item-link" href = "#" >
< span class = ".en" > Map< / span > < span class = ".zh" > 导航< / span >
< / a >
< script >
$("#menu-Map").click(function(){
tips.question({
timeout: 20000,
close: false,
overlay: true,
displayMode: 'once',
//id: 'question',
zindex: 999,
title: 'Map',
message: '',
position: 'center',
buttons: [
['< button > < b > '+((page.tran.getLang() != 'zh')?'APIs':'接口')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://api.yimian.xyz/");
else
window.location.href="https://api.yimian.xyz/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Imgs':'图库')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://img.yimian.xyz/");
else
window.location.href="https://img.yimian.xyz/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Imgbed':'图床')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("/");
else
window.location.href="undefined";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Fileshare':'文件分享')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://share.yimian.xyz/");
else
window.location.href="https://share.yimian.xyz/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Monitor':'监控')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://monitor.yimian.xyz/");
else
window.location.href="https://monitor.yimian.xyz/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'ACG.WATCH':'视频')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://acg.watch/");
else
window.location.href="https://acg.watch/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Oneindex':'网盘')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://onedrive.yimian.xyz/");
else
window.location.href="https://onedrive.yimian.xyz/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Proxy':'下载代理')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://proxy.yimian.xyz/");
else
window.location.href="https://proxy.yimian.xyz/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'ShortenURL':'短链')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://shorturl.yimian.xyz/");
else
window.location.href="https://shorturl.yimian.xyz/";
}, true],
['< button > < b > close< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
}, true],
]
});
});
< / script >
< / li >
< li class = "menu-item" >
< a id = "menu-About" class = "menu-item-link" href = "#" >
< span class = ".en" > About< / span > < span class = ".zh" > 关于< / span >
< / a >
< script >
$("#menu-About").click(function(){
tips.question({
timeout: 20000,
close: false,
overlay: true,
displayMode: 'once',
//id: 'question',
zindex: 999,
title: 'About',
message: '',
position: 'center',
buttons: [
['< button > < b > '+((page.tran.getLang() != 'zh')?'links':'友链')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("true" == "true")
pjax.loadUrl("/links/");
else
window.location.href="/links/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Me':'关于我')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://iotcat.me/");
else
window.location.href="https://iotcat.me/";
}, true],
['< button > < b > '+((page.tran.getLang() != 'zh')?'Contact':'留言板')+'< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
if("undefined" == "true")
pjax.loadUrl("https://cv.yimian.xyz/contact.html");
else
window.location.href="https://cv.yimian.xyz/contact.html";
}, true],
['< button > < b > close< / b > < / button > ', function (instance, toast) {
instance.hide({ transitionOut: 'fadeOut' }, toast, 'button');
}, true],
]
});
});
< / script >
< / li >
< / ul > < / nav >
< / header >
< main id = "main" class = "main" >
< div class = "content-wrapper" >
< div id = "content" class = "content" > < section id = "posts" class = "posts" > < article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/wiot2.html" > < span class = ".zh" > wIoT发展展望< / span > < span class = ".en" hidden > wIoT - What is the future< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2020-09-15
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 本文将讨论wiot项目下一步的发展目标与实施方法。< / p >
< / span >
< span class = ".en" >
< p > This article will discuss the next development goals and implementation methods of the Wiot project.< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/wiot2.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/kms.html" > < span class = ".zh" > 一键激活win10< / span > < span class = ".en" hidden > Activate win10 with one click< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2020-02-07
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 一键激活win10家庭版,专业版,企业版,教育版 φ( ̄∇ ̄o)< / p >
< / span >
< span class = ".en" >
< p > Activate win10 Home Edition, Professional Edition, Enterprise Edition, Education Edition with one click φ( ̄∇ ̄o)< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/kms.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/travel/ivisa-checklist.html" > < span class = ".zh" > 英国意大利申根签攻略< / span > < span class = ".en" hidden > Schengen visa guide< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-10-30
< / span > < span class = "post-category" >
< a href = "/categories/travel/" > travel< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 在英国留学,圣诞去欧洲旅游,DIY了意大利申根签证。现在游完归来,总结一份申根签攻略。< / p >
< / span >
< span class = ".en" >
< p > I studied in the UK, traveled to Europe on Christmas, and DIYed an Italian Schengen visa. Now come back from the tour, summarize a Schengen sign strategy.< / p >
< / span >
< div class = "read-more" >
< a href = "/travel/ivisa-checklist.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/crown-place-erp.html" > < span class = ".zh" > 公共开支结算系统< / span > < span class = ".en" hidden > Shared Expense Management System< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-09-22
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 在英国留学与4个室友合租,为了更好的控制和监管公共支出,以及维持彼此之间的公共支出平衡,我利用迎新周三天时间设计并开发除了此ERP公共开支计划系统。希望此系统能够便捷接下来一年的生活,减少大家之间的矛盾,促使充满幸福感的公共支出项目持久化OωO< / p >
< / span >
< span class = ".en" >
< p > I studied in the UK and shared with 4 roommates. In order to better control and monitor public expenditures and maintain the balance of public expenditures between each other, I designed and developed this ERP public expenditure planning system during the welcome Wednesday. I hope that this system will make life easier for the next year, reduce conflicts between everyone, and promote the sustainability of public expenditure projects full of happiness OωO< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/crown-place-erp.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/smart-home.html" > < span class = ".zh" > 在家中部署智慧家庭系统< / span > < span class = ".en" hidden > Deploy a smart home system at home< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-07-28
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 基于Home Assisstant搭建综合家庭照明系统,多媒体系统,水流系统的智慧家庭。技术点:天猫精灵交互,LoRa通信,MQTT协议,frp内网穿透,NAS存储,拨动开关电路改造。< / p >
< / span >
< span class = ".en" >
< p > Based on Home Assisstant, build a smart home with integrated home lighting system, multimedia system and water flow system. Technical points: Tmall Genie interaction, LoRa communication, MQTT protocol, FRP intranet penetration, NAS storage, and toggle switch circuit transformation.< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/smart-home.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/smartfarming-surf.html" > < span class = ".zh" > 2019 SURF SmartFarming Proj 架构说明< / span > < span class = ".en" hidden > 2019 SURF SmartFarming Proj Architecture Description< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-07-26
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 本文详细介绍了XJTLU大学2019暑期科研SmartFarming Proj物联网架构的设计思路,实施情况以及缺陷反思。< / p >
< / span >
< span class = ".en" >
< p > This article introduces in detail the design ideas, implementation status and defect reflections of the SmartFarming Proj IoT architecture of XJTLU University’s 2019 summer scientific research.< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/smartfarming-surf.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/rand-pic-api.html" > < span class = ".zh" > 随机图片API< / span > < span class = ".en" hidden > Random Picture API< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-07-10
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 本API基于华为云对象存储,使用华为CDN云加速,全球平均下载速度达10MB/s。API中已收录1100+张二次元图片,20+张Bing壁纸(每日自动抓取),150+张二次元头像,10+张图床上传图片。< / p >
< / span >
< span class = ".en" >
< p > This API is based on Huawei Cloud Object Storage and uses Huawei CDN Cloud acceleration. The global average download speed is 10MB/s. The API has included 1100+ two-dimensional pictures, 20+ Bing wallpapers (automatically captured daily), 150+ two-dimensional avatars, and 10+ pictures uploaded on the bed.< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/rand-pic-api.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/tech/wiot.html" > < span class = ".zh" > wIoT - 轻松物联< / span > < span class = ".en" hidden > wIoT - Easy IoT< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-05-20
< / span > < span class = "post-category" >
< a href = "/categories/tech/" > tech< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 基于NodeJS搭建的物联网系统,配合D1 MINI单片机,帮助你灰常快速实现物联~< / p >
< / span >
< span class = ".en" >
< p > The Internet of Things system based on NodeJS, combined with D1 MINI microcontroller, helps you quickly realize the Internet of Things~< / p >
< / span >
< div class = "read-more" >
< a href = "/tech/wiot.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/thoughts/global-climate-change.html" > < span class = ".zh" > 气候变化与全球环境< / span > < span class = ".en" hidden > Climate change and the global environment< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2019-02-27
< / span > < span class = "post-category" >
< a href = "/categories/thoughts/" > thoughts< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 全球气候变化与人类行为有着显著的相关性,人类行为又会改变气候的自然变化。通过研究Ice core等Archive,发现地球历史中温度与$CO_{2}$浓度有着显著正相关性。如今,人类行为使大气$CO_{2}$含量远超其正常水平,其可能引起全球变暖,冰川融化等,但仅为可能..< / p >
< / span >
< span class = ".en" >
< p > Global climate change has a significant correlation with human behavior, and human behavior will change the natural changes in climate. By studying Archives such as Ice core, it is found that there is a significant positive correlation between the temperature and the concentration of $CO_{2}$ in the history of the earth. Nowadays, human behavior makes the atmospheric content of $CO_{2}$ far exceed its normal level, which may cause global warming, melting of glaciers, etc., but it is only possible…< / p >
< / span >
< div class = "read-more" >
< a href = "/thoughts/global-climate-change.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/thoughts/two-fundamental-demands-of-human-beings.html" > < span class = ".zh" > 人类的两个基本需求< / span > < span class = ".en" hidden > Two Fundamental Demands of Human Beings< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2018-12-23
< / span > < span class = "post-category" >
< a href = "/categories/thoughts/" > thoughts< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 人类的需求可以总结为两类,创造需求的需求,与解决需求的需求。< / p >
< / span >
< span class = ".en" >
< p > Human needs can be summarized into two categories, the need to create needs, and the need to solve needs.< / p >
< / span >
< div class = "read-more" >
< a href = "/thoughts/two-fundamental-demands-of-human-beings.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< article class = "post" >
< header class = "post-header" >
< h1 class = "post-title" > < a class = "post-link" href = "/thoughts/fog-architecture-and-internet-of-things.html" > < span class = ".zh" > 边缘计算与物联网< / span > < span class = ".en" hidden > Fog Architecture and Internet of Things< / span > < / a >
< / h1 >
< div class = "post-meta" >
< span class = "post-time" >
2018-12-17
< / span > < span class = "post-category" >
< a href = "/categories/thoughts/" > thoughts< / a >
< / span >
< / div >
< / header >
< div class = "post-content" > < span class = ".zh" >
< p > 在过去的几十年中,互联网迅速发展,在人们的生活中起着越来越重要的作用。 在地球上几乎所有人类的参与之后[1],开发人员不可避免地期望为互联网提供更多可用的东西,然后产生了物联网(IoT)的想法。 遗憾的是,在大量事物连接到Internet的情况下,其当前体系结构似乎并不是IoT的高效解决方案。 Bonomi等。 思科的文献[2]首先注意到了这个问题,然后他们提出了革命性的Fog概念,以适应即将到来的物联网时代对越来越多的各种设备的访问。 本文将论证雾概念可以对促进物联网建设产生重大影响。< / p >
< / span >
< span class = ".en" >
< p > 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.< / p >
< / span >
< div class = "read-more" >
< a href = "/thoughts/fog-architecture-and-internet-of-things.html" class = "read-more-link" > Read more..< / a >
< / div >
< / div > < / article >
< nav class = "pagination" > < / nav > < / section > < / div > < / div >
< / main >
< footer id = "footer" class = "footer" >
< script >
page_obj = {
layout: "",
comments: ""
};
< / script > < div class = "social-links" > < a href = "mailto:i@iotcat.me" class = "iconfont icon-email" title = "email" > < / a >
< a href = "https://github.com/iotcat" target = "_blank" rel = "noopener" class = "iconfont icon-github" title = "github" > < / a >
< a href = "/atom.xml" class = "iconfont icon-rss" title = "rss" > < / a >
< / div > < div class = "copyright" > < span class = "power-by" >
Powered by < a class = "hexo-link" href = "https://ushio.cool/" target = "_blank" rel = "noopener" > Ushio< / a >
< / span >
< span class = "division" > |< / span >
< span class = "theme-info" >
Theme -
< a class = "theme-link" href = "https://github.com/iotcat/kayo" target = "_blank" rel = "noopener" > Kayo< / a >
< / span >
< span class = "copyright-year" > © 2018 - 2021< span class = "heart shaky" >
< i class = "iconfont icon-heart" > < / i >
< / span >
< span class = "author" > < a href = "https://iotcat.me/" target = "_blank" rel = "noopener" > IoTcat< / a > < / span >
< / span >
< / div >
< / footer >
< div class = "back-to-top" id = "back-to-top" >
< i class = "iconfont icon-up" > < / i >
< / div >
< / div >
< script src = "https://cdn.yimian.xyz/kayo/lib/valine/valine.min.js" data-pjax > < / script >
< style >
/* 背景图片 */
#veditor {
background-image: url(https://cdn.yimian.xyz/img/blog/comments_bg.webp);
background-size: contain;
background-repeat: no-repeat;
background-position: right;
background-color: rgba(255, 255, 255, 0);
resize: vertical
}
/* 头像旋转 */
img.vimg {
transition: all 1s /* 旋转时间为 1s */
}
img.vimg:hover {
transform: rotate(360deg);
-webkit-transform: rotate(360deg);
-moz-transform: rotate(360deg);
-o-transform: rotate(360deg);
-ms-transform: rotate(360deg);
}
/* 盒子模式 */
#vcomments .vcards .vcard {
padding: 15px 20px 0 20px;
border-radius: 10px;
margin-bottom: 15px;
box-shadow: 0 0 4px 1px rgba(0, 0, 0, .12);
transition: all .3s
}
#vcomments .vcards .vcard:hover {
box-shadow: 0 0 8px 3px rgba(0, 0, 0, .12)
}
#vcomments .vcards .vcard .vh .vcard {
border: none;
box-shadow: none;
}
< / style >
< script >
pjax_valine = () => {
$.get('https://auth.yimian.xyz/getEmailHash.php', function(res){
if(page.tran.getLang() == 'zh'){
var lan = 'zh-CN';
var metaPlaceholder = {"nick":"昵称/QQ号","mail":"邮箱(完全保密)"};
var tagMeta = ["博主","小伙伴","访客"];
var placeholder = "填写邮箱可以及时收到回复哦(●'◡'●)";
}else{
var lan = 'en';
var metaPlaceholder = {"nick":"Nickname/QQ","mail":"EMail"};
var tagMeta = ["Master","Friend","Visitor"];
var placeholder = "Leave some comments here (●'◡'●)";
}
new Valine({
el: '#vcomments',
appId: 'eVzpK7EyT6OafJvXWIRminWT-gzGzoHsz',
appKey: '2qjuEBgVE0BscTQnTmoS9roU',
master: '9b616ff4cd6c305e5970bee7b1bd9b1f', //博主邮箱md5
tagMeta: tagMeta, //标识字段名
friends: res, //["b6ddef7c7e1c647e7767afeacdfb7b64","46dd4e6fef4f9591736c4723a965ca2e","6132d77f9f0ae060bc733090991acecb","3e00e104b79d7c6e866c6b23c6ba6dfc"], //小伙伴邮箱Md5
metaPlaceholder: metaPlaceholder,
placeholder: placeholder,
lang: lan,
path: window.location.pathname,
enableQQ: true,
visitor: true,
emojiCDN: '//i0.hdslb.com/bfs/emote/',
emojiMaps: {
"tv_doge": "6ea59c827c414b4a2955fe79e0f6fd3dcd515e24.png",
"tv_亲亲": "a8111ad55953ef5e3be3327ef94eb4a39d535d06.png",
"tv_偷笑": "bb690d4107620f1c15cff29509db529a73aee261.png",
"tv_再见": "180129b8ea851044ce71caf55cc8ce44bd4a4fc8.png",
"tv_冷漠": "b9cbc755c2b3ee43be07ca13de84e5b699a3f101.png",
"tv_发怒": "34ba3cd204d5b05fec70ce08fa9fa0dd612409ff.png",
"tv_发财": "34db290afd2963723c6eb3c4560667db7253a21a.png",
"tv_可爱": "9e55fd9b500ac4b96613539f1ce2f9499e314ed9.png",
"tv_吐血": "09dd16a7aa59b77baa1155d47484409624470c77.png",
"tv_呆": "fe1179ebaa191569b0d31cecafe7a2cd1c951c9d.png",
"tv_呕吐": "9f996894a39e282ccf5e66856af49483f81870f3.png",
"tv_困": "241ee304e44c0af029adceb294399391e4737ef2.png",
"tv_坏笑": "1f0b87f731a671079842116e0991c91c2c88645a.png",
"tv_大佬": "093c1e2c490161aca397afc45573c877cdead616.png",
"tv_大哭": "23269aeb35f99daee28dda129676f6e9ea87934f.png",
"tv_委屈": "d04dba7b5465779e9755d2ab6f0a897b9b33bb77.png",
"tv_害羞": "a37683fb5642fa3ddfc7f4e5525fd13e42a2bdb1.png",
"tv_尴尬": "7cfa62dafc59798a3d3fb262d421eeeff166cfa4.png",
"tv_微笑": "70dc5c7b56f93eb61bddba11e28fb1d18fddcd4c.png",
"tv_思考": "90cf159733e558137ed20aa04d09964436f618a1.png",
"tv_惊吓": "0d15c7e2ee58e935adc6a7193ee042388adc22af.png",
"tv_打脸": "56ab10b624063e966bfcb76ea5dc4794d87dfd47.png",
"tv_抓狂": "fe31c08edad661d63762b04e17b8d5ae3c71a757.png",
"tv_抠鼻": "c666f55e88d471e51bbd9fab9bb308110824a6eb.png",
"tv_斜眼笑": "911f987aa8bc1bee12d52aafe62bc41ef4474e6c.png",
"tv_无奈": "ea8ed89ee9878f2fece2dda0ea8a5dbfe21b5751.png",
"tv_晕": "5443c22b4d07fb1907ccc610c8e6db254f2461b7.png",
"tv_流汗": "cead1c351ab8d79e9f369605beb90148db0fbed3.png",
"tv_流泪": "7e71cde7858f0cd50d74b0264aa26db612a8a167.png",
"tv_流鼻血": "c32d39db2737f89b904ca32700d140a9241b0767.png",
"tv_点赞": "f85c354995bd99e28fc76c869bfe42ba6438eff4.png",
"tv_生气": "26702dcafdab5e8225b43ffd23c94ac1ff932654.png",
"tv_生病": "8b0ec90e6b86771092a498c54f09fc94621c1900.png",
"tv_疑问": "0793d949b18d7be716078349c202c15ff166f314.png",
"tv_白眼": "c1d59f439e379ee50eef488bcb5e5378e5044ea4.png",
"tv_皱眉": "72ccad6679fea0d14cce648b4d818e09b8ffea2d.png",
"tv_目瞪口呆": "0b8cb81a68de5d5365212c99375e7ace3e7891b7.png",
"tv_睡着": "8b196675b53af58264f383c50ad0945048290b33.png",
"tv_笑哭": "1abc628f6d4f4caf9d0e7800878f4697abbc8273.png",
"tv_腼腆": "89712c0d4af73e67f89e35cbc518420380a7f6f4.png",
"tv_色": "61822c7e9aae5da76475e7892534545336b23a6f.png",
"tv_调侃": "4bc022533ef31544ca0d72c12c808cf4a1cce3e3.png",
"tv_调皮": "b9c41de8e82dd7a8515ae5e3cb63e898bf245186.png",
"tv_鄙视": "6e72339f346a692a495b123174b49e4e8e781303.png",
"tv_闭嘴": "c9e990da7f6e93975e25fd8b70e2e290aa4086ef.png",
"tv_难过": "87f46748d3f142ebc6586ff58860d0e2fc8263ba.png",
"tv_馋": "fc7e829b845c43c623c8b490ee3602b7f0e76a31.png",
"tv_鬼脸": "0ffbbddf8a94d124ca2f54b360bbc04feb6bbfea.png",
"tv_黑人问号": "45821a01f51bc867da9edbaa2e070410819a95b2.png",
"tv_鼓掌": "1d21793f96ef4e6f48b23e53e3b9e42da833a0f6.png"
// ... 更多表情
}
});
});
};
< / script > < script type = "text/javascript" src = "https://cdn.yimian.xyz/ushio-js/ushio-footer.min.js" > < / script >
< script >
session.onload(function(){
if(session.get('group') != 'anonymous'){
function insertNick(){
if($('.vnick').length){
$('.vnick').val(session.get('nickname'));
}else{
setTimeout(insertNick, 500);
}
}
function insertMail(){
if($('.vmail').length){
$('.vmail').val(session.get('email'));
}else{
setTimeout(insertMail, 500);
}
}
if(session.get('nickname')){
insertNick();
}
if(session.get('email')){
insertMail();
}
}
});
< / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/lib/slideout/slideout.js" > < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/lib/fancybox/jquery.fancybox.pack.js" > < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/lib/iziToast/iziToast.min.js" > < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/lib/iziModal/iziModal.min.js" > < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/lib/mermaid/mermaid.min.js" > < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/js/src/kayo.js?v=1.0.0" data-pjax > < / script >
< script type = "text/javascript" src = "https://cdn.yimian.xyz/kayo/js/src/kayo-no-pjax.js?v=1.0.0" > < / script >
< script src = "https://cdn.yimian.xyz/kayo/lib/pjax/pjax.min.js" > < / script >
< script > w i n d o w . p j a x = n e w P j a x ( {
elements: 'a[href]:not([href^="#"]):not([href="javascript:void(0)"])',
selectors: ["head title, #main", "#footer"],
});/* lazyload */
window.imageLazyLoadSetting = {
isSPA: false,
processImages: null,
};
window.addEventListener("load",function(){var t=/\.(gif|jpg|jpeg|tiff|png)$/i,r=/^data:image\/[a-z]+;base64,/;Array.prototype.slice.call(document.querySelectorAll("img[data-original]")).forEach(function(a){var e=a.parentNode;"A"===e.tagName&&(e.href.match(t)||e.href.match(r))&&(e.href=a.dataset.original)})});
/* 第一次载入页面加载的函数 */
pjax_ini = () => {
/* 关闭侧边栏 */
window.slideout.close();
if(page_obj.comments == "true"){pjax_valine();}pjax_google_analytics();mermaid.init(undefined, $(".mermaid"));/* lazy load */
!function(n){n.imageLazyLoadSetting.processImages=o;var i=n.imageLazyLoadSetting.isSPA,r=Array.prototype.slice.call(document.querySelectorAll("img[data-original]"));function o(){i&&(r=Array.prototype.slice.call(document.querySelectorAll("img[data-original]"))); for(var t,e,a=0;a< r.length ; a + + ) t = r[a],e=void 0 , 0 < = ( e = t.getBoundingClientRect()).bottom&&0<=e.left&&e.top<=(n.innerHeight||document.documentElement.clientHeight)&&function(){var t , e , n , i , o = r[a];t=o,e=function(){r=r.filter(function(t){return o ! = = t } ) } , n = new Image , i = t.getAttribute("data-original"),n.onload=function(){t.src=i,e&&e()},n.src=i}()}o(),n.addEventListener("scroll",function(){var t , e ; t = o,e=n,clearTimeout(t.tId),t.tId=setTimeout(function(){t.call(e)},500)})}(this);
!function(){var t=/\.(gif|jpg|jpeg|tiff|png)$/i,r=/^data:image\/[a-z]+;base64,/;Array.prototype.slice.call(document.querySelectorAll("img[data-original]")).forEach(function(a){var e=a.parentNode;"A"===e.tagName&&(e.href.match(t)||e.href.match(r))&&(e.href=a.dataset.original)})}();
};
/* 第一次 执行 */
pjax_ini();var loadingBar = document.querySelector(".loading-bar");
var progress = document.querySelector(".loading-bar .progress");
var timer = null;
// Pjax 开始时执行的函数
var loadingbarStart = function () {
// 进度条默认已经加载 20%
var loadingBarWidth = 20;
// 进度条的最大增加宽度
var MAX_LOADING_WIDTH = 95;
// 显示进度条
loadingBar.classList.add("loading");
// 初始化进度条的宽度
progress.style.width = loadingBarWidth + "%";
clearInterval(timer);
timer = setInterval(function () {
// 进度条的增加速度(可以改为一个随机值,显得更加真实)
loadingBarWidth += 3;
// 当进度条到达 95% 后停止增加
if (loadingBarWidth > MAX_LOADING_WIDTH) {
loadingBarWidth = MAX_LOADING_WIDTH;
}
progress.style.width = loadingBarWidth + "%";
}, 500);
};
// Pjax 完成之后执行的函数
var loadingbarStop = function () {
clearInterval(timer);
progress.style.width = "100%";
loadingBar.classList.remove("loading");
setTimeout(function () {
progress.style.width = 0;
}, 400);
};/* Pjax 开始时,重新加载的函数 */
document.addEventListener("pjax:send", function () {loadingbarStart();
});
/* Pjax 完成后,重新加载的函数 */
document.addEventListener("pjax:complete", function () {
/* 重载带data-pjax的script,或者.pjax-reload属性内容的script */
$("script[data-pjax], .pjax-reload script").each(function () {
$(this).parent().append($(this).remove());
});
pjax_ini();loadingbarStop();
page.tran.setLang();
});
/* Pjax 出错,执行的函数 */
document.addEventListener("pjax:error", function () {
});< / script >
< / body >
< / html >