VB开发类似IIS简易的WebServer,代码不到100行
最近遇到三个人问关于VB写网页服务器的问题,所以今天抽时间写一下,演示其实没有多复杂。
代码里自定义的方法只有四个,没有公共变量绕来绕去,该注释的也都注释了。
想扩展更复杂的功能,就需要自己补脑HTTP协议。
新建一个VB工程,界面及控件如下:

文本框控件名不变,两个按钮的Name分别是 启动服务 和 关闭服务。然后粘贴以下代码进去:
(↓↓↓点+展开代码~.~)
Option Explicit
Private Const MAX_CLIENT = '最大连接数
'启动初始化和按钮代码
Private Sub Form_Load()
Dim i As Long
For i = To MAX_CLIENT
Load SCK(i) '预加载
Next i
End Sub
Private Sub 关闭服务_Click()
Dim i As Long
For i = To MAX_CLIENT
If SCK(i).State <> sckClosed Then SCK(i).Close
Next i
关闭服务.Enabled = False
End Sub
Private Sub 启动服务_Click()
On Error GoTo errline
SCK().LocalPort = '监听80端口,如果被占用,就改其他的,浏览器访问就需要127.0.0.1:8080的形式
SCK().Listen
启动服务.Enabled = False
关闭服务.Enabled = True
Exit Sub
errline:
Call ErrCatch
End Sub
'连接请求处理
Private Sub SCK_ConnectionRequest(Index As Integer, ByVal requestID As Long)
Dim i As Long
For i = To MAX_CLIENT
'如果winsock不处于"正在连接"和"已连接状态",就使用
If SCK(i).State <> sckConnected And SCK(i).State <> sckConnecting Then
If SCK(i).State <> sckClosed Then SCK(i).Close
SCK(i).Accept requestID
End If
Next i
End Sub
Private Sub SCK_Error(Index As Integer, ByVal Number As Integer, Description As String, ByVal Scode As Long, ByVal Source As String, ByVal HelpFile As String, ByVal HelpContext As Long, CancelDisplay As Boolean)
Call ErrCatch
SCK(Index).Close
End Sub
Private Sub SCK_SendComplete(Index As Integer)
Showlog "发送完成!"
SCK(Index).Close
End Sub
'接收处理
Private Sub SCK_DataArrival(Index As Integer, ByVal bytesTotal As Long)
Dim s As String
SCK(Index).GetData s
Dim urls() As String
Dim txt As String
urls = PickUrl(s)
If UBound(urls) = Then
txt = "欢迎访问,这是来自WebServer的内容!"
Else
Select Case urls()
Case "time": txt = "北京时间:" & Now
Case "ip": txt = "您的IP是:" & SCK(Index).RemoteHostIP
Case "test": txt = Replace(s, vbCrLf, "<BR />")
Case Else: txt = "欢迎访问,这是来自WebServer的内容!"
End Select
End If
SCK(Index).SendData Response(txt)
End Sub
'HTTP头响应头和内容的组装
Private Function Response(content As String) As String
Dim html As String
Dim b() As Byte
b = StrConv(content, vbFromUnicode)
html = html & "HTTP/1.1 200 OK" & vbCrLf
html = html & "Content-Type: text/html; charset=gb2312" & vbCrLf
html = html & "Connection: keep-alive" & vbCrLf
html = html & "Server: VB-WebServer" & vbCrLf
html = html & "Content-Length: " & (UBound(b) + ) & vbCrLf & vbCrLf
html = html & content & vbCrLf
Response = html
End Function
'提取请求URL的目录组成
Private Function PickUrl(request As String) As String()
Dim i As Long
Dim j As Long
Dim s As String
i = InStr(request, " ")
j = InStr(i + , request, " ")
s = Mid(request, i + , j - i - )
Showlog "收到:" & s
PickUrl = Split(s, "/")
End Function
'异常输出
Private Sub ErrCatch()
Showlog "异常" & Err.Number & "," & Err.Description
End Sub
'显示日志
Private Sub Showlog(msg As String)
Text1.Text = Text1.Text & msg & vbCrLf
Text1.SelStart = Len(Text1.Text)
End Sub
运行效果:

