电力负控终端原理图和PCB,分享给需求的人。
文件列表2008-05-0315:52114,688001-GPRS.SchDoc2008-05-0314:33340,480GPRS.PcbDoc2008-05-0315:5129,855GPRS.PrjPcb2008-05-0311:12206,336001-CPU.SchDoc2008-05-0311:1253,760002-Memory.SchDoc2008-05-0311:15221,184003-CtrlIO.SchDoc2008-05-0311:15319,488004-Com.SchDoc2008-05-0315:5252,736005-Power.SchDoc2008-05-0311:17156,160006-LCD.SchDoc2008-04-2412:4410,752007-Port.SchDoc2008-05-0315:53335,872008-计量.SchDoc2008-05-0315:381,932,800393-3.PcbDoc2008-05-0315:5339,578Main.PrjPCB2008-04-2911:1110,752main.SchDoc2008-05-0317:011,932,800CopyofPowerNet08A主板V1.0.PCBDOC2008-05-0317:26352,256CopyofPowerNet08A电源板V1.0.PCBDOC2008-05-0316:07402,285PCB-OK.rar2008-05-0314:54340,480PowerNet08A-GPRSV1.0.PcbDoc2008-05-0311:331,932,800PowerNet08A主板V1.0.PCBDOC2008-05-0315:45352,256PowerNet08A电源板V1.0.PCBDOC2008-05-0315:53124,452Schemati.pdf
2023/3/4 16:32:31 1.92MB 电子产品
1
首先要理解基本的原理,2台电脑间实现TCP通讯,首先要建立起连接,在这里要提到服务器端与客户端,两个的区别通俗讲就是主动与被动的关系,两个人对话,肯定是先有人先发起会话,要不然谁都不讲,谈什么话题,呵呵!一样,TCPIP下建立连接首先要有一个服务器,它是被动的,它只能等待别人跟它建立连接,自己不会去主动连接,那客户端如何去连接它呢,这里提到2个东西,IP地址和端口号,通俗来讲就是你去拜访某人,知道了他的地址是一号大街2号楼,这个是IP地址,那么1号楼这么多门牌号怎么区分,嗯!门牌号就是端口(这里提到一点,我们访问网页的时候也是IP地址和端口号,IE默认的端口号是80),一个服务器可以接受多个客户端的连接,但是一个客户端只能连接一台服务器,在连接后,服务器自动划分内存区域以分配各个客户端的通讯,那么,那么多的客户端服务器如何区分,你可能会说,根据IP么,不是很完整,很简单的例子,你一台计算机开3个QQ,服务器怎么区分?所以准确的说是IP和端口号,但是客户端的端口号不是由你自己定的,是由计算机自动分配的,要不然就出现端口冲突了,说的这么多,看下面的这张图就简单明了了。
在上面这张图中,你可以理解为程序A和程序B是2个SOCKET程序,服务器端程序A设置端口为81,已接遭到3个客户端的连接,计算机C开了2个程序,分别连接到E和D,而他的端口是计算机自动分配的,连接到E的端口为789,连接到D的为790。
了解了TCPIP通讯的基本结构后,接下来讲解建立的流程,首先声明一下我用的开发环境是VisualStudio2008版的,语言C#,组件System.Net.Sockets,流程的建立包括服务器端的建立和客户端的建立,如图所示:二、实现:1.客户端:第一步,要创建一个客户端对象TcpClient(命名空间在System.Net.Sockets),接着,调用对象下的方法BeginConnect进行尝试连接,入口参数有4个,address(目标IP地址),port(目标端口号),requestCallback(连接成功后的返调函数),state(传递参数,是一个对象,随便什么都行,我建议是将TcpClient自己传递过去),调用完毕这个函数,系统将进行尝试连接服务器。
第二步,在第一步讲过一个入口参数requestCallback(连接成功后的返调函数),比如我们定义一个函数voidConnected(IAsyncResultresult),在连接服务器成功后,系统会调用此函数,在函数里,我们要获取到系统分配的数据流传输对象(NetworkStream),这个对象是用来处理客户端与服务器端数据传输的,此对象由TcpClient获得,在第一步讲过入口参数state,如果我们传递了TcpClient进去,那么,在函数里我们可以根据入口参数state获得,将其进行强制转换TcpClienttcpclt=(TcpClient)result.AsyncState,接着获取数据流传输对象NetworkStreamns=tcpclt.GetStream(),此对象我建议弄成全局变量,以便于其他函数调用,接着我们将挂起数据接收等待,调用ns下的方法BeginRead,入口参数有5个,buff(数据缓冲),offset(缓冲起始序号),size(缓冲长度),callback(接收到数据后的返调函数),state(传递参数,一样,随便什么都可以,建议将buff传递过去),调用完毕函数后,就可以进行数据接收等待了,在这里因为已经创建了NetworkStream对象,所以也可以进行向服务器发送数据的操作了,调用ns下的方法Write就可以向服务器发送数据了,入口参数3个,buff(数据缓冲),offset(缓冲起始序号),size(缓冲长度)。
第三步,在第二步讲过调用了BeginRead函数时的一个入口参数callback(接收到数据后的返调函数),比如我们定义了一个函数voidDataRec(IAsyncResultresult),在服务器向客户端发送数据后,系统会调用此函数,在函数里我们要获得数据流(byte数组),在上一步讲解BeginRead函数的时候还有一个入口参数state,如果我们传递了buff进去,那么,在这里我们要强制转换成byte[]类型byte[]data=(byte[])result.AsyncState,转换完毕后,我们还要获取缓冲区的大小intlength=ns.EndRead(result),ns为上一步创建的NetworkStream全局对象,接着我们就可以对数据进行处理了,如果获取的length为0表示客户端已经断开连接。
具体实现代码,在这里我建立了一个名称为Test的类:2.服务
2023/2/17 5:19:13 297KB TCP/IP C++ 协议
1
泊坞窗-wordpress在Docker容器中运转WordPress。
.env在名为.env的根目录中创建一个文件,在文件中放置以下内容。
根据需要修改此文件内容。
WORDPRESS_VERSION=5.0.3WORDPRESS_PORT=8083WORDPRESS_DB_USER=wordpressWORDPRESS_DB_PASSWORD=A7yXSYuJBSIixuWORDPRESS_DB_NAME=wordpress跑打开系统二进制文件,转到项目目录,然后运转以下命令。
docker-composeup-d
2023/2/11 5:10:16 2.52MB CSS
1
使用MongoDB表达BoillerplateRestfullApi核心堆栈Node.js-Express-Mongo数据库-https:猫鼬-https:nodemon-//www.npmjs.com/package/nodemonpm2-//www.npmjs.com/package/pm2特征使用jwt进行身份验证,登录,登记,注册,黑名单令牌,登记jwt用jwt验证路线粗俗的例子错误处理数据库不使用sqlmongodbmongoose用摩卡和柴测试覆盖范围使用istanbull与码头工人的例子验证,使用Express-Valdator分页示例自定义消息API响应埃斯林特爱彼迎基地单元测试怎么跑复制环境变量cp.env-sample.env手动运行#installpackagenpminstall#runningappnpmrundev#runningunittetsingnpmruntest尽早填写复制的环境APP_PORT=2000T
2023/2/4 14:02:34 96KB nodejs mocha mongodb tdd
1
默认情况下,Chrome的–proxy-server="http://ip:port"参数不支持设置用户名和密码认证。
但在启动代理IP时大多数会遇到需要通过用户名和密码验证来添加代理,本博客就遇到了这样的问题,查阅材料后,对整个思路做了一个封装,与大家共勉
2015/5/22 5:33:26 3KB 代理IP
1
编译好的floodlightv1.2.0版本。
该版本集成了web模块,可以通过http://ip:port/ui/index.html进行访问管理,对官网或者github中下载的发布版本启动后无法访问web进行了修复。
可以正常访问,紧缩包中有startup.sh的启动脚本。
配置好java1.8后,可以直接执行该脚本启动。
配置文件也在紧缩包中。
2015/10/1 12:23:56 67.54MB floodlight web
1
packageChatRoomTCPQQ谈天室;importjava.io.BufferedReader;importjava.io.IOException;importjava.io.InputStreamReader;importjava.io.PrintWriter;importjava.net.Socket;importjava.net.UnknownHostException;importjavax.swing.JOptionPane;publicclassChatRoomClent{privateSockets;publicChatRoomClent(Stringhost,intport){try{s=newSocket(host,port);}catch(UnknownHostExceptione){e.printStackTrace();}catch(IOExceptione){e.printStackTrace();}}publicvoidsendMessage(Stringstr){PrintWriterpw=null;try{pw=newPrintWriter(s.getOutputStream());pw.println(str);pw.flush();}catch(IOExceptione){e.printStackTrace();}}publicStringreciveMessage(){BufferedReaderbr=null;Stringstr="";try{br=newBufferedReader(newInputStreamReader(s.getInputStream()));str=br.readLine();}catch(IOExceptione){//TODOAuto-generatedcatchblocke.printStackTrace();}returnstr;}}
2019/5/10 14:54:12 15KB SocketTCP javaSocket java javaQQ聊天室 javaQQ
1
PjSIP实现视频通话,实现免提,SurfaceView上下叠加显示,并且能切换。
导入到Eclipse就能用。
jdk采用7的。
希望大家互相学习,只需改掉里面的ip和port以及对应分机的密码就能注册使用。
服务端我是用FS,能与电脑端的互相视频通信,视频编码采用H264.里面有完整的步骤以及代码。
1
针对官网下载较慢成绩,特意整理相关文件,提供各位大大便利,其中jar包启动命令“java-Dserver.port=808-jarsentinel-dashboard-1.8.1.jar”
2020/6/10 12:05:19 24.82MB 微服务 springsentinel
1
针对官网下载较慢成绩,特意整理相关文件,提供各位大大便利,其中jar包启动命令“java-Dserver.port=808-jarsentinel-dashboard-1.8.1.jar”
2018/4/14 2:19:18 24.82MB 微服务 springsentinel
1
共 80 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