【iOS逆向与安全】好用的一套 TCP 类
初始化
//页面
%hook xxxxxxxViewController//- (void)viewWillAppear:(BOOL)animated{
//NSLog(@"View Will Appear,再次进入刷新");
- (void)viewDidLoad{//启动tcp[[Xddtcp sharedTcpManager] connectServer] ;}
发送数据
//发送数据 [[Xddtcp sharedTcpManager] sendDataToServer:[@"MyiPhone" dataUsingEncoding:NSUTF8StringEncoding]] ;
源码类
//
// Xddtcp.m
// YFX_ScoketForClientDemo
//
// Created by adminxdd on 2020/8/20.
// Copyright © 2020 fangxue. All rights reserved.
//#import "Xddtcp.h"#define WSELF __weak typeof(self) wself = self;/** 主线程异步队列 */
#define Dispatch_main_async_safe(block)\
if ([NSThread isMainThread]) {\
block();\
} else {\
dispatch_async(dispatch_get_main_queue(), block);\
}//@implementation Xddtcp
@interface Xddtcp() <GCDAsyncSocketDelegate>/** 心跳计时器 */
@property (nonatomic, strong) NSTimer *heartBeatTimer;/** 没有网络的时候检测网络定时器 */
@property(nonatomic,strong)NSTimer*netWorkTestingTimer;/** 存储要发送给服务端的数据 */
@property (nonatomic, strong) NSMutableArray *sendDataArray;/** 数据请求队列(串行队列) */
@property (nonatomic, strong) dispatch_queue_t queue;/** 重连时间 */
@property (nonatomic, assign) NSTimeInterval reConnectTime;/** 用于判断是否主动关闭长连接,如果是主动断开连接,连接失败的代理中,就不用执行 重新连接方法 */
@property (nonatomic, assign) BOOL isActivelyClose;/** 缓存区域 */
@property (nonatomic, strong) NSMutableData *readBuf;@end@implementation Xddtcp#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥
#pragma mark ----单利------/** 单利 */
+ (instancetype)sharedTcpManager{static Xddtcp*_instace =nil;static dispatch_once_t onceToken;dispatch_once(&onceToken,^{_instace = [[self alloc]init];NSLog(@"TCP 单利实例化!");});return _instace;
}
#pragma mark ----初始化------/** 初始化 */
- (instancetype)init{self= [super init];if(self){self.reConnectTime = 0;self.isActivelyClose = NO;self.queue = dispatch_queue_create("BF",NULL);self.sendDataArray = [[NSMutableArray alloc] init];// self.mRecvPacket = [JHreceivePacket sharedManager];// self.deviceListArr = [[NSMutableArray alloc] init];// DLogInfo(@"初始化!");}return self;
}#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥#pragma mark --- 心跳计时器处理 -----/** 心跳计时器初始化 */
- (void)initHeartBeat{//心跳没有被关闭if(self.heartBeatTimer){return;}[self destoryHeartBeat];//连接成功 先发一次 心跳数据 在打开计时器//[[JHSocketData sharedManager] heartbeat];//判断是否打开if([xddTools keyGet:@"isOpenTCP"]&&[[xddTools keyGet:@"isOpenTCP"] isEqualToString:@"已打开"]){[self.asyncTcpSocket writeData:[@"MyiPhone" dataUsingEncoding:NSUTF8StringEncoding] withTimeout:30 tag:0];}WSELFDispatch_main_async_safe(^{wself.heartBeatTimer = [NSTimer timerWithTimeInterval:30 target:wself selector:@selector(senderheartBeat) userInfo:nil repeats:true];[[NSRunLoop currentRunLoop]addTimer:wself.heartBeatTimer forMode:NSRunLoopCommonModes];});}#pragma mark --- 取消心跳 -----/** 取消心跳 */
- (void)destoryHeartBeat
{WSELFDispatch_main_async_safe(^{if(wself.heartBeatTimer){[wself.heartBeatTimer invalidate];wself.heartBeatTimer =nil;}});
}#pragma mark --- 没有网络的时候开始定时 -- 用于网络检测 -----/** 没有网络,进行网络监测 */
- (void)noNetWorkStartTestingTimer{WSELFDispatch_main_async_safe(^{wself.netWorkTestingTimer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:wself selector:@selector(noNetWorkStartTesting) userInfo:nil repeats:YES];[[NSRunLoop currentRunLoop] addTimer:wself.netWorkTestingTimer forMode:NSDefaultRunLoopMode];});
}#pragma mark --- 取消网络监测 ----/** 取消网络监测 */
- (void)destoryNetWorkStartTesting
{WSELFDispatch_main_async_safe(^{if(wself.netWorkTestingTimer){[wself.netWorkTestingTimer invalidate];wself.netWorkTestingTimer =nil;}});
}#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥#pragma mark --- 发送心跳 ---/** 发送心跳 */
- (void)senderheartBeat{// 和服务端约定好发送什么作为心跳标识,尽可能的减小心跳包大小[self.asyncTcpSocket writeData:[@"ok" dataUsingEncoding:NSUTF8StringEncoding] withTimeout:30 tag:0];// WSELF;// Dispatch_main_async_safe(^{//// });
}#pragma mark --- 定时检查网络 ---/** 定时检查网络 */
- (void)noNetWorkStartTesting{//有网络if(AFNetworkReachabilityManager.sharedManager.networkReachabilityStatus != AFNetworkReachabilityStatusNotReachable){//关闭网络检测定时器[self destoryNetWorkStartTesting];//开始重连[self reConnectServer];}}
#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥#pragma mark ----建立连接------/** 建立连接 */-(void)connectServer{self.isActivelyClose = NO;NSError*error =nil;_asyncTcpSocket= [[GCDAsyncSocket alloc]initWithDelegate:self delegateQueue:dispatch_get_main_queue()];NSString* ip = [xddTools keyGet:@"TCP_IP"];NSString* port_str = [xddTools keyGet:@"TCP_Port"];if([ip isEqualToString:@""]){ip = @"192.168.1.2";[xddTools keySet:@"TCP_IP" v:ip];}if([port_str isEqualToString:@""]){port_str = @"12485";[xddTools keySet:@"TCP_Port" v:port_str];}UInt16 port = [port_str integerValue];//你的ip地址和端口号[_asyncTcpSocket connectToHost:ip onPort:port withTimeout:60 error:&error];if(error) {NSLog(@"TCP连接错误:%@", error);}[self.asyncTcpSocket readDataWithTimeout:-1 tag:0];}#pragma mark --- 重连服务器 ---/** 重连服务器 */
- (void)reConnectServer{if (self.asyncTcpSocket.isConnected) {return;}if (self.reConnectTime > 10240) {self.reConnectTime = 0;return;}WSELF;dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(self.reConnectTime *NSEC_PER_SEC)), dispatch_get_main_queue(), ^{if(wself.asyncTcpSocket.isConnected){return;}[wself connectServer];NSLog(@"正在重连%f",wself.reConnectTime);if(wself.reConnectTime==0){ //重连时间2的指数级增长wself.reConnectTime=2;} else {wself.reConnectTime*=2;}});NSLog(@"重连服务器!");}#pragma mark ----关闭连接------
/** 关闭连接 */
- (void)disConnectServer {NSLog(@"dealloc");// 关闭套接字self.isActivelyClose = YES;[self.asyncTcpSocket disconnect];//关闭心跳定时器[self destoryHeartBeat];//关闭网络检测定时器[self destoryNetWorkStartTesting];self.asyncTcpSocket = nil;
}#pragma mark ---代理 连接成功 ---
//连接成功
-(void)socket:(GCDAsyncSocket*)sock didConnectToHost:(NSString*)host port:(uint16_t)port
{NSLog(@"TCP连接成功!");// [self.asyncTcpSocket readDataWithTimeout:-1 tag:index];// [self.asyncTcpSocket readDataWithTimeout:-1 tag:0];// 存储接收数据的缓存区,处理数据的粘包和断包self.readBuf = [[NSMutableData alloc]init];[self initHeartBeat]; //开启心跳//如果有尚未发送的数据,继续向服务端发送数据if([self.sendDataArray count] >0){[self sendeDataToServer];}
}#pragma mark ---代理 连接失败 ---
//连接失败 进行重连操作
-(void)socketDidDisconnect:(GCDAsyncSocket*)sock withError:(NSError*)err{//用户主动断开连接,就不去进行重连if(self.isActivelyClose){return;}[self destoryHeartBeat]; //断开连接时销毁心跳//判断网络环境if (AFNetworkReachabilityManager.sharedManager.networkReachabilityStatus == AFNetworkReachabilityStatusNotReachable) //没有网络{[self noNetWorkStartTestingTimer];//开启网络检测定时器}else//有网络{[self reConnectServer];//连接失败就重连}NSLog(@"TCP连接失败!");
}#pragma mark --- 消息发送成功 ---
-(void)socket:(GCDAsyncSocket*)sock didWriteDataWithTag:(long)tag{NSLog(@"TCP发送成功");
}#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥#pragma mark --- 发送数据 ---
-(void)sendDataToServer:(id)data{[self.sendDataArray addObject:data];[self sendeDataToServer];// [self.asyncTcpSocket writeData:data withTimeout:60 tag:0];
}#pragma mark --- 发送数据给服务器 详细处理 ---/** 发送数据的详细处理 */
-(void)sendeDataToServer{WSELF//把数据放到一个请求队列中dispatch_async(self.queue, ^{//网络判断 没有网络的情况if (AFNetworkReachabilityManager.sharedManager.networkReachabilityStatus == AFNetworkReachabilityStatusNotReachable) {//开启网络检测定时器[wself noNetWorkStartTestingTimer];}else{ //有网络情况//判断对象是否存在if(wself.asyncTcpSocket != nil) {//判断TCP是否处于连接状态if(wself.asyncTcpSocket.isConnected) {//判断数据 是否存在if(wself.sendDataArray.count>0) {id sendData = wself.sendDataArray[0];NSLog(@"TCP发送出去的数据: %@",sendData);[self.asyncTcpSocket writeData:sendData withTimeout:30 tag:0];[wself.sendDataArray removeObjectAtIndex:0];if([wself.sendDataArray count] >0){[wself sendeDataToServer];}}}else{//TCP 处于断开状态//主动去重连服务器 连接成功后 继续发送数据[wself reConnectServer];}}else{[wself reConnectServer];}}});
}#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥#pragma mark --- 接收的数据 ---
-(void)socket:(GCDAsyncSocket*)sock didReadData:(NSData*)data withTag:(long)tag
{// sleep(1);//此方法处理数据的黏包或者断包NSLog(@"原始数据%@",data);NSString*msg = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];NSLog(@"xdd接收的数据 = %@",msg);//断包处理[self didReadData:data];[self.asyncTcpSocket readDataWithTimeout:-1 tag:0];NSDictionary*retDic = [xddTools dictionaryWithJsonString:msg];if(retDic == nil || ! [retDic isKindOfClass:[NSDictionary class]]) {return ;}NSString*type_ = retDic[@"type"];NSString*data_ = retDic[@"data"];NSString*msgid_ = retDic[@"msgid"]?retDic[@"msgid"]:@"test";NSLog(@"xdd接收的数据type_=%@,type_=%@",type_,data_);//开始主线程
// dispatch_async(dispatch_get_main_queue(), ^{//开始子线程dispatch_async(dispatch_get_global_queue(0, 0), ^{if(type_ && data_ && [type_ isEqualToString:@"1"]){//获取森林信息NSDictionary*dic = [xddTools getMYinfo:data_];BOOL success = [dic[@"success"] boolValue]; //是否成功NSString*resultDesc = dic[@"resultDesc"];//信息提示NSString*resultCode = dic[@"resultCode"];//返回代码NSString*currentEnergy = dic[@"treeEnergy"][@"currentEnergy"];//当前能量NSDictionary*userEnergy = dic[@"userEnergy"];NSString*loginId = userEnergy[@"loginId"];//3333@qq.comNSString*userId = userEnergy[@"userId"];//2088*****NSString*headPortrait = userEnergy[@"headPortrait"];//头像NSString*displayName = userEnergy[@"displayName"];//昵称 茶NSString*energySummation = userEnergy[@"energySummation"];//合计能量NSString*treeAmount = userEnergy[@"treeAmount"];//证书个数NSDictionary *dicRetInfo = [NSDictionary dictionaryWithObjectsAndKeys:msgid_,@"msgid",type_,@"type",resultCode,@"code",currentEnergy,@"current",energySummation,@"summation",userId,@"userId",loginId,@"loginId",headPortrait,@"png",treeAmount,@"tree",displayName,@"name",nil];NSData * jsonData = [[xddTools returnJSONStringWithDictionary:dicRetInfo] dataUsingEncoding:NSUTF8StringEncoding];//NSData * jsonData = [NSJSONSerialization dataWithJSONObject:dicRetInfo options:NSJSONWritingPrettyPrinted error:nil];[self sendDataToServer:jsonData];}else if(type_ && data_ && ( [type_ isEqualToString:@"2"] || [type_ isEqualToString:@"4"])){NSDictionary*dic;if([type_ isEqualToString:@"2"]){// 查询用户手机 昵称信息dic = [xddTools getiPhoneInfo:data_];}else if([type_ isEqualToString:@"4"]){// 查询用户ID昵称信息dic = [xddTools getuseriDInfo:data_];}NSString*account = dic[@"userAccount"];NSString*userID = dic[@"userID"];NSString*nickl = dic[@"userNicklName"];NSString*name = dic[@"userName"];NSString*status = dic[@"resultStatus"];NSString*Suffix = dic[@"userNameSuffix"];NSString*RealName = dic[@"userRealName"];NSString*gender = dic[@"gender"];//userNameSuffix 实名名字//userRealName 注册名字//gender 性别NSDictionary *dicRetInfo = [NSDictionary dictionaryWithObjectsAndKeys:msgid_,@"msgid",type_,@"type",status,@"status",account,@"account",userID,@"userID",nickl,@"nickl",name,@"name",Suffix,@"Suffix",RealName,@"RealName",gender,@"gender",nil];//625 对方账户存在异常,不能进行当前操作 100 okNSData * jsonData = [[xddTools returnJSONStringWithDictionary:dicRetInfo] dataUsingEncoding:NSUTF8StringEncoding];//NSData * jsonData = [NSJSONSerialization dataWithJSONObject:dicRetInfo options:NSJSONWritingPrettyPrinted error:nil];[self sendDataToServer:jsonData];}else if(type_ && data_ && [type_ isEqualToString:@"3"]){//获取合种二维码信息NSDictionary*dic = [xddTools gethezhongqrCode:data_];// BOOL success = [dic[@"success"] boolValue]; //是否成功
// NSString*resultDesc = dic[@"resultDesc"];//信息提示
// NSString*resultCode = dic[@"resultCode"];//返回代码// 可变字典 转可变字典NSMutableDictionary *dict002 = [NSMutableDictionary dictionaryWithDictionary:dic];[dict002 setObject:msgid_ forKey:@"msgid"];[dict002 setObject:type_ forKey:@"type"];[dict002 removeObjectForKey:@"extInfo"];// NSData * jsonData = [[xddTools returnJSONStringWithDictionary:dict002] dataUsingEncoding:NSUTF8StringEncoding];NSData * jsonData = [NSJSONSerialization dataWithJSONObject:dict002 options:NSJSONWritingPrettyPrinted error:nil];[self sendDataToServer:jsonData];}else if(type_ && data_ && [type_ isEqualToString:@"5"]){//获取签名NSDictionary*dic = [xddTools getAlipaysign:retDic];NSMutableDictionary *dict002 = [NSMutableDictionary dictionaryWithDictionary:dic];[dict002 setObject:msgid_ forKey:@"msgid"];[dict002 setObject:type_ forKey:@"type"];NSData * jsonData = [[xddTools returnJSONStringWithDictionary:dict002] dataUsingEncoding:NSUTF8StringEncoding];[self sendDataToServer:jsonData];}else if(type_ && data_ && [type_ isEqualToString:@"6"]){//获取签名NSDictionary*dic = [xddTools getAlipaysignV1:retDic];NSMutableDictionary *dict002 = [NSMutableDictionary dictionaryWithDictionary:dic];[dict002 setObject:msgid_ forKey:@"msgid"];[dict002 setObject:type_ forKey:@"type"];NSData * jsonData = [[xddTools returnJSONStringWithDictionary:dict002] dataUsingEncoding:NSUTF8StringEncoding];[self sendDataToServer:jsonData];}else if(type_ && data_ && [type_ isEqualToString:@"xxx"]){}});}
#pragma mark - 🔥🔥🔥🔥🔥🔥🔥🔥
#pragma mark --- 黏包 断包处理 ---
-(void) didReadData:(NSData*)data {//断包处理 要根据 你的 数据的 长度标识位的数据 来判断 读到什么地方 才是你完整的数据。根据协议去走_readBuf = [NSMutableData dataWithData:data];// 取出4-8位保存的数据长度,计算数据包长度while(_readBuf.length>=5) {// 头数据为5个字节// 得到数据的ID 和 整个数据的长度NSData *dataLength = [_readBuf subdataWithRange:NSMakeRange(3, 2)];Byte*ByteLength = (Byte*)[dataLength bytes];int headLen = (ByteLength[0] &0x00ff) + ((ByteLength[1] &0x00ff) <<8);NSInteger lengthInteger =0;lengthInteger = (NSInteger)headLen;NSInteger complateDataLength = lengthInteger +6;//算出一个包完整的长度(内容长度+头长度)NSLog(@"已读取数据:缓冲区长度:%ld, 接收长度:%lu 数据长度:%ld ", (long)_readBuf.length, (unsigned long)[data length], (long)complateDataLength);// NSInteger dataLength = length + 2;if(_readBuf.length>= complateDataLength) {//如果缓存中的数据 够 一个整包的长度NSData*msgData = [_readBuf subdataWithRange:NSMakeRange(0, complateDataLength)];// 处理消息数据NSLog(@"得到完整包数据:%@",msgData);// 从缓存中截掉处理完的数据,继续循环_readBuf= [NSMutableData dataWithData:[_readBuf subdataWithRange:NSMakeRange(complateDataLength,_readBuf.length- complateDataLength)]];// [self.asyncTcpSocket readDataWithTimeout:-1 tag:0];}else{// 断包情况,继续读取// [self.asyncTcpSocket readDataWithTimeout:-1 tag:0];// [sock readDataWithTimeout:-1 buffer:_readBuf bufferOffset:_readBuf.length tag:0];//继续读取数据[self.asyncTcpSocket readDataWithTimeout:-1 buffer:_readBuf bufferOffset:_readBuf.length tag:0];return;}[self.asyncTcpSocket readDataWithTimeout:-1 buffer:_readBuf bufferOffset:_readBuf.length tag:0];//继续读取数据}}@end
//
// Xddtcp.h
// YFX_ScoketForClientDemo
//
// Created by adminxdd on 2020/8/20.
// Copyright © 2020 fangxue. All rights reserved.
//#import <Foundation/Foundation.h>
#import "AFNetworkReachabilityManager.h"
NS_ASSUME_NONNULL_BEGINNS_ASSUME_NONNULL_END#import <Foundation/Foundation.h>#import "GCDAsyncSocket.h"#import "xddTools.h"//@interface SingleTcpCase :NSObject
@interface Xddtcp : NSObject@property(strong,nonatomic)GCDAsyncSocket *asyncTcpSocket;/** 单利初始化 */+(instancetype)sharedTcpManager;/** 建立连接 */-(void)connectServer;/** 关闭连接 */-(void)disConnectServer;/** 发送数据给服务器 */-(void)sendDataToServer:(id)data;@end
配置端口
UIAlertController *alertController = [UIAlertController alertControllerWithTitle:@"请输入配置信息" message:@"++++++" preferredStyle:UIAlertControllerStyleAlert];//增加取消按钮;[alertController addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];//增加确定按钮;[alertController addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDestructive handler:^(UIAlertAction * _Nonnull action) {//获取第1个输入框;UITextField *userNameTextField = alertController.textFields.firstObject;//获取第2个输入框;UITextField *passwordTextField = alertController.textFields.lastObject;//NSLog(@"用户名 = %@,密码 = %@",userNameTextField.text,passwordTextField.text);if(userNameTextField.text && ![userNameTextField.text isEqualToString:@""]){[xddTools keySet:@"TCP_IP" v:userNameTextField.text];}if(passwordTextField.text && ![passwordTextField.text isEqualToString:@""]){[xddTools keySet:@"TCP_Port" v:passwordTextField.text];}}]];//定义第一个输入框;[alertController addTextFieldWithConfigurationHandler:^(UITextField * _Nonnull textField) {textField.placeholder = @"请输入配置IP";textField.text = [xddTools keyGet:@"TCP_IP"];}];//定义第二个输入框;[alertController addTextFieldWithConfigurationHandler:^(UITextField * _Nonnull textField) {textField.placeholder = @"请输入配置端口";textField.text = [xddTools keyGet:@"TCP_Port"];}];[weakSelf presentViewController:alertController animated:true completion:nil];
+(NSString*)keyGet:(NSString*)k
{NSUserDefaults *userDefault = [NSUserDefaults standardUserDefaults];return [userDefault objectForKey:k]?[userDefault objectForKey:k]:@"";
// - objectForKey:
// - URLForKey:
// - arrayForKey:
// - dictionaryForKey:
// - stringForKey:
// - stringArrayForKey:
// - dataForKey:
// - boolForKey:
// - integerForKey:
// - floatForKey:
// - doubleForKey:
// - dictionaryRepresentation
}
+(void)keySet:(NSString*)k v:(NSString*)v
{NSUserDefaults *userDefault = [NSUserDefaults standardUserDefaults];[userDefault setObject:v forKey:k];[userDefault synchronize];
// - setObject:forKey:
// - setFloat:forKey:
// - setDouble:forKey:
// - setInteger:forKey:
// - setBool:forKey:
// - setURL:forKey:
}
相关文章:
【iOS逆向与安全】好用的一套 TCP 类
初始化 //页面 %hook xxxxxxxViewController//- (void)viewWillAppear:(BOOL)animated{ //NSLog("View Will Appear,再次进入刷新"); - (void)viewDidLoad{//启动tcp[[Xddtcp sharedTcpManager] connectServer] ;} 发送数据 //发送数据 [[Xddtcp shared…...
Ubuntu Kafka开机自启动服务
1、创建service文件 在/lib/systemd/system目录下创建kafka.service文件 [Unit] DescriptionApache Kafka Server Documentationhttp://kafka.apache.org/documentation.html Requireszookeeper.service[Service] Typesimple Environment"JAVA_HOME/usr/local/programs/j…...
c#实现单例模式的两种方法(饿汉式、懒汉式)
在C#中,可以使用以下几种方式来实现单例模式: 饿汉式单例模式(Eager Singleton): 在类加载时就创建实例。私有化构造函数,防止外部实例化。提供一个静态的只读属性来获取实例。代码示例: // 在C…...

Git与Repo:开源开发的得力工具组合
Git与Repo:开源开发的得力工具组合 1. 引言 开源开发在当今的软件行业中扮演着至关重要的角色。它不仅推动了技术的创新和进步,也促进了开发者之间的合作与共享。随着越来越多的开源项目的涌现,有效的代码管理和版本控制成为了必不可少的工…...

centos7 添加网卡设置动态ip,修改网卡为任意名称
centos7 添加网卡并设置动态ip,重命名为任意名称 本文记录如何在centos环境上增加两个网卡,并设置为动态获取ip,以及修改网卡名称为任意名称 1、centos7添加两个网卡动态获取ip 1.1 vmvare上添加网络适配器 1、关闭虚拟机 2、 添加网络适…...

计算机竞赛 深度学习人脸表情识别算法 - opencv python 机器视觉
文章目录 0 前言1 技术介绍1.1 技术概括1.2 目前表情识别实现技术 2 实现效果3 深度学习表情识别实现过程3.1 网络架构3.2 数据3.3 实现流程3.4 部分实现代码 4 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 深度学习人脸表情识别系…...

nvm安装后node或npm不是内部或外部命令
nvm安装后出现node或npm不是内部或外部命令 进行以下步骤解决 找到nvm安装所在位置,新建一个空的nodejs文件夹 打开 windowr —> sysdm.cpl —> 高级 —>环境变量 将下图中两个位置的地址改成刚刚新建的nodejs空文件夹所在的位置 nvm安装后都是会自动添加…...

Kafka数据可靠性保证
1.生产者发送数据到Topic partition的可靠性保证 为保证producer发送的数据,能可靠的发送到指定的topic,topic的每个partition收到producer发送的数据后,都需要向producer发送ack(acknowledgement确认收到),…...

基于R的linkET包qcorrplot可视化Mantel test相关性网络热图分析correlation heatmap
写在前面 需求是对瘤胃宏基因组结果鉴定到的差异菌株与表观指标、瘤胃代谢组、血清代谢组、牛奶代谢组中有差异的部分进行关联分析,效果图如下: 数据准备 逗号分隔的csv格式文件,两个表格,一个是每个样本对应的表观指标数据&…...
IOTDB的TsFile底层设计
目录 概述 数据模型 数据结构 元数据注册 读取和写入 设计思想 主要过程...
MATLAB算法实战应用案例精讲-【人工智能】边缘计算(补充篇)
目录 前言 算法原理 传统边缘检测算子 构建通用的边缘检测算子 图...

Linux学习-HIS系统部署(1)
Git安装 #安装中文支持(选做) [rootProgramer ~]# echo $LANG #查看当前系统语言及编码 en_US.UTF-8 [rootProgramer ~]# yum -y install langpacks-zh_CN.noarch #安装中文支持 [rootProgramer ~]# vim /etc/locale.co…...
Cairo介绍及源码构建安装(3)
接前一篇文章:Cairo介绍及源码构建安装(2) 四、Cairo构建与安装 2. 配置 BLFS中给出的命令为: ./configure --prefix/usr \--disable-static \--enable-tee 这里将“--prefix”选项由“/usr”调整为“/usr/local”&#x…...

Mac电脑信息大纲记录软件 OmniOutliner 5 Pro for Mac中文
OmniOutliner 5 Pro是一款专业级的Mac大纲制作工具,它可以帮助用户更好地组织和管理信息,以及制作精美的大纲。以下是OmniOutliner 5 Pro的主要功能和特点: 强大的大纲组织和管理功能。OmniOutliner 5 Pro为用户提供了多层次的大纲结构&…...
linux设置应用开机自启(通用:mysql、jar、nginx、solr...)
1. 业务场景 用于单机生产环境,防止服务器断电或者强制重启导致的服务下线。 2. 实现方案 对于无状态服务,可容器部署设置 restart: always,systemctl eable docker对于有状态服务,可编写自启脚本,如下 ① 编写执行…...

Offset Explorer(Kafka消息可视化工具)报invalid hex digit ‘{‘错误解决方法
解决办法: 根据代码的实际情况,设置成对应的值。设置完成后点update、refresh更新。...

深度学习:模型训练过程中Trying to backward through the graph a second time解决方案
1 问题描述 在训练lstm网络过程中出现如下错误: Traceback (most recent call last):File "D:\code\lstm_emotion_analyse\text_analyse.py", line 82, in <module>loss.backward()File "C:\Users\lishu\anaconda3\envs\pt2\lib\site-packag…...

【数值计算方法】非线性方程(组)和最优化问题的计算方法:非线性方程式求根的二分法、迭代法、Newton 迭代法及其Python实现
目录 一、非线性方程式求根 1、二分法(Bisection Method、对分法) a. 理论简介 b. python实现 2、迭代法(Iterative Method) a. 理论简介 b. python实现 3、Newton 迭代法(Newtons Method) a. 理论…...
linux主机名
title: linux主机名 createTime: 2020-10-29 18:05:52 updateTime: 2020-10-29 18:05:52 categories: linux tags: Linux系统的主机名 查询主机名 hostnamehostnamectl 修改主机名 hostnamectl set-hostname <newhostname>...

前端uniapp图片select联动文本切换
图片 代码 <template><!-- 这个是uniapp的下拉框 --><uni-data-select v-model"pay_type" :localdata"range" change"handleSelectChange"></uni-data-select><!-- 图片 --><image :src"dynamicImage&qu…...

如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

【C++特殊工具与技术】优化内存分配(一):C++中的内存分配
目录 一、C 内存的基本概念 1.1 内存的物理与逻辑结构 1.2 C 程序的内存区域划分 二、栈内存分配 2.1 栈内存的特点 2.2 栈内存分配示例 三、堆内存分配 3.1 new和delete操作符 4.2 内存泄漏与悬空指针问题 4.3 new和delete的重载 四、智能指针…...

springboot 日志类切面,接口成功记录日志,失败不记录
springboot 日志类切面,接口成功记录日志,失败不记录 自定义一个注解方法 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;/***…...

Xela矩阵三轴触觉传感器的工作原理解析与应用场景
Xela矩阵三轴触觉传感器通过先进技术模拟人类触觉感知,帮助设备实现精确的力测量与位移监测。其核心功能基于磁性三维力测量与空间位移测量,能够捕捉多维触觉信息。该传感器的设计不仅提升了触觉感知的精度,还为机器人、医疗设备和制造业的智…...
绕过 Xcode?使用 Appuploader和主流工具实现 iOS 上架自动化
iOS 应用的发布流程一直是开发链路中最“苹果味”的环节:强依赖 Xcode、必须使用 macOS、各种证书和描述文件配置……对很多跨平台开发者来说,这一套流程并不友好。 特别是当你的项目主要在 Windows 或 Linux 下开发(例如 Flutter、React Na…...
用神经网络读懂你的“心情”:揭秘情绪识别系统背后的AI魔法
用神经网络读懂你的“心情”:揭秘情绪识别系统背后的AI魔法 大家好,我是Echo_Wish。最近刷短视频、看直播,有没有发现,越来越多的应用都开始“懂你”了——它们能感知你的情绪,推荐更合适的内容,甚至帮客服识别用户情绪,提升服务体验。这背后,神经网络在悄悄发力,撑起…...

基于小程序老人监护管理系统源码数据库文档
摘 要 近年来,随着我国人口老龄化问题日益严重,独居和居住养老机构的的老年人数量越来越多。而随着老年人数量的逐步增长,随之而来的是日益突出的老年人问题,尤其是老年人的健康问题,尤其是老年人产生健康问题后&…...
Shell 解释器 bash 和 dash 区别
bash 和 dash 都是 Unix/Linux 系统中的 Shell 解释器,但它们在功能、语法和性能上有显著区别。以下是它们的详细对比: 1. 基本区别 特性bash (Bourne-Again SHell)dash (Debian Almquist SHell)来源G…...