目录
0.简介
- 本文属于一个系列中的第二篇文章,这个系列会实现一个项目,这个项目主要使用Visual Studio 2019作为开发工具,创建WCF服务、创建Web应用程序调用WCF服务等功能
- 本文主要介绍如何通过 Visual Studio 2019 来创建一个ASP.NET Web应用程序,来使用上一章实现的WCF服务,这个服务实现的功能是返回数学中Pi的值。
1.环境
Visual Studio 2019 + c# + windows11
2.知识点
3.详细过程
1)创建空项目
打开VS2019,添加新项目,搜索【web application】,找到【ASP.NET Web应用程序】,有两种,一个是VB语言,一个是C#语言,我选择的是C#
data:image/s3,"s3://crabby-images/4c5a2/4c5a27918f0bde41601bbc3dcd49cd1c0970ead8" alt=""
data:image/s3,"s3://crabby-images/0f258/0f25828385bc3a8708c6d18b5d4f16e8c6dc3daa" alt=""
选择后,点击右下角的【下一步】
修改自定义的项目名称,点击右下角的【创建】
data:image/s3,"s3://crabby-images/ff26b/ff26b3a2f9d9c47cb1b603599baff39f4901d44a" alt=""
新窗口,模板选择【空】即可
data:image/s3,"s3://crabby-images/bc09f/bc09f748a3351b76733cdc2491a5ee96ec6b3531" alt=""
新建的目录是这样的
data:image/s3,"s3://crabby-images/7432f/7432f77c18211a5d69c68309933cfa9252ccb993" alt=""
2)添加Web表单
右键项目名字,选择【添加】-【新建项】
data:image/s3,"s3://crabby-images/e29c9/e29c93bad2875693ac36a9ca7c757fbeeabc73e3" alt=""
在【Web】中,选择【Web窗体】或【Web Form】,可以修改自定义名称,通常叫【Default】,点击添加
data:image/s3,"s3://crabby-images/2abf6/2abf6de10ffced5ed9617b7302e9ca8a05d14835" alt=""
添加后目录如下
data:image/s3,"s3://crabby-images/a1fe3/a1fe3a120ab488586134e16524ab9ce6e0b7f944" alt=""
Default是一个页面,语言是xhtml,是html的变体
我们有两种形式编辑这个页面:用界面控件拖动的方式(类似GUI),以及纯代码书写,如下图所示,点击【设计】,是界面,可以拖动控件;点击【源】,则是纯代码。
data:image/s3,"s3://crabby-images/bcdf0/bcdf0a008e94cf7c4bc2695c5ac5ce3f33cda6b3" alt=""
如果使用【设计】模式,可以在右侧边栏的【工具箱】中找到很多控件,如button、label等,拖动即可
data:image/s3,"s3://crabby-images/b3798/b3798a43f290f8b1f881bf1f3dd163035aa761c9" alt=""
3)使用Web表单的GUI设计
我们做一个最简单的界面,来显示WCF服务获取的PI值。我用了一个button和一个label
data:image/s3,"s3://crabby-images/fd4a3/fd4a36a02ece6cb104c447753e0237a747437844" alt=""
如果你想修改按钮的属性,注意,属性不是显示的TEXT,修改属性可以在【源】中修改button相关代码的【ID】字段
data:image/s3,"s3://crabby-images/adfae/adfaebbdf12b26bfd3a6db11e871e30e52fcf4c0" alt=""
如果你想修改按钮的显示的文字,可以修改【Text】字段
data:image/s3,"s3://crabby-images/4a45b/4a45b8757ff570a3b378efebd75f59b0224426f4" alt=""
data:image/s3,"s3://crabby-images/83186/831861414c2a74f7506cb48a9b9b86fcc3be0c64" alt=""
双击【button】会自动跳转到【Default.aspx.cs】文件,新增一个点击button后触发的接口,我们在这个接口中实现点击button需要做的事情:获取WCF服务的PI值
data:image/s3,"s3://crabby-images/6b129/6b1299bfab236f50cc9393826d416857d7f69b9e" alt=""
4)添加服务引用
准备工作:复制WCF的服务链接
首先我们要打开WCF项目,注意是上一篇博客实现的WCF项目,我的WCF项目名字为【WcfService1】,然后找到【Service1.svc】,右键.svc,选择【在浏览器中查看】,这个时候会打开浏览器出现一个服务界面,复制这个链接。
data:image/s3,"s3://crabby-images/697f3/697f37e27de512c3bae55938654c2931355eb564" alt=""
data:image/s3,"s3://crabby-images/891ea/891eab8ac512dc373d876477fcc64fd89cef904b" alt=""
每个人的链接都不一样,请复制你的WCF服务链接
data:image/s3,"s3://crabby-images/b39f1/b39f11d00264d626dda499d0adf6ff017a38894e" alt=""
复制完链接后,我们的准备工作已经做完了,回到我们的Web项目,右键项目名称,选择【添加】-【服务引用】
data:image/s3,"s3://crabby-images/8f16a/8f16aed6ffbc9a1130c63bfe39a454a55f150d39" alt=""
data:image/s3,"s3://crabby-images/0fd39/0fd390718426110b08ce561fcc44c72f403d5648" alt=""
请将复制的链接粘贴在【地址】中,然后点击【转到】,会出现Service1的列表
data:image/s3,"s3://crabby-images/1440d/1440dd1e90ca822cf4b1a5bc43d4b3927bf577f0" alt=""
然后在服务窗口中,点一下IService1,也就是上图中的第3步,右侧空白处就会出现你这个服务所实现的具体服务名称
data:image/s3,"s3://crabby-images/4cbaa/4cbaadd1265aae3b59942bc92e0c6ba994da3cbf" alt=""
这里我们只是用PiValue就好,其余几个都是写的例子,你可以在下方的【命名空间】修改自己的服务名字,一会我们在代码里调用时需要用到这个名字,我就用默认的【ServiceReference1】,然后点击【确定】
data:image/s3,"s3://crabby-images/718d2/718d22b1f466b66c73c1faf1c55e2fde1c95ddcb" alt=""
5)在Web的button函数中调用服务,获取PI值
我们找到Web服务项目中的【】,找到双击button产生的点击函数,输入代码,将服务注册到按钮事件中
data:image/s3,"s3://crabby-images/6086d/6086d95a4dd1488c6a34d4ee7abcf5459909040e" alt=""
cs
protected void Button1_Click(object sender, EventArgs e)
{
ServiceReference1.Service1Client prxy = new ServiceReference1.Service1Client();
Label1.Text = Convert.ToString(prxy.PiValue());
}
6)测试
在Web项目,右键【Default.aspx】选择【设为起始页】,这样执行的时候就会从这个函数开始执行
data:image/s3,"s3://crabby-images/c8bdc/c8bdcc4953c133afda81bc065c677822326ea85e" alt=""
在VS2019上边栏中,选择【调试】-【开始调试】
data:image/s3,"s3://crabby-images/9473a/9473ac7ac9a11a395350f335f4790cef7f9bc7f5" alt=""
会打开一个网页
data:image/s3,"s3://crabby-images/8006d/8006d9df6d6fbf8266458db14677f26b0db2c27d" alt=""
点击按钮,label处就会显示PI值了
data:image/s3,"s3://crabby-images/185a8/185a8a56c23f33a7b0cb6e46987dee6b0791634e" alt=""
至此,WCF + ASP.NET Web的项目就结束啦,主要功能是实现在页面获取WCF服务产生的PI值,如有过程有问题,欢迎批评指正
--END--