打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
VB.NET教程

VB.Net - 正则表达式

正则表达式是可以与输入文本匹配的模式。 .Net框架提供了允许这种匹配的正则表达式引擎。 模式由一个或多个字符文字,运算符或构造组成。

定义正则表达式的构造

有各种类别的字符,运算符和构造,允许您定义正则表达式。 单击以下链接以查找这些结构。

  • 字符转义

  • 字符类

  • 分组构造

  • 量词

  • 反向引用结构

  • 交替结构

  • 替换

  • 杂项结构

正则表达式类

正则表达式类用于表示一个正则表达式。

正则表达式类有以下常用方法:

SN 方法和说明
1

Public Function IsMatch (input As String) As Boolean
公共函数IsMatch(输入作为字符串)作为布尔

表示在正则表达式构造函数中指定的正则表达式是否发现在指定的输入字符串匹配。

2

Public Function IsMatch (input As String, startat As Integer ) As Boolean

公共函数IsMatch(输入作为字符串,startat作为整数)作为布尔

指示在Regex构造函数中指定的正则表达式是否在指定的输入字符串中找到匹配项,从字符串中指定的起始位置开始。

3

Public Shared Function IsMatch (input As String, pattern As String ) As Boolean

公共共享函数IsMatch(输入作为字符串,图案作为字符串)作为布尔

指示指定的正则表达式是否在指定的输入字符串中找到匹配项。

4

Public Function Matches (input As String) As MatchCollection

公共函数匹配(输入作为字符串)作为MatchCollection

搜索指定的输入字符串以查找正则表达式的所有出现。

5

Public Function Replace (input As String, replacement As String) As String

公共函数替换(输入作为字符串,更换作为字符串)作为字符串

在指定的输入字符串中,使用指定的替换字符串替换与正则表达式模式匹配的所有字符串。

6

Public Function Split (input As String) As String()

公共函数(输入作为字符串)作为字符串()

将输入字符串插入到由正则表达式构造函数中指定一个正则表达式模式定义的位置的子字符串数组。

有关方法和属性的完整列表,请参阅Microsoft文档。

示例1

以下示例匹配以“S”开头的单词:

  1. Imports System.Text.Regulars
  2. Module regexProg
  3. Sub showMatch(ByVal text As String, ByVal expr As String)
  4. Console.WriteLine('The : ' + expr)
  5. Dim mc As MatchCollection = Regex.Matches(text, expr)
  6. Dim m As Match
  7. For Each m In mc
  8. Console.WriteLine(m)
  9. Next m
  10. End Sub
  11. Sub Main()
  12. Dim str As String = 'A Thousand Splendid Suns'
  13. Console.WriteLine('Matching words that start with 'S': ')
  14. showMatch(str, 'SS*')
  15. Console.ReadKey()
  16. End Sub
  17. End Module

当上述代码被编译和执行时,它产生了以下结果:

  1. Matching words that start with 'S':
  2. The : SS*
  3. Splendid
  4. Suns

 

例2

以下示例匹配以“m”开头并以“e”结尾的单词:

  1. Imports System.Text.Regulars
  2. Module regexProg
  3. Sub showMatch(ByVal text As String, ByVal expr As String)
  4. Console.WriteLine('The : ' + expr)
  5. Dim mc As MatchCollection = Regex.Matches(text, expr)
  6. Dim m As Match
  7. For Each m In mc
  8. Console.WriteLine(m)
  9. Next m
  10. End Sub
  11. Sub Main()
  12. Dim str As String = 'make a maze and manage to measure it'
  13. Console.WriteLine('Matching words that start with 'm' and ends with 'e': ')
  14. showMatch(str, 'mS*e')
  15. Console.ReadKey()
  16. End Sub
  17. End Module

当上述代码被编译和执行时,它产生了以下结果:

  1. Matching words start with 'm' and ends with 'e':
  2. The : mS*e
  3. make
  4. maze
  5. manage
  6. measure

 

例3

此示例替换了额外的空白空间:

  1. Imports System.Text.Regulars
  2. Module regexProg
  3. Sub Main()
  4. Dim input As String = 'Hello World '
  5. Dim pattern As String = 's+'
  6. Dim replacement As String = ' '
  7. Dim rgx As Regex = New Regex(pattern)
  8. Dim result As String = rgx.Replace(input, replacement)
  9. Console.WriteLine('Original String: {0}', input)
  10. Console.WriteLine('Replacement String: {0}', result)
  11. Console.ReadKey()
  12. End Sub
  13. End Module

当上述代码被编译和执行时,它产生了以下结果:

  1. Original String: Hello World
  2. Replacement String: Hello World

VB.Net - 数据库访问

应用程序与数据库通信,首先,检索存储在那里的数据,并以用户友好的方式呈现它,其次,通过插入,修改和删除数据来更新数据库。

Microsoft ActiveX Data Objects.Net(ADO.Net)是一个模型,.Net框架的一部分,由.Net应用程序用于检索,访问和更新数据。

 

ADO.Net对象模型

ADO.Net对象模型只不过是通过各种组件的结构化流程。 对象模型可以被图形描述为:

通过数据提供者检索驻留在数据存储或数据库中的数据。 数据提供者的各种组件检索应用程序的数据并更新数据。

应用程序通过数据集或数据读取器访问数据。

  • Datasets 数据集:数据集将数据存储在断开连接的缓存中,应用程序从中检索数据。

  • Data readers 数据读取:数据读取器以只读和仅转发模式向应用程序提供数据。

数据提供程序

数据提供程序用于连接到数据库、 执行命令和检索数据,将其存储在一个数据集,阅读检索到的数据和更新数据库。

在 ADO.Net 数据提供程序包括以下四个对象︰

SN 对象和说明
1

Connection

This component is used to set up a connection with a data source.

该组件被用来建立与数据源的连接。

2

Command

A command is a SQL statement or a stored procedure used to retrieve, insert, delete or modify data in a data source.

命令是用于检索,插入,删除或修改数据源中的数据的SQL语句或存储过程。

3

DataReader

Data reader is used to retrieve data from a data source in a read-only and forward-only mode.

数据读取器用于以只读和仅转发模式从数据源检索数据。

4

DataAdapter

This is integral to the working of ADO.Net since data is transferred to and from a database through a data adapter. It retrieves data from a database into a dataset and updates the database. When changes are made to the dataset, the changes in the database are actually done by the data adapter.