结束!
VB开发类似IIS简易的WebServer,代码不到100行的更多相关文章
- 100 行代码实现的 JavaScript MVC 样式框架
介绍 使用过 JavaScript框架(如 AngularJS, Backbone 或者Ember)的人都很熟悉在UI(用户界面,前端)中mvc的工作机理.这些框架实现了MVC,使得在一个单页面中实现 ...
- GuiLite 1.2 发布(希望通过这100+行代码来揭示:GuiLite的初始化,界面元素Layout,及消息映射的过程)
经过开发群的长期验证,我们发现:即使代码只有5千多行,也不意味着能够轻松弄懂代码意图.痛定思痛,我们发现:虽然每个函数都很简单(平均长度约为30行),可以逐个击破:但各个函数之间如何协作,却很难说明清 ...
- ESP8266开发之旅 网络篇⑪ WebServer——ESP8266WebServer库的使用
授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...
- JAVA开发类似冒险岛的游戏Part1
JAVA开发类似冒险岛的游戏Part1 一.总结 二.JAVA开发类似冒险岛的游戏Part1 初学嘛) ,不过总的来说这个程序还是很有意思的.这里我重新再整理了一下,希望能帮助到其他想要开发类似程序的 ...
- iOS开发系列--Objective-C之协议、代码块、分类
概述 ObjC的语法主要基于smalltalk进行设计的,除了提供常规的面向对象特性外,还增加了很多其他特性,这一节将重点介绍ObjC中一些常用的语法特性.当然这些内容虽然和其他高级语言命名不一样,但 ...
- 做了一个简易的git 代码自动部署脚本
做了一个简易的git 代码自动部署脚本 http://my.oschina.net/caomenglong/blog/472665 发表于2个月前(2015-06-30 21:08) 阅读(200 ...
- KoaHub平台基于Node.js开发的Koa 连接支付宝插件代码信息详情
KoaHub平台基于Node.js开发的Koa 链接支付宝插件代码信息详情 easy-alipay alipay payment & notification APIs easy-alipay ...
- 用Java为Hyperledger Fabric(超级账本)开发区块链智能合约链代码之部署与运行示例代码
部署并运行 Java 链代码示例 您已经定义并启动了本地区块链网络,而且已构建 Java shim 客户端 JAR 并安装到本地 Maven 存储库中,现在已准备好在之前下载的 Hyperledger ...
- 游戏开发中IIS常见支持MIME类型文件解析
游戏开发中IIS常见支持MIME类型文件解析 .apkapplication/vnd.android .ipaapplication/vnd.iphone .csbapplication/octet- ...
随机推荐
- hive笔记
cast cast(number as string), 可以将整数转成字符串 lpad rpad lpad(target, 10, '0') 表示在target字符串前面补0,构成一个长度为 ...
- LCA(Tarjan)
时间复杂度:dfs为O(N),dfs过程中处理所有查询对为O(M),总时间复杂度O(N+M) #include<iostream> #include<cstdio> using ...
- 小程序图片转Base64
在小程序中,有些业务要用到 图片的 base64 wx.chooseImage({ success: res => { wx.getFileSystemManager().readFile({ ...
- [物理学与PDEs]第5章习题9 伴随矩阵的特征值
设 $3\times 3$ 阵 ${\bf A}$ 的特征值为 $\lm_1,\lm_2,\lm_3$, 证明 $\cof {\bf A}$ 的特征值为 $$\bex \lm_2\lm_3,\quad ...
- Beta冲刺(6/7)
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(6/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 ppt制作 视频拍摄 接下来的计划 准备答辩 ...
- typecho视频播放插件JWPlayer
JWplayer for typecho是羽中大神开发并持续维护的一款插件,目前插件已经发布了8个版本,涵盖typecho0.8到1.0,插件基于原生的JWPlayer,可以说非常完美,详细使用方法在 ...
- 动态代理和CGlib
静态代理:静态代理的类也需要实现接口interface1,还要创建一个实现接口interface1的其他类class1,并且在静态代理类重写的方法中调用class1重写的方法.操作太多冗余.不好 动态 ...
- 洛谷P5280 [ZJOI2019]线段树 [线段树,DP]
传送门 无限Orz \(\color{black}S\color{red}{ooke}\)-- 思路 显然我们不能按照题意来每次复制一遍,而多半是在一棵线段树上瞎搞. 然后我们可以从\(modify\ ...
- bootstrap轮播图 两侧半透明阴影
用bootstrap轮播图:Carousel插件,图片两侧影音实在碍眼,想去掉,首先发现有css里由opacity: 0.5这个东西来控制,全部改成opacity: 0.0,发现指示箭头也看不见了. ...
- LuoGu P4996 咕咕咕
题目描述 小 F 是一个能鸽善鹉的同学,他经常把事情拖到最后一天才去做,导致他的某些日子总是非常匆忙. 比如,时间回溯到了 2018 年 11 月 3 日.小 F 望着自己的任务清单: 看 iG 夺冠 ...