首页 文章 精选 留言 我的

精选列表

搜索[网站开发],共10000篇文章
优秀的个人博客,低调大师

《深入理解Nginx:模块开发与架构解析》一1.6 Nginx的命令行控制

1.6 Nginx的命令行控制 在Linux中,需要使用命令行来控制Nginx服务器的启动与停止、重载配置文件、回滚日志文件、平滑升级等行为。默认情况下,Nginx被安装在目录/usr/local/nginx/中,其二进制文件路径为/usr/local/nginc/sbin/nginx,配置文件路径为/usr/local/nginx/conf/nginx.conf。当然,在configure执行时是可以指定把它们安装在不同目录的。为了简单起见,本节只说明默认安装情况下的命令行的使用情况,如果读者安装的目录发生了变化,那么替换一下即可。(1)默认方式启动直接执行Nginx二进制程序。例如: /usr/local/nginx/sbin/nginx 这时,会读取默认路径下的配置文件:/usr/local/nginx/conf/nginx.c

优秀的个人博客,低调大师

《深入理解Nginx:模块开发与架构解析》一3.4 HTTP模块的数据结构

3.4 HTTP模块的数据结构 定义HTTP模块方式很简单,例如: ngx_module_t ngx_http_mytest_module; 其中,ngx_module_t 是一个Nginx模块的数据结构(详见8.2节)。下面来分析一下Nginx模块中所有的成员,如下所示: typedef struct ngx_module_s ngx_module_t; struct ngx_module_s { /* 下面的ctx_index、index、spare0、spare1、spare2、spare3、version变量不需要在定义时赋值,可以用Nginx准备好的宏NGX_MODULE_V1来定义,它已经定义好了这7个值。 #define NGX_MODULE_V1 0, 0, 0, 0, 0, 0, 1 对于一类模

优秀的个人博客,低调大师

《Android应用开发攻略》——1.8 通过SlideME将应用程序安装到模拟器上

1.8 通过SlideME将应用程序安装到模拟器上 David Dawes1.8.1 问题App Store(应用程序商店)是现代智能手机吸引人的一个重要因素。Google的Android Market(安卓市场)是官方的应用程序商店,但是你可能希望利用其他的商店。1.8.2 解决方案SlideMe LLC提供一个备选的应用商店。SlideME应用商店允许安装其他应用程序(你可能希望与其他应用程序集成),也可以在模拟Android设备上测试发布和下载自己的应用程序的体验。SlideME还能联系到许多被Google Android Market关在门外的Android用户,包括拥有无法支持的设备,以及生活在Android Market所不支持的国家中的人们。1.8.3 讨论Slide ME是官方的Android Market的一个替代

优秀的个人博客,低调大师

iOS开发-Reachability实时检测Wifi,2G/3G/4G/网络状态

最近遇到一个功能就是根据用户当前的网络状,用户未联网需要提示一下,如果是Wifi可以推荐一些图片新闻,如果是3G模式设置为无图的模式,获取网络状态比较简单,毕竟中国现在的流量还是一个比较贵的状态,哪天用户发现App消耗流量过多说不定就干掉了App。不过苹果的Reachability都解决了以上问题,使用起来也比较方便,具体的稍微简单分析一下。 Reachability.h头文件代码: + View Code Reachability.m文件: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 #import <arpa/inet.h> #import <ifaddrs.h> #import <netdb.h> #import <sys/socket.h> #import <CoreFoundation/CoreFoundation.h> #import "Reachability.h" NSString *kReachabilityChangedNotification = @ "kNetworkReachabilityChangedNotification" ; #pragma mark - Supporting functions #define kShouldPrintReachabilityFlags 1 static void PrintReachabilityFlags(SCNetworkReachabilityFlags flags, const char * comment) { #if kShouldPrintReachabilityFlags NSLog (@ "Reachability Flag Status: %c%c %c%c%c%c%c%c%c %s\n" , //当前网络2G/3G/4G蜂窝网络 (flags & kSCNetworkReachabilityFlagsIsWWAN) ? 'W' : '-' , //网络是否可达 (flags & kSCNetworkReachabilityFlagsReachable) ? 'R' : '-' , (flags & kSCNetworkReachabilityFlagsTransientConnection) ? 't' : '-' , (flags & kSCNetworkReachabilityFlagsConnectionRequired) ? 'c' : '-' , (flags & kSCNetworkReachabilityFlagsConnectionOnTraffic) ? 'C' : '-' , (flags & kSCNetworkReachabilityFlagsInterventionRequired) ? 'i' : '-' , (flags & kSCNetworkReachabilityFlagsConnectionOnDemand) ? 'D' : '-' , (flags & kSCNetworkReachabilityFlagsIsLocalAddress) ? 'l' : '-' , (flags & kSCNetworkReachabilityFlagsIsDirect) ? 'd' : '-' , comment ); #endif } static void ReachabilityCallback(SCNetworkReachabilityRef target, SCNetworkReachabilityFlags flags, void * info) { #pragma unused (target, flags) NSCAssert (info != NULL , @ "info was NULL in ReachabilityCallback" ); NSCAssert ([(__bridge NSObject *) info isKindOfClass: [Reachability class ]], @ "info was wrong class in ReachabilityCallback" ); //http://www.cnblogs.com/xiaofeixiang Reachability* noteObject = (__bridge Reachability *)info; // Post a notification to notify the client that the network reachability changed. [[ NSNotificationCenter defaultCenter] postNotificationName: kReachabilityChangedNotification object: noteObject]; } #pragma mark - Reachability implementation @implementation Reachability { BOOL _alwaysReturnLocalWiFiStatus; //default is NO SCNetworkReachabilityRef _reachabilityRef; } //通过域名进行实例化 博客园-Fly_Elephant + (instancetype)reachabilityWithHostName:( NSString *)hostName { Reachability* returnValue = NULL ; SCNetworkReachabilityRef reachability = SCNetworkReachabilityCreateWithName( NULL , [hostName UTF8String]); if (reachability != NULL ) { returnValue= [[ self alloc] init]; if (returnValue != NULL ) { returnValue->_reachabilityRef = reachability; returnValue->_alwaysReturnLocalWiFiStatus = NO ; } } return returnValue; } //通过ip地址实例化Reachability + (instancetype)reachabilityWithAddress:( const struct sockaddr_in *)hostAddress { SCNetworkReachabilityRef reachability = SCNetworkReachabilityCreateWithAddress(kCFAllocatorDefault, ( const struct sockaddr *)hostAddress); Reachability* returnValue = NULL ; if (reachability != NULL ) { returnValue = [[ self alloc] init]; if (returnValue != NULL ) { returnValue->_reachabilityRef = reachability; returnValue->_alwaysReturnLocalWiFiStatus = NO ; } } return returnValue; } //检测是否能够直接连上互联网 + (instancetype)reachabilityForInternetConnection { struct sockaddr_in zeroAddress; bzero(&zeroAddress, sizeof (zeroAddress)); zeroAddress.sin_len = sizeof (zeroAddress); zeroAddress.sin_family = AF_INET; return [ self reachabilityWithAddress:&zeroAddress]; } //检测当前网络是否能够联上wifi + (instancetype)reachabilityForLocalWiFi { struct sockaddr_in localWifiAddress; bzero(&localWifiAddress, sizeof (localWifiAddress)); localWifiAddress.sin_len = sizeof (localWifiAddress); localWifiAddress.sin_family = AF_INET; // IN_LINKLOCALNETNUM is defined in <netinet/in.h> as 169.254.0.0. localWifiAddress.sin_addr.s_addr = htonl(IN_LINKLOCALNETNUM); Reachability* returnValue = [ self reachabilityWithAddress: &localWifiAddress]; if (returnValue != NULL ) { returnValue->_alwaysReturnLocalWiFiStatus = YES ; } return returnValue; } #pragma mark - Start and stop notifier - ( BOOL )startNotifier { BOOL returnValue = NO ; SCNetworkReachabilityContext context = {0, (__bridge void *)( self ), NULL , NULL , NULL }; //SCNetworkReachabilitySetCallback函数为指定一个target //当设备对于这个target链接状态发生改变时(比如断开链接,或者重新连上),则回调reachabilityCallback函数, if (SCNetworkReachabilitySetCallback(_reachabilityRef, ReachabilityCallback, &context)) { if (SCNetworkReachabilityScheduleWithRunLoop(_reachabilityRef, CFRunLoopGetCurrent(), kCFRunLoopDefaultMode)) { returnValue = YES ; } } return returnValue; } - ( void )stopNotifier { if (_reachabilityRef != NULL ) { SCNetworkReachabilityUnscheduleFromRunLoop(_reachabilityRef, CFRunLoopGetCurrent(), kCFRunLoopDefaultMode); } } - ( void )dealloc { [ self stopNotifier]; if (_reachabilityRef != NULL ) { CFRelease(_reachabilityRef); } } #pragma mark - Network Flag Handling - (NetworkStatus)localWiFiStatusForFlags:(SCNetworkReachabilityFlags)flags { PrintReachabilityFlags(flags, "localWiFiStatusForFlags" ); NetworkStatus returnValue = NotReachable; if ((flags & kSCNetworkReachabilityFlagsReachable) && (flags & kSCNetworkReachabilityFlagsIsDirect)) { returnValue = ReachableViaWiFi; } return returnValue; } - (NetworkStatus)networkStatusForFlags:(SCNetworkReachabilityFlags)flags { PrintReachabilityFlags(flags, "networkStatusForFlags" ); if ((flags & kSCNetworkReachabilityFlagsReachable) == 0) { // The target host is not reachable. return NotReachable; } NetworkStatus returnValue = NotReachable; if ((flags & kSCNetworkReachabilityFlagsConnectionRequired) == 0) { /* If the target host is reachable and no connection is required then we'll assume (for now) that you're on Wi-Fi... */ returnValue = ReachableViaWiFi; } if ((((flags & kSCNetworkReachabilityFlagsConnectionOnDemand ) != 0) || (flags & kSCNetworkReachabilityFlagsConnectionOnTraffic) != 0)) { /* ... and the connection is on-demand (or on-traffic) if the calling application is using the CFSocketStream or higher APIs... */ if ((flags & kSCNetworkReachabilityFlagsInterventionRequired) == 0) { /* ... and no [user] intervention is needed... */ returnValue = ReachableViaWiFi; } } if ((flags & kSCNetworkReachabilityFlagsIsWWAN) == kSCNetworkReachabilityFlagsIsWWAN) { /* ... but WWAN connections are OK if the calling application is using the CFNetwork APIs. */ returnValue = ReachableViaWWAN; } return returnValue; } - ( BOOL )connectionRequired { NSAssert (_reachabilityRef != NULL , @ "connectionRequired called with NULL reachabilityRef" ); SCNetworkReachabilityFlags flags; if (SCNetworkReachabilityGetFlags(_reachabilityRef, &flags)) { return (flags & kSCNetworkReachabilityFlagsConnectionRequired); } return NO ; } //获取当前网络状态 - (NetworkStatus)currentReachabilityStatus { NSAssert (_reachabilityRef != NULL , @ "currentNetworkStatus called with NULL SCNetworkReachabilityRef" ); NetworkStatus returnValue = NotReachable; SCNetworkReachabilityFlags flags; if (SCNetworkReachabilityGetFlags(_reachabilityRef, &flags)) { if (_alwaysReturnLocalWiFiStatus) { returnValue = [ self localWiFiStatusForFlags:flags]; } else { returnValue = [ self networkStatusForFlags:flags]; } } return returnValue; } @end AppDelegate中的实现: 1 2 3 4 5 6 7 8 9 10 - ( BOOL )application:(UIApplication *)application didFinishLaunchingWithOptions:( NSDictionary *)launchOptions { //添加一个系统通知 [[ NSNotificationCenter defaultCenter] addObserver: self selector: @selector (reachabilityChanged:) name:kReachabilityChangedNotification object: nil ]; //初始化 self .internetReachability=[Reachability reachabilityForInternetConnection]; //通知添加到Run Loop [ self .internetReachability startNotifier]; [ self updateInterfaceWithReachability:_internetReachability]; return YES ; } 回调函数: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 - ( void ) reachabilityChanged:( NSNotification *)note { Reachability* curReach = [note object]; NSParameterAssert ([curReach isKindOfClass:[Reachability class ]]); [ self updateInterfaceWithReachability:curReach]; } - ( void )updateInterfaceWithReachability:(Reachability *)reachability { NetworkStatus netStatus = [reachability currentReachabilityStatus]; switch (netStatus) { case NotReachable: NSLog (@ "====当前网络状态不可达=======http://www.cnblogs.com/xiaofeixiang" ); break ; case ReachableViaWiFi: NSLog (@ "====当前网络状态为Wifi=======博客园-Fly_Elephant" ); break ; case ReachableViaWWAN: NSLog (@ "====当前网络状态为3G=======keso" ); break ; } } 模式测试 Wifi模式-wuWifi-连接Wifi,显示结果如下: 如果直接通过host实例化也可以: 1 2 NSString *remoteHostName = @ "www.cnblogs.com/xiaofeixiang" ; self .hostReachability = [Reachability reachabilityWithHostName:remoteHostName]; 本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4472343.html,如需转载请自行联系原作者