这是ADO.Net的工作的组成部分,因为数据通过数据适配器传输到数据库和从数据库传输。 它将数据从数据库检索到数据集并更新数据库。 当对数据集进行更改时,数据库中的更改实际上由数据适配器完成。

ADO.Net中包含以下不同类型的数据提供程序

  • SQL Server的.Net Framework数据提供者 - 提供对Microsoft SQL Server的访问。

  • OLE DB的.Net Framework数据提供者 - 提供对使用OLE DB公开的数据源的访问。

  • ODBC的.Net Framework数据提供程序 - 提供对ODBC公开的数据源的访问。

  • Oracle的.Net Framework数据提供程序 - 提供对Oracle数据源的访问。

  • EntityClient提供程序 - 允许通过实体数据模型(EDM)应用程序访问数据。

 

数据集

DataSet是数据的内存表示。 它是从数据库检索的断开连接的高速缓存的记录集。 当与数据库建立连接时,数据适配器创建数据集并在其中存储数据。 在检索数据并将其存储在数据集中之后,将关闭与数据库的连接。 这被称为“断开连接的架构”。 数据集用作包含表,行和列的虚拟数据库。
 

下图显示了数据集对象模型:

DataSet类存在于System.Data命名空间中。 下表描述了DataSet的所有组件:

SN 组件及说明
1

DataTableCollection

It contains all the tables retrieved from the data source.

它包含了从数据源中检索的所有表。

2

DataRelationCollection

It contains relationships and the links between tables in a data set.

它包含数据集中的表之间的关系和链接。

3

ExtendedProperties

It contains additional information, like the SQL statement for retrieving data, time of retrieval, etc.

它包含的其他信息,例如用于检索数据的SQL语句,检索的时间等

4

DataTable

It represents a table in the DataTableCollection of a dataset. It consists of the DataRow and DataColumn objects. The DataTable objects are case-sensitive.

它表示数据集的DataTableCollection中的表。它由DataRow和DataColumn对象组成。 DataTable对象区分大小写。

5

DataRelation

It represents a relationship in the DataRelationshipCollection of the dataset. It is used to relate two DataTable objects to each other through the DataColumn objects.

它表示数据集的DataRelationshipCollection中的关系。它用于通过DataColumn对象将两个DataTable对象相互关联。

6

DataRowCollection

It contains all the rows in a DataTable.

它包含DataTable中的所有行。

7

DataView

It represents a fixed customized view of a DataTable for sorting, filtering, searching, editing and navigation.

它表示用于排序,过滤,搜索,编辑和导航的DataTable的固定自定义视图。

8

PrimaryKey

It represents the column that uniquely identifies a row in a DataTable.

它表示唯一标识DataTable中某一行的列。

9

DataRow

It represents a row in the DataTable. The DataRow object and its properties and methods are used to retrieve, evaluate, insert, delete, and update values in the DataTable. The NewRow method is used to create a new row and the Add method adds a row to the table.

它表示DataTable中的一行。 DataRow对象及其属性和方法用于检索,评估,插入,删除和更新DataTable中的值。 NewRow方法用于创建一个新行,Add方法向表中添加一行。

10

DataColumnCollection

It represents all the columns in a DataTable.

它表示DataTable中的所有列。

11

DataColumn

It consists of the number of columns that comprise a DataTable.

它由组成DataTable的列数组成。

 

连接到数据库

.Net框架提供两种类型的Connection类:

  • SqlConnection -设计用于连接到Microsoft SQL Server。

  • OleDbConnection -设计用于连接到各种数据库,如Microsoft Access和Oracle。

示例1

我们有一个表存储在名为testDB的数据库中的名为Customers的Microsoft SQL Server中。 有关在SQL Server中创建数据库和数据库表的信息,请参考“SQL Server”教程。
 

让我们连接到此数据库。 执行以下步骤:

  • 选择工具 - >连接到数据库

  • 在“添加连接”对话框中选择服务器名称和数据库名称。

  • 单击测试连接按钮以检查连接是否成功。

  • 在表单上添加一个DataGridView。

  • 单击选择数据源组合框。

  • 单击添加项目数据源链接。

  • 这将打开“数据源配置向导”。

  • 选择“数据库”作为数据源类型

  • 选择的DataSet作为数据库模型。

  • 选择已设置的连接。

  • 保存连接字符串。

  • 在我们的示例中选择数据库对象Customers表,然后单击完成按钮。

  • 选择“预览数据”链接以查看“结果”网格中的数据:

当使用Microsoft Visual Studio工具栏上的“开始”按钮运行应用程序时,将显示以下窗口:

示例2

在这个例子中,让我们使用代码访问DataGridView控件中的数据。 执行以下步骤:

  • 在窗体中添加一个DataGridView控件和一个按钮。

  • 将按钮控件的文本更改为“填充”。

  • 双击按钮控件,为按钮的Click事件添加所需的代码,如下所示:

  1. Imports System.Data.SqlClient
  2. Public Class Form1
  3. Private Sub Form1_Load(sender As Object, e As EventArgs) _
  4. Handles MyBase.Load
  5. 'TODO: This line of code loads data into the 'TestDBDataSet.CUSTOMERS' table. You can move, or remove it, as needed.
  6. Me.CUSTOMERSTableAdapter.Fill(Me.TestDBDataSet.CUSTOMERS)
  7. ' Set the caption bar text of the form.
  8. Me.Text = 'tutorialspoint.com'
  9. End Sub
  10. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  11. Dim connection As SqlConnection = New sqlconnection()
  12. connection.ConnectionString = 'Data Source=KABIR-DESKTOP; _
  13. Initial Catalog=testDB;Integrated Security=True'
  14. connection.Open()
  15. Dim adp As SqlDataAdapter = New SqlDataAdapter _
  16. ('select * from Customers', connection)
  17. Dim ds As DataSet = New DataSet()
  18. adp.Fill(ds)
  19. DataGridView1.DataSource = ds.Tables(0)
  20. End Sub
  21. End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口:

单击“填充”按钮可显示数据网格视图控件上的表:

 

创建表,列和行



我们已经讨论过,像DataTable,DataColumn和DataRow这样的DataSet组件允许我们分别创建表,列和行。

下面的例子演示了这个概念:

 

示例3

到目前为止,我们已经使用我们的计算机中已经存在的表和数据库。 在本示例中,我们将创建一个表,向其中添加列,行和数据,并使用DataGridView对象显示表。

