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- ...
随机推荐
- Pandas系列(七)-计算工具介绍
内容目录 1. 统计函数 2. 窗口函数 3. 加深加强 数据准备 # 导入相关库 import numpy as np import pandas as pd #Pandas 中包含了非常丰富的计算 ...
- 老男孩Python全栈学习 S9 日常作业 006
1.使用循环打印以下效果: 1: * ** *** **** ***** 2: ***** **** *** ** * 3: * *** ***** ******* ********* for i i ...
- Ceph集群搭建及Kubernetes上实现动态存储(StorageClass)
集群准备 ceph集群配置说明 节点名称 IP地址 配置 作用 ceph-moni-0 10.10.3.150 centos7.5 4C,16G,200Disk 管理节点,监视器 monitor ...
- C++回顾day03---<多态>
一:错误理解下的多态 #include <iostream> using namespace std; class Parent { public: Parent() { cout < ...
- JavaScript 基本包装类型,包装对象
前言 javascript对象是一种复合值,它是属性或已命名值的集合.通过'.'符号来引用属性值.当属性值是一个函数时,称其为方法.通过o.m()来调用对象o中的方法.我们发现,字符串也同样具有属性和 ...
- MyEclipse 2015 Stable 2.0破解方法
本篇博文简单介绍一下利用网上说明的方法破解MyEclipse 2015 Stable 2.0的具体细节.因为原来在贴吧上的方法不够详细,所以本人重新整理了一下.方法源自:http://tieba.ba ...
- MySQL高可用——PXC简介
序言 Percona XtraDB Cluster(简称PXC集群)提供了MySQL高可用的一种实现方法. PXC属于一套近乎完美的mysql高可用集群解决方案,相比那些比较传统的基于主从复制模式的集 ...
- Beamer制作索引
\documentclass{beamer} \usepackage{multicol} \usepackage{makeidx} \newenvironment{theindex}{% \let\i ...
- [再寄小读者之数学篇](2014-06-20 求极限-L'Hospital 法则的应用)
设 $f\in C[0,+\infty)$, $a$ 为实数, 且存在有限极限 $$\bex \vlm{x}\sez{f(x)+a\int_0^x f(t)\rd t}. \eex$$ 证明; $f( ...
- Linux 下软件的安装方法
1:rpm 安装 ,rpm安装会有依赖问题,例如安装A,提示需要安装B 安装B需要安装C 格式: rpm -ivh [包名].rpm 2:yum 安装 特点:简单.易用.高校 缺点:不能定制 解决 ...