优秀的个人博客,低调大师

张高兴的 Windows 10 IoT 开发笔记:使用 ADS1115 读取模拟信号

考虑到 Raspberry Pi 读取模拟信号是很烦人的事情,更何况是在没人玩的 Windows 10 IoT 下,所以准备正儿八经的写点东西。 需求:使用 Raspberry Pi 读取输出模拟信号的 MQ 系列气体传感器。(GitHub:https://github.com/ZhangGaoxing/windows-iot-demo/tree/master/ADS1115) 由于 Raspberry Pi 3B 内部并没有集成 ADC,因此需要外接 ADC 来进行模数转换。外接 ADC 选用的是 ADS1115,淘宝到处都是,而且还不贵, I2C 的通讯方式实现起来相对容易些。 1. 过程分析 在 ADS1115 的数据手册(GitHub项目中附带了PDF)的第11页中,官方给出了一个简单的快速开始 (1)设置配置寄存器 (2)定位到转换寄存器 (3)读取转换寄存器 2. 寄存器配置分析 了解了大概过程后接下来就是查寄存器的格式及配置方法了。 ADS1115 的 ADDR 接口的接法决定了地址。 地址确定后,下面来看看寄存器的地址指针。由于我们只是简单的读取,只需要用到最上面的两个指针。配置寄存器为 0x01,转换寄存器为 0x00。 按照第一点的过程分析,第一步我们要设置配置寄存器。配置寄存器分高八位和低八位,指针定位到配置寄存器后,需要分别写入两个 byte 的配置数据。详细的比特位的功能可以查下数据手册。在这里只介绍用的到的。 在14-12位,是 MUX 配置。简单的说,这决定了 ADS1115 的 A0-A3 接口的测量方式。比如说,当设置为 0x04 时测量的为 A0-GND 的电压,当设置为 0x00 时测量的为 A0-A1 间的电压。 在11-9位,是 PGA 配置。这决定了 ADS1115 的量程。 在第8位,是 ADS1115 的状态配置。0x00 为测量模式,0x01 为休眠。 在第7-5位,是每秒采样次数的配置。 以上是我们需要的配置位,其他的按照数据手册上的默认即可。即高八位 0 100 001 0(0x42),低八位 100 0 0 0 11(0x83)。需要其他的功能,按照数据手册上的更改即可。 配置完成后,读取数据是非常简单的,直接读取即可。 3. 连线 VDD - 5V GND - GND SCL - SCL SDA - SDA ADDR - GND A0 - MQ 传感器的 A0 4. 部分代码 详细的代码已经放在 GitHub 上了,这里只给出 ADS1115.cs 的简单介绍。 /// <summary> /// Constructor /// </summary> /// <param name="addr">ADS1115 Address</param> /// <param name="mux">Input Multiplexer</param> /// <param name="pga">Programmable Gain Amplifier</param> /// <param name="rate">Data Rate </param> public ADS1115(AddressSetting addr = AddressSetting.GND, InputMultiplexeConfig mux = InputMultiplexeConfig.AIN0, PgaConfig pga = PgaConfig.FS4096, DataRate rate = DataRate.SPS128); /// <summary> /// Initialize ADS1115 /// </summary> /// <returns></returns> public async Task InitializeAsync(); /// <summary> /// Read Raw Data /// </summary> /// <returns>Raw Value</returns> public short ReadRaw(); /// <summary> /// Convert Raw Data to Voltage /// </summary> /// <param name="val">Raw Data</param> /// <returns>Voltage</returns> public double RawToVoltage(short val); /// <summary> /// Cleanup /// </summary> public void Dispose(); 5. 如何使用 第一步,需要实例化 ADS1115,并调用InitializeAsync()。 ADS1115 adc = new ADS1115(AddressSetting.GND, InputMultiplexeConfig.AIN0, PgaConfig.FS4096, DataRate.SPS860); await adc.InitializeAsync(); 第二步,读取数据。 short raw = adc.ReadRaw(); double vol = adc.RawToVoltage(raw); 如果需要释放,调用adc.Dispose(); 6. 运行图

资源下载

更多资源
优质分享App

优质分享App

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Nacos

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册