执行以下步骤:

  • 在窗体中添加一个DataGridView控件和一个按钮。

  • 将按钮控件的文本更改为“填充”。

  • 在代码编辑器中添加以下代码。

  1. Public Class Form1
  2. Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
  3. ' Set the caption bar text of the form.
  4. Me.Text = 'tutorialspont.com'
  5. End Sub
  6. Private Function CreateDataSet() As DataSet
  7. 'creating a DataSet object for tables
  8. Dim dataset As DataSet = New DataSet()
  9. ' creating the student table
  10. Dim Students As DataTable = CreateStudentTable()
  11. dataset.Tables.Add(Students)
  12. Return dataset
  13. End Function
  14. Private Function CreateStudentTable() As DataTable
  15. Dim Students As DataTable
  16. Students = New DataTable('Student')
  17. ' adding columns
  18. AddNewColumn(Students, 'System.Int32', 'StudentID')
  19. AddNewColumn(Students, 'System.String', 'StudentName')
  20. AddNewColumn(Students, 'System.String', 'StudentCity')
  21. ' adding rows
  22. AddNewRow(Students, 1, 'Zara Ali', 'Kolkata')
  23. AddNewRow(Students, 2, 'Shreya Sharma', 'Delhi')
  24. AddNewRow(Students, 3, 'Rini Mukherjee', 'Hyderabad')
  25. AddNewRow(Students, 4, 'Sunil Dubey', 'Bikaner')
  26. AddNewRow(Students, 5, 'Rajat Mishra', 'Patna')
  27. Return Students
  28. End Function
  29. Private Sub AddNewColumn(ByRef table As DataTable, _
  30. ByVal columnType As String, ByVal columnName As String)
  31. Dim column As DataColumn = _
  32. table.Columns.Add(columnName, Type.GetType(columnType))
  33. End Sub
  34. 'adding data into the table
  35. Private Sub AddNewRow(ByRef table As DataTable, ByRef id As Integer,_
  36. ByRef name As String, ByRef city As String)
  37. Dim newrow As DataRow = table.NewRow()
  38. newrow('StudentID') = id
  39. newrow('StudentName') = name
  40. newrow('StudentCity') = city
  41. table.Rows.Add(newrow)
  42. End Sub
  43. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  44. Dim ds As New DataSet
  45. ds = CreateDataSet()
  46. DataGridView1.DataSource = ds.Tables('Student')
  47. End Sub
  48. End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口:

单击“填充”按钮可显示数据网格视图控件上的表:


VB.Net - Excel工作表

VB.Net提供对Microsoft Excel 2010的COM对象模型和应用程序之间的互操作性的支持。

要在应用程序中使用此互操作性,您需要在Windows窗体应用程序中导入命名空间Microsoft.Office.Interop.Excel。

 

从VB.Net创建一个Excel应用程序

让我们从Microsoft Visual Studio中的以下步骤开始创建窗体表单应用程序:文件 - >新建项目 - > Windows窗体应用程序

最后,选择确定,Microsoft Visual Studio创建您的项目并显示以下Form1。

在窗体中插入Button控件Button1。

向项目中添加对Microsoft Excel对象库的引用。 进行以下操作:

  • 从项目菜单中选择添加引用。

  • 在COM选项卡上,找到Microsoft Excel对象库,然后单击选择。

  • 点击OK。

双击代码窗口并填充Button1的Click事件,如下所示。

  1. ' Add the following code snippet on top of Form1.vb
  2. Imports Excel = Microsoft.Office.Interop.Excel
  3. Public Class Form1
  4. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  5. Dim appXL As Excel.Application
  6. Dim wbXl As Excel.Workbook
  7. Dim shXL As Excel.Worksheet
  8. Dim raXL As Excel.Range
  9. ' Start Excel and get Application object.
  10. appXL = CreateObject('Excel.Application')
  11. appXL.Visible = True
  12. ' Add a new workbook.
  13. wbXl = appXL.Workbooks.Add
  14. shXL = wbXl.ActiveSheet
  15. ' Add table headers going cell by cell.
  16. shXL.Cells(1, 1).Value = 'First Name'
  17. shXL.Cells(1, 2).Value = 'Last Name'
  18. shXL.Cells(1, 3).Value = 'Full Name'
  19. shXL.Cells(1, 4).Value = 'Specialization'
  20. ' Format A1:D1 as bold, vertical alignment = center.
  21. With shXL.Range('A1', 'D1')
  22. .Font.Bold = True
  23. .VerticalAlignment = Excel.XlVAlign.xlVAlignCenter
  24. End With
  25. ' Create an array to set multiple values at once.
  26. Dim students(5, 2) As String
  27. students(0, 0) = 'Zara'
  28. students(0, 1) = 'Ali'
  29. students(1, 0) = 'Nuha'
  30. students(1, 1) = 'Ali'
  31. students(2, 0) = 'Arilia'
  32. students(2, 1) = 'RamKumar'
  33. students(3, 0) = 'Rita'
  34. students(3, 1) = 'Jones'
  35. students(4, 0) = 'Umme'
  36. students(4, 1) = 'Ayman'
  37. ' Fill A2:B6 with an array of values (First and Last Names).
  38. shXL.Range('A2', 'B6').Value = students
  39. ' Fill C2:C6 with a relative formula (=A2 & ' ' & B2).
  40. raXL = shXL.Range('C2', 'C6')
  41. raXL.Formula = '=A2 & '' '' & B2'
  42. ' Fill D2:D6 values.
  43. With shXL
  44. .Cells(2, 4).Value = 'Biology'
  45. .Cells(3, 4).Value = 'Mathmematics'
  46. .Cells(4, 4).Value = 'Physics'
  47. .Cells(5, 4).Value = 'Mathmematics'
  48. .Cells(6, 4).Value = 'Arabic'
  49. End With
  50. ' AutoFit columns A:D.
  51. raXL = shXL.Range('A1', 'D1')
  52. raXL.EntireColumn.AutoFit()
  53. ' Make sure Excel is visible and give the user control
  54. ' of Excel's lifetime.
  55. appXL.Visible = True
  56. appXL.UserControl = True
  57. ' Release object references.
  58. raXL = Nothing
  59. shXL = Nothing
  60. wbXl = Nothing
  61. appXL.Quit()
  62. appXL = Nothing
  63. Exit Sub
  64. Err_Handler:
  65. MsgBox(Err.Description, vbCritical, 'Error: ' & Err.Number)
  66. End Sub
  67. End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口:

单击按钮将显示以下excel表。 将要求您保存工作簿。


VB.Net - 发送邮件

VB.Net允许从您的应用程序发送电子邮件。 System.Net.Mail命名空间包含用于向简单邮件传输协议(SMTP)服务器发送电子邮件以进行传递的类。

下表列出了一些常用的类:

SN 描述
1 Attachment 表示对电子邮件的附件。
2 AttachmentCollection 存储要作为电子邮件的一部分发送的附件。
3 MailAddress 表示电子邮件发件人或收件人的地址。
4 MailAddressCollection 存储与电子邮件相关联的电子邮件地址。
5 MailMessage 表示可以使用SmtpClient类发送的电子邮件。
6 SmtpClient 允许应用程序使用简单邮件传输协议(SMTP)发送电子邮件。
7 SmtpException 表示当SmtpClient无法完成发送或SendAsync操作时抛出的异常。

 

SmtpClient类

SmtpClient类允许应用程序使用简单邮件传输协议(SMTP)发送电子邮件。
 

以下是SmtpClient类的一些常用属性:

SN 属性 描述
1 ClientCertificates 指定应使用哪些证书建立安全套接字层(SSL)连接。
2 Credentials 获取或设置用于验证发件人的凭据。
3 EnableSsl 指定SmtpClient是否使用安全套接字层(SSL)加密连接。
4 Host 获取或设置用于SMTP事务的主机的名称或IP地址。
5 Port 获取或设置用于SMTP事务的端口。
6 Timeout 获取或设置一个值,该值指定同步发送调用超时的时间量。
7 UseDefaultCredentials 获取或设置一个布尔值,该值控制是否随请求一起发送DefaultCredentials。

以下是SmtpClient类的一些常用方法:

SN 方法和说明
1

Dispose

向SMTP服务器发送QUIT消息,正常结束TCP连接,并释放SmtpClient类的当前实例使用的所有资源。

2

Dispose(Boolean)

向SMTP服务器发送QUIT消息,正常结束TCP连接,释放由SmtpClient类的当前实例使用的所有资源,并且可选地处置托管资源。

3

OnSendCompleted

引发SendCompleted事件。

4

Send(MailMessage)

将指定的消息发送到SMTP服务器进行传递。

5

Send(String,String,String,String)

将指定的电子邮件发送到SMTP服务器进行传送。消息发件人,收件人,主题和邮件正文使用String对象指定。

6

SendAsync(MailMessage,Object)

将指定的电子邮件发送到SMTP服务器进行传送。此方法不会阻止调用线程,并允许调用者将一个对象传递给操作完成时调用的方法。

7 SendAsync(String,String,String,String,Object)
将电子邮件发送到SMTP服务器进行传送。消息发件人,收件人,主题和邮件正文使用String对象指定。此方法不会阻止调用线程,并允许调用者将一个对象传递给操作完成时调用的方法。
8

SendAsyncCancel

取消异步操作以发送电子邮件。

9

SendMailAsync(MAILMESSAGE)

发送指定消息,以交付作为异步操作的SMTP服务器。

10 SendMailAsync(MailMessage)
将指定的消息发送到SMTP服务器以作为异步操作进行传递。
11 ToString
返回表示当前对象的字符串。

以下示例演示如何使用SmtpClient类发送邮件。 在这方面应注意以下几点:

  • 您必须指定用于发送电子邮件的SMTP主机服务器。 不同主机服务器的主机和端口属性将不同。 我们将使用gmail服务器。

  • 如果SMTP服务器需要,您需要授予认证凭据。

  • 您还应该分别使用MailMessage.From和MailMessage.To属性提供发件人的电子邮件地址和收件人的电子邮件地址。

  • 您还应该使用MailMessage.Body属性指定消息内容。

 

示例

在这个例子中,让我们创建一个发送电子邮件的简单应用程序。 执行以下步骤:

  • 在表单中添加三个标签,三个文本框和一个按钮控件。

  • 将标签的文本属性分别更改为 - “From”,“To:”和“Message:”。

  • 将文本的名称属性分别更改为txtFrom,txtTo和txtMessage。

  • 将按钮控件的文本属性更改为“发送”

  • 在代码编辑器中添加以下代码。

  1. Imports System.Net.Mail
  2. Public Class Form1
  3. Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
  4. ' Set the caption bar text of the form.
  5. Me.Text = 'tutorialspoint.com'
  6. End Sub
  7. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  8. Try
  9. Dim Smtp_Server As New SmtpClient
  10. Dim e_mail As New MailMessage()
  11. Smtp_Server.UseDefaultCredentials = False
  12. Smtp_Server.Credentials = New Net.NetworkCredential('username@gmail.com', 'password')
  13. Smtp_Server.Port = 587
  14. Smtp_Server.EnableSsl = True
  15. Smtp_Server.Host = 'smtp.gmail.com'
  16. e_mail = New MailMessage()
  17. e_mail.From = New MailAddress(txtFrom.Text)
  18. e_mail.To.Add(txtTo.Text)
  19. e_mail.Subject = 'Email Sending'
  20. e_mail.IsBodyHtml = False
  21. e_mail.Body = txtMessage.Text
  22. Smtp_Server.Send(e_mail)
  23. MsgBox('Mail Sent')
  24. Catch error_t As Exception
  25. MsgBox(error_t.ToString)
  26. End Try
  27. End Sub

您必须提供您的gmail地址和真实密码以获取凭据。
 

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口,您将使用该窗口发送电子邮件,自行尝试。


VB.Net - XML处理

可扩展标记语言(XML)是一种非常类似于HTML或SGML的标记语言。 这是万维网联盟推荐的,可作为开放标准。

.Net框架中的System.Xml命名空间包含用于处理XML文档的类。 以下是System.Xml命名空间中常用的一些类。

SN 描述
1 XmlAttribute 表示属性。属性的有效值和默认值在文档类型定义(DTD)或模式中定义。
2 XmlCDataSection 表示一个CDATA部分。
3 XmlCharacterData 提供由几个类使用的文本处理方法。
4 XMLCOMMENT 表示一个XML注释的内容。
5 XmlConvert 对XML名称进行编码和解码,并提供在公共语言运行时类型和XML模式定义语言(XSD)类型之间进行转换的方法。转换数据类型时,返回的值与语言环境无关。
6 XmlDeclaration 表示XML声明节点<?xml version ='1.0'...?>。
7 XmlDictionary 实现一本字典用来优化 Windows 通信基础(WCF) 的 XML 读取器/编写器实现。
8 XmlDictionaryReader Windows Communication Foundation(WCF)从XmlReader派生来进行序列化和反序列化的抽象类。
9 XmlDictionaryWriter 表示Windows Communication Foundation(WCF)从XmlWriter派生来进行序列化和反序列化的抽象类。
10 XmlDocument 表示XML文档。
11 XmlDocumentFragment 表示对树插入操作有用的轻量级对象。
12 XmlDocumentType 表示文档类型声明。
13 XmlElement 表示一个元素。
14 XmlEntity 表示一个实体声明,如<!ENTITY ...>。
15 XmlEntityReference 表示一个实体引用节点。
16 XmlException 返回有关最后一个异常的详细信息。
17 XmlImplementation 定义一组XmlDocument对象的上下文。
18 XmlLinkedNode 获取此节点之前或之后的节点。
19 XmlNode 表示XML文档中的单个节点。
20 XmlNodeList 表示节点的有序集合。
21 XmlNodeReader 表示提供对XmlNode中的XML数据的快速,非缓存转发访问的阅读器。
22 XmlNotation 表示一个注释声明,如<!NOTATION ...>。
23 XmlParserContext 提供XmlReader解析XML片段所需的所有上下文信息。
24 XmlProcessingInstruction 表示处理指令,XML定义为在文档的文本中保留处理器特定的信息。
25 XmlQualifiedName 表示一个XML限定名称。
26 XmlReader 表示一个阅读器,提供了快速,非缓存,只进到XML数据访问。
27 XmlReaderSettings 指定一组要在Create方法创建的XmlReader对象上支持的要素。
28 XmlResolver 解析由统一资源标识符(URI)命名的外部XML资源。
29 XmlSecureResolver 有助于通过封装XmlResolver对象并限制底层XmlResolver有权访问的资源来保护XmlResolver的另一个实现。
30 XmlSignificantWhitespace 表示混合内容节点中的标记之间或xml:space ='preserve'范围内的空白空间中的空格。这也称为有效的空白空间。
31 XmlText 表示元素或属性的文本内容。
32 XmlTextReader 表示提供对XML数据的快速,非缓存,仅转发访问的阅读器。
33 XmlTextWriter 代表作家提供了一个快速,非缓存,只进生成包含符合W3C可扩展标记语言(XML)1.0和XML中建议的命名空间XML数据流或文件的方式。
34 XmlUrlResolver 解析由统一资源标识符(URI)命名的外部XML资源。
35 XmlWhitespace 代表元素内容中的空白。
36 XmlWriter 表示提供快速,非缓存,仅转发方式生成包含XML数据的流或文件的写入程序。
37 XmlWriterSettings 指定一组要在XmlWriter.Create方法创建的XmlWriter对象上支持的要素。

 

XML解析器的API

XML数据的两个最基本和广泛使用的API是SAX和DOM接口。

XML的简单API(SAX):在这里,您注册感兴趣的事件的回调,然后让解析器继续处理文档。这在文档很大或者有内存限制时很有用,它在从磁盘读取文件时解析文件,整个文件从不存储在内存中。

文档对象模型(DOM)API:这是万维网联盟推荐,其中整个文件被读入存储器并以分层(基于树)的形式存储以表示XML文档的所有特征。

SAX显然不能像使用大文件时DOM那样快速地处理信息。另一方面,使用DOM可以真正地杀死你的资源,特别是如果用于很多小文件。

SAX是只读的,而DOM允许更改XML文件。由于这两个不同的API字面上互补,没有理由你不能使用它们两个大项目。

对于所有的XML代码示例,让我们使用一个简单的XML文件movies.xml作为输入:

  1. <?xml version='1.0'?>
  2. <collection shelf='New Arrivals'>
  3. <movie title='Enemy Behind'>
  4. <type>War, Thriller</type>
  5. <format>DVD</format>
  6. <year>2003</year>
  7. <rating>PG</rating>
  8. <stars>10</stars>
  9. <description>Talk about a US-Japan war</description>
  10. </movie>
  11. <movie title='Transformers'>
  12. <type>Anime, Science Fiction</type>
  13. <format>DVD</format>
  14. <year>1989</year>
  15. <rating>R</rating>
  16. <stars>8</stars>
  17. <description>A schientific fiction</description>
  18. </movie>
  19. <movie title='Trigun'>
  20. <type>Anime, Action</type>
  21. <format>DVD</format>
  22. <episodes>4</episodes>
  23. <rating>PG</rating>
  24. <stars>10</stars>
  25. <description>Vash the Stampede!</description>
  26. </movie>
  27. <movie title='Ishtar'>
  28. <type>Comedy</type>
  29. <format>VHS</format>
  30. <rating>PG</rating>
  31. <stars>2</stars>
  32. <description>Viewable boredom</description>
  33. </movie>
  34. </collection>

 

解析XML使用SAX API

在SAX模型中,使用XmlReader和XmlWriter类来处理XML数据。

XmlReader类用于以快速,仅向前和非缓存方式读取XML数据。 它读取XML文档或流。

 

示例1

此示例演示从文件movies.xml中读取XML数据。

执行以下步骤:

  • 将movies.xml文件添加到应用程序的bin \ Debug文件夹中。

  • 在Form1.vb文件中导入System.Xml命名空间。

  • 在表单中添加标签,并将其文字更改为“Movies Galore”。

  • 添加三个列表框和三个按钮,以显示来自xml文件的电影的标题,类型和描述。

  • 使用代码编辑器窗口添加以下代码。

  1. Imports System.Xml
  2. Public Class Form1
  3. Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
  4. ' Set the caption bar text of the form.
  5. Me.Text = 'tutorialspoint.com'
  6. End Sub
  7. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  8. ListBox1().Items.Clear()
  9. Dim xr As XmlReader = XmlReader.Create('movies.xml')
  10. Do While xr.Read()
  11. If xr.NodeType = XmlNodeType.Element AndAlso xr.Name = 'movie' Then
  12. ListBox1.Items.Add(xr.GetAttribute(0))
  13. End If
  14. Loop
  15. End Sub
  16. Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click
  17. ListBox2().Items.Clear()
  18. Dim xr As XmlReader = XmlReader.Create('movies.xml')
  19. Do While xr.Read()
  20. If xr.NodeType = XmlNodeType.Element AndAlso xr.Name = 'type' Then
  21. ListBox2.Items.Add(xr.ReadElementString)
  22. Else
  23. xr.Read()
  24. End If
  25. Loop
  26. End Sub
  27. Private Sub Button3_Click(sender As Object, e As EventArgs) Handles Button3.Click
  28. ListBox3().Items.Clear()
  29. Dim xr As XmlReader = XmlReader.Create('movies.xml')
  30. Do While xr.Read()
  31. If xr.NodeType = XmlNodeType.Element AndAlso xr.Name = 'description' Then
  32. ListBox3.Items.Add(xr.ReadElementString)
  33. Else
  34. xr.Read()
  35. End If
  36. Loop
  37. End Sub
  38. End Class

使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码。 单击按钮将显示文件中电影的标题,类型和描述。

XmlWriter类用于将XML数据写入流,文件或TextWriter对象。 它也以只向前,非缓存的方式工作。

示例2

让我们通过在运行时添加一些数据来创建一个XML文件。 执行以下步骤:

  • 在窗体中添加WebBrowser控件和按钮控件。

  • 将按钮的Text属性更改为显示作者文件。

  • 在代码编辑器中添加以下代码。

  1. Imports System.Xml
  2. Public Class Form1
  3. Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
  4. ' Set the caption bar text of the form.
  5. Me.Text = 'tutorialspoint.com'
  6. End Sub
  7. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  8. Dim xws As XmlWriterSettings = New XmlWriterSettings()
  9. xws.Indent = True
  10. xws.NewLineOnAttributes = True
  11. Dim xw As XmlWriter = XmlWriter.Create('authors.xml', xws)
  12. xw.WriteStartDocument()
  13. xw.WriteStartElement('Authors')
  14. xw.WriteStartElement('author')
  15. xw.WriteAttributeString('code', '1')
  16. xw.WriteElementString('fname', 'Zara')
  17. xw.WriteElementString('lname', 'Ali')
  18. xw.WriteEndElement()
  19. xw.WriteStartElement('author')
  20. xw.WriteAttributeString('code', '2')
  21. xw.WriteElementString('fname', 'Priya')
  22. xw.WriteElementString('lname', 'Sharma')
  23. xw.WriteEndElement()
  24. xw.WriteStartElement('author')
  25. xw.WriteAttributeString('code', '3')
  26. xw.WriteElementString('fname', 'Anshuman')
  27. xw.WriteElementString('lname', 'Mohan')
  28. xw.WriteEndElement()
  29. xw.WriteStartElement('author')
  30. xw.WriteAttributeString('code', '4')
  31. xw.WriteElementString('fname', 'Bibhuti')
  32. xw.WriteElementString('lname', 'Banerjee')
  33. xw.WriteEndElement()
  34. xw.WriteStartElement('author')
  35. xw.WriteAttributeString('code', '5')
  36. xw.WriteElementString('fname', 'Riyan')
  37. xw.WriteElementString('lname', 'Sengupta')
  38. xw.WriteEndElement()
  39. xw.WriteEndElement()
  40. xw.WriteEndDocument()
  41. xw.Flush()
  42. xw.Close()
  43. WebBrowser1.Url = New Uri(AppDomain.CurrentDomain.BaseDirectory + 'authors.xml')
  44. End Sub
  45. End Class

使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码。 单击显示作者文件将在Web浏览器上显示新创建的authors.xml文件。

 

使用DOM API解析XML

根据文档对象模型(DOM),XML文档由节点和节点的属性组成。 XmlDocument类用于实现.Net框架的XML DOM解析器。 它还允许您通过插入,删除或更新文档中的数据来修改现有的XML文档。

以下是XmlDocument类的一些常用方法:

SN 方法名称和说明
1

AppendChild

将指定的节点添加到此节点的子节点列表的末尾。

2

CreateAttribute(String)

使用指定的名称创建XmlAttribute。

3

CreateComment

创建包含指定数据的XmlComment。

4

CreateDefaultAttribute

创建具有指定前缀,本地名称和命名空间URI的默认属性。

5

CreateElement(String)

创建具有指定名称的元素。

6

CreateNode(String, String, String)

创建具有指定节点类型,Name和NamespaceURI的XmlNode。

7

CreateNode(XmlNodeType, String, String)

创建具有指定的XmlNodeType,Name和NamespaceURI的XmlNode。

8

CreateNode(XmlNodeType, String, String, String)

创建具有指定的XmlNodeType,Prefix,Name和NamespaceURI的XmlNode。

9

CreateProcessingInstruction

创建具有指定名称和数据的XmlProcessingInstruction。

10

CreateSignificantWhitespace

创建一个XmlSignificantWhitespace节点。

11

createTextNode

创建具有指定文本的XMLTEXT。

12

CreateWhitespace

创建一个XmlWhitespace节点。

13

CreateXmlDeclaration

创建一个具有指定值的XmlDeclaration节点。

14

GetElementById

获取具有指定ID的XmlElement。

15

GetElementsByTagName(String)

返回一个包含与指定名称匹配的所有后代元素的列表的XmlNodeList。

16

GetElementsByTagName(String, String)

返回一个包含与指定名称匹配的所有后代元素的列表的XmlNodeList。

17

InsertAfter

在指定的引用节点之后立即插入指定的节点。

18

InsertBefore

在指定的引用节点之前插入指定的节点。

19

Load(Stream)

从指定的流装载XML文档。

20

Load(String)

从指定的TextReader加载XML文档。

21

Load(TextReader)

从指定的TextReader加载XML文档。

22

Load(XmlReader)

从指定的XmlReader加载XML文档。

23

LoadXml

从指定的字符串加载XML文档。

24

PrependChild

将指定的节点添加到此节点的子节点列表的开头。

25

ReadNode

基于XmlReader中的信息创建XmlNode对象。读取器必须位于节点或属性上。

26

RemoveAll

删除当前节点的所有子节点和/或属性。

27

RemoveChild

删除指定的子节点。

28

ReplaceChild

将子节点oldChild替换为newChild节点。

29

Save(Stream)

保存XML文档到指定的流。

30

Save(String)

将XML文档保存到指定的文件。

31

Save(TextWriter)

将XML文档保存到指定的TextWriter。

32

Save(XmlWriter)

将XML文档保存到指定的XmlWriter。

 

示例3

在本示例中,让我们在xml文档authors.xml中插入一些新节点,然后在列表框中显示所有作者的名字。

执行以下步骤:

  • 将authors.xml文件添加到应用程序的bin / Debug文件夹中(如果您已经尝试了最后一个示例,应该在那里)

  • 导入System.Xml命名空间

  • 在表单中添加列表框和按钮控件,并将按钮控件的text属性设置为“显示作者”。

  • 使用代码编辑器添加以下代码。

  1. Imports System.Xml
  2. Public Class Form1
  3. Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
  4. ' Set the caption bar text of the form.
  5. Me.Text = 'tutorialspoint.com'
  6. End Sub
  7. Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
  8. ListBox1.Items.Clear()
  9. Dim xd As XmlDocument = New XmlDocument()
  10. xd.Load('authors.xml')
  11. Dim newAuthor As XmlElement = xd.CreateElement('author')
  12. newAuthor.SetAttribute('code', '6')
  13. Dim fn As XmlElement = xd.CreateElement('fname')
  14. fn.InnerText = 'Bikram'
  15. newAuthor.AppendChild(fn)
  16. Dim ln As XmlElement = xd.CreateElement('lname')
  17. ln.InnerText = 'Seth'
  18. newAuthor.AppendChild(ln)
  19. xd.DocumentElement.AppendChild(newAuthor)
  20. Dim tr As XmlTextWriter = New XmlTextWriter('movies.xml', Nothing)
  21. tr.Formatting = Formatting.Indented
  22. xd.WriteContentTo(tr)
  23. tr.Close()
  24. Dim nl As XmlNodeList = xd.GetElementsByTagName('fname')
  25. For Each node As XmlNode In nl
  26. ListBox1.Items.Add(node.InnerText)
  27. Next node
  28. End Sub
  29. End Class

使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码。 单击“显示作者”按钮将显示所有作者的名字,包括我们在运行时添加的作者。


VB.Net - Web编程

动态Web应用程序包括以下两种类型的程序之一或两者:

  • 服务器端脚本 -这些是在Web服务器上执行的程序,使用服务器端脚本语言(如ASP(Active Server Pages)或JSP(Java Server Pages))编写。

  • 客户端脚本 -这些是在浏览器上执行的程序,使用脚本语言(如JavaScript,VBScript等)编写。

ASP.Net是由Microsoft引入的ASP的.Net版本,用于通过使用服务器端脚本创建动态网页。 ASP.Net应用程序是使用.Net框架中存在的可扩展和可重用组件或对象编写的编译代码。这些代码可以使用.Net框架中的类的整个层次结构。

ASP.Net应用程序代码可以用以下任何一种语言编写:

  • Visual Basic .NET

  • C#

  • Jscript脚本

  • J#

在本章中,我们将简要介绍使用VB.Net编写ASP.Net应用程序。有关详细讨论,请参阅ASP.Net教程。

 

ASP.Net内置对象

ASP.Net有一些在Web服务器上运行的内置对象。 这些对象具有在应用程序开发中使用的方法,属性和集合。

下表列出了具有简要说明的ASP.Net内置对象:

目的 描述

Application 

应用

描述存储与整个Web应用程序相关的信息的对象的方法,属性和集合,包括应用程序生命周期中存在的变量和对象。
您使用此对象来存储和检索要在应用程序的所有用户之间共享的信息。例如,您可以使用Application对象来创建电子商务页面。

Request

请求

描述存储与HTTP请求相关的信息的对象的方法,属性和集合。这包括表单,Cookie,服务器变量和证书数据。
您使用此对象来访问在从浏览器到服务器的请求中发送的信息。例如,您可以使用Request对象来访问用户在HTML表单中输入的信息。
Response
响应
描述存储与服务器响应相关的信息的对象的方法,属性和集合。这包括显示内容,操作标头,设置区域设置和重定向请求。
您使用此对象向浏览器发送信息。例如,您使用Response对象将输出从脚本发送到浏览器。
Server
服务器
描述提供各种服务器任务的方法的对象的方法和属性。使用这些方法,您可以执行代码,获取错误条件,编码文本字符串,创建对象供网页使用,并映射物理路径。
您使用此对象访问服务器上的各种实用程序功能。例如,您可以使用Server对象为脚本设置超时。
Session
会话
描述存储与用户会话相关的信息的对象的方法,属性和集合,包括会话生存期内存在的变量和对象。
您使用此对象来存储和检索有关特定用户会话的信息。例如,您可以使用Session对象来保存有关用户及其首选项的信息,并跟踪待处理操作。

 

ASP.Net编程模型

ASP.Net提供两种类型的编程模型:

  • Web Forms-这使您能够创建将应用于用户界面的各种组件的用户界面和应用程序逻辑。

  • WCF Services-这使您可以远程访问一些服务器端功能。

对于本章,您需要使用免费的Visual Studio Web Developer。 IDE与您已经用于创建Windows应用程序的IDE几乎相同。

 

Web表单

Web表单包括:

  • 用户界面

  • 应用程序逻辑

用户界面包括静态HTML或XML元素和ASP.Net服务器控件。 创建Web应用程序时,HTML或XML元素和服务器控件存储在具有.aspx扩展名的文件中。 此文件也称为页面文件。

应用程序逻辑包括应用于页面中用户界面元素的代码。 你可以用任何.Net语言,如VB.Net或C#编写代码。
 

下图显示了“设计”视图中的Web窗体:

 

示例

让我们创建一个带有Web表单的新网站,该表单将显示用户点击按钮时的当前日期和时间。 执行以下步骤:

  • 选择文件 - >新建 - > Web站点。将出现“新建网站”对话框。

  • 选择ASP.Net空网站模板。 键入网站的名称,然后选择保存文件的位置。

  • 您需要向站点添加默认页面。 右键单击解决方案资源管理器中的网站名称,然后从上下文菜单中选择添加新项目选项。 将显示“添加新项”对话框:

  • 选择Web窗体选项并提供默认页面的名称。 我们把它保存为Default.aspx。 单击添加按钮。

  • 默认页面显示在源视图中

  • 通过向“值”添加值来设置“默认”网页的标题

  • 要在网页上添加控件,请转到设计视图。 在表单上添加三个标签,一个文本框和一个按钮。

  • 双击该按钮,并将以下代码添加到该按钮的Click事件:

  1. Protected Sub Button1_Click(sender As Object, e As EventArgs) _
  2. Handles Button1.Click
  3. Label2.Visible = True
  4. Label2.Text = 'Welcome to Tutorials Point: ' + TextBox1.Text
  5. Label3.Text = 'You visited us at: ' + DateTime.Now.ToString()
  6. End Sub

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,浏览器中将打开以下页面:

输入您的姓名,然后点击提交按钮:

网页服务

Web服务是一个Web应用程序,基本上是一个由其他应用程序可以使用的方法组成的类。它也遵循代码隐藏架构,如ASP.Net网页,虽然它没有用户界面。
 

.Net Framework的早期版本使用了ASP.Net Web Service的这个概念,它具有.asmx文件扩展名。然而,从.Net Framework 4.0开始,Windows通信基础(WCF)技术已经发展成为Web Services,.Net Remoting和一些其他相关技术的新继任者。它把所有这些技术结合在一起。在下一节中,我们将简要介绍Windows Communication Foundation(WCF)。

如果您使用先前版本的.Net Framework,您仍然可以创建传统的Web服务。有关详细说明,请参阅ASP.Net - Web服务详细说明。

 

Windows通信基础

Windows Communication Foundation或WCF提供了一个用于创建分布式面向服务的应用程序的API,称为WCF服务。

像Web服务一样,WCF服务也支持应用程序之间的通信。但是,与Web服务不同,此处的通信不仅限于HTTP。 WCF可以配置为通过HTTP,TCP,IPC和消息队列使用。支持WCF的另一个强点是,它提供对双工通信的支持,而对于Web服务,我们只能实现单工通信。

从初学者的角度来看,编写WCF服务与编写Web服务并不完全不同。为了保持简单,我们将看到如何:

  • 创建一个WCF服务

  • 创建一个服务合同并定义操作

  • 执行合同

  • 测试服务

  • 使用该服务

 

示例

要理解这个概念,让我们创建一个简单的服务,提供股价信息。客户可以根据股票代号查询股票的名称和价格。为了保持这个例子简单,这些值被硬编码在二维数组中。此服务将有两种方法:

  • GetPrice方法 - 它将返回股票的价格,基于提供的符号。

  • GetName方法 - 它将返回股票的名称,基于提供的符号。

创建WCF服务

执行以下步骤:

  • 打开VS Express for Web 2012

  • 选择新的网站,打开新建网站对话框。

  • 选择模板列表中的WCF服务模板:

  • 从Web位置下拉列表中选择文件系统。

  • 提供WCF服务的名称和位置,然后单击“确定”。

创建一个新的WCF服务。

创建服务合同并定义操作

服务契约定义服务执行的操作。 在WCF服务应用程序中,您会发现在解决方案资源管理器中的App_Code文件夹中自动创建两个文件

  • IService.vb - 这将有服务合同; 在简单的话,它将有服务的接口,与服务将提供的方法的定义,您将在您的服务中实现。

  • Service.vb - 这将实现服务合同。

用给定的代码替换IService.vb文件的代码:

  1. Public Interface IService
  2. <OperationContract()>
  3. Function GetPrice(ByVal symbol As String) As Double
  4. <OperationContract()>
  5. Function GetName(ByVal symbol As String) As String
  6. End Interface

实施合同

在Service.vb文件中,您将找到一个名为Service的类,它将实现在IService接口中定义的服务契约。

使用以下代码替换IService.vb的代码:

  1. ' NOTE: You can use the 'Rename' command on the context menu to change the class name 'Service' in code, svc and config file together.
  2. Public Class Service
  3. Implements IService
  4. Public Sub New()
  5. End Sub
  6. Dim stocks As String(,) =
  7. {
  8. {'RELIND', 'Reliance Industries', '1060.15'},
  9. {'ICICI', 'ICICI Bank', '911.55'},
  10. {'JSW', 'JSW Steel', '1201.25'},
  11. {'WIPRO', 'Wipro Limited', '1194.65'},
  12. {'SATYAM', 'Satyam Computers', '91.10'}
  13. }
  14. Public Function GetPrice(ByVal symbol As String) As Double _
  15. Implements IService.GetPrice
  16. Dim i As Integer
  17. 'it takes the symbol as parameter and returns price
  18. For i = 0 To i = stocks.GetLength(0) - 1
  19. If (String.Compare(symbol, stocks(i, 0)) = 0) Then
  20. Return Convert.ToDouble(stocks(i, 2))
  21. End If
  22. Next i
  23. Return 0
  24. End Function
  25. Public Function GetName(ByVal symbol As String) As String _
  26. Implements IService.GetName
  27. ' It takes the symbol as parameter and
  28. ' returns name of the stock
  29. Dim i As Integer
  30. For i = 0 To i = stocks.GetLength(0) - 1
  31. If (String.Compare(symbol, stocks(i, 0)) = 0) Then
  32. Return stocks(i, 1)
  33. End If
  34. Next i
  35. Return 'Stock Not Found'
  36. End Function
  37. End Class

测试服务

要运行如此创建的WCF服务,请从菜单栏中选择Debug-> Start Debugging选项。 输出将是:

要测试服务操作,请从左窗格的树中双击操作的名称。 新的选项卡将显示在右窗格中。

在右窗格的“请求”区域中输入参数值,然后单击“调用”按钮。
 

下图显示了测试GetPrice操作的结果:

下图显示了测试GetName操作的结果:

使用服务

让我们在同一个解决方案中添加一个默认页面,一个ASP.NET Web窗体,我们将使用我们刚刚创建的WCF服务。

执行以下步骤:

  • 右键单击解决方案资源管理器中的解决方案名称,并向解决方案添加新的Web表单。 它将被命名为Default.aspx。

  • 在表单上添加两个标签,一个文本框和一个按钮。

  • 我们需要添加一个服务引用到我们刚刚创建的WCF服务。 右键单击解决方案资源管理器中的网站,然后选择添加服务引用选项。 这将打开“添加服务引用”对话框。

  • 在地址文本框中输入服务的URL(位置),然后单击执行按钮。 它使用默认名称ServiceReference1创建服务引用。 单击确定按钮。

    添加引用为您的项目做了两个作业:

    • 在web.config文件中为服务创建地址和绑定。

    • 创建代理类以访问服务。

双击表单中的“获取价格”按钮,在其Click事件上输入以下代码段:

  1. Partial Class _Default
  2. Inherits System.Web.UI.Page
  3. Protected Sub Button1_Click(sender As Object, e As EventArgs) _
  4. Handles Button1.Click
  5. Dim ser As ServiceReference1.ServiceClient = _
  6. New ServiceReference1.ServiceClient
  7. Label2.Text = ser.GetPrice(TextBox1.Text).ToString()
  8. End Sub
  9. End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,浏览器中将打开以下页面:

输入符号并单击获取价格按钮以获得硬编码的价格:


未完待续,下一章节,つづく

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
vb6如何把特定的字符替换成其他的字符
VB.NET字节数组用法
vb RegExp的Test方法
如何用VB6的COM 外接程序对word2007功能区进行定制(4.24日更新代码)
VB和VB.NET中的XML操作 (3)
请教如何使用VB导出XML文件
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服