html5中文学习网

您的位置: 首页 > 网络编程 > ASP.NET » 正文

ASP.NET学习篇(3)――几个简单的ASP.ENT的例子_.NET教程_编程技术

[ ] 已经帮助:人解决问题

一个WEBFORM——这里将介绍ASP.NET WEBFORM的基本概念,以及其中表单项的变化。 UXJHTML5中文学习网 - HTML5先行者学习网

*一个数据库的应用——如何利用CONFIG.WEB中设置的DNS连接数据库,数据库操作对象的一些基本用法。 UXJHTML5中文学习网 - HTML5先行者学习网

*EMAIL发送——在 引入一个系统类库后(用IMPORT 标识符 ),利用msgMail对象,可以很方便的操作邮件发送过程。 UXJHTML5中文学习网 - HTML5先行者学习网

*上传——<INPUT TYPE=FILE …… 这样一个INPUT 项在ASP.NET中有POSTEDFILE属性,结合SAVEAS 事件,就可以实现上传了。 UXJHTML5中文学习网 - HTML5先行者学习网

一、 WEBFORM的使用 UXJHTML5中文学习网 - HTML5先行者学习网

以下为引用的内容:

<script language="C#" runat=server> UXJHTML5中文学习网 - HTML5先行者学习网

    void SubmitBtn_Click(Object sender, EventArgs e) {
      Message.Text = "Hi " + Name.Text + ", you selected: " + Category.SelectedItem;
    }
</script> UXJHTML5中文学习网 - HTML5先行者学习网

UXJHTML5中文学习网 - HTML5先行者学习网

以上是用C#写的一个事件处理函数,void SubmitBtn_Click(Object sender , EventArgs e) , void代表该函数没有返回值,sender是事件中触发的对象,在这里就是button对象,e是触发事件的参数。该函数中的Message、Name、Category并没有定义,它们来自下面的代码: UXJHTML5中文学习网 - HTML5先行者学习网

以下为引用的内容:
    <form action="intro6.aspx" method="post" runat="server">
      <h3> Name: <asp:textbox id="Name" runat="server"/>
      Category: <asp:dropdownlist id="Category" runat=server>
             <asp:listitem>psychology</asp:listitem>
             <asp:listitem>business</asp:listitem>
             <asp:listitem>popular_comp</asp:listitem>
           </asp:dropdownlist>
      <asp:button type=submit text="Lookup" OnClick="SubmitBtn_Click" runat="server"/>
      <p>
      <asp:label id="Message" runat="server"/>
</form>
UXJHTML5中文学习网 - HTML5先行者学习网

首先可以注意到表单的写法和html表单完全不同.所有的表单项包括表单本身后面都加上了runat=server,这一属性说明这是服务器端控制项,原先的文本输入,下拉菜单等的写法也变了。在这里采用的是: UXJHTML5中文学习网 - HTML5先行者学习网

<asp:<控件类别> id=[ID] 属性= runat="server"/> UXJHTML5中文学习网 - HTML5先行者学习网

控件的种类有很多(所有控件的列表可以附录中找到),各个控件的属性当然不一样,这会在今后详细介绍,上面的代码中,我们可以看见的有textbox、button的id、text属性,以及dropdownlist的SelectedItem属性(注意:这个属性只针对C#,在VB中,要用SelectedItem.Text属性来作为相应的代替)。 UXJHTML5中文学习网 - HTML5先行者学习网

这里出现了一个服务器端控制<asp:label id=”Message” runat=”server”/>,这个asp:label是传统表单所没有的,它是一个服务器端文本控制,那么就存在一个问题,如果传统的HTML里没有这个元素,那么ASP+是怎么接收的呢?你运行一下这个程序,然后看一下HTML源码,你会发现这么一行: UXJHTML5中文学习网 - HTML5先行者学习网

<INPUT type="hidden" name="__VIEWSTATE" value="a0z-1715863018__x"> UXJHTML5中文学习网 - HTML5先行者学习网

对,ASP+就是通过这个隐藏表单的形式传递过去的。另外,在提交后你可以发现在文本框中填写的内容,以及下拉菜单的选择都被保留下来了,这在ASP中需要代码来实现。 UXJHTML5中文学习网 - HTML5先行者学习网

需要提出的一点,在ASP.NET中,还可以有另一种方式添加服务器端控件: UXJHTML5中文学习网 - HTML5先行者学习网

以下为引用的内容:
<script language="C#" runat=server>
void AddText(){
TextBox text1=new TextBox();
text1.Text="TEST";
……
}
</script>
UXJHTML5中文学习网 - HTML5先行者学习网

这一段代码添加了一个TextBox控件。更多内容,可参看: 什么是ASP.NET的WEBFORM UXJHTML5中文学习网 - HTML5先行者学习网

二、一个数据库连接的例子 UXJHTML5中文学习网 - HTML5先行者学习网

使用DNS连接,代码,说明 UXJHTML5中文学习网 - HTML5先行者学习网

CONFIG.WEB 中的设置: UXJHTML5中文学习网 - HTML5先行者学习网

以下为引用的内容:

<appsettings>
<add key="MyConn" value="server=localhost;uid=sa;pwd=mypassword;
Database=somedatabase"/>
  </appsettings> 
**********************************************************
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SQL" %>
<script language="VB" runat="server">
Sub Page_Load(Src As Object, E As EventArgs)
Dim MyConnection As SQLConnection
‘SQLSERVER 的连接对象
Dim Config as HashTable
’定义一个本地变量
Config = Context.GetConfig("appsettings")
’用本地变量来保存DSN连接字符串变量
MyConnection = New SQLConnection(Config("MyConn"))
‘建立连接
Dim MyCommand As SQLCommand
’申明一个Command对象来往database中插入数据 UXJHTML5中文学习网 - HTML5先行者学习网

dim parm1 as string = "SomeTextValue"
dim parm1 as string = "SomeTextValue2" UXJHTML5中文学习网 - HTML5先行者学习网

Dim InsertCmd As String = "Insert into tablename values (@parm1, @parm2)" UXJHTML5中文学习网 - HTML5先行者学习网

'Using the connection string
'使用连接字符串
MyCommand = New SQLCommand(InsertCmd, MyConnection) UXJHTML5中文学习网 - HTML5先行者学习网

MyCommand.Parameters.Add(New SQLParameter("@Parm1", SQLDataType.VarChar, 50))
MyCommand.Parameters("@Parm1").Value = Parm1 UXJHTML5中文学习网 - HTML5先行者学习网

MyCommand.Parameters.Add(New SQLParameter("@Parm2", SQLDataType.VarChar, 50))
MyCommand.Parameters("@Parm2").Value = Parm2 UXJHTML5中文学习网 - HTML5先行者学习网

MyCommand.ActiveConnection.Open()
MyCommand.Execute()
MyCommand.ActiveConnection.Close() UXJHTML5中文学习网 - HTML5先行者学习网

End Sub
</script> UXJHTML5中文学习网 - HTML5先行者学习网

UXJHTML5中文学习网 - HTML5先行者学习网

在以上的代码中,在利用CONFIG.WEB中设置的DNS建立连接后,又用一个COMMAND 的对象完成了插入数据的操作.和从前的ADO没什么不同,只是对象名字有些改变。 UXJHTML5中文学习网 - HTML5先行者学习网

三、一个发送邮件的例子 UXJHTML5中文学习网 - HTML5先行者学习网

下面给出一段代码,非常容易的实现了发送一封HTML格式,带有附件的EMAIL。而不象ASP中需要自己编写组件来实现。 UXJHTML5中文学习网 - HTML5先行者学习网

以下为引用的内容:
<% @Page Language="C#" %>
<% @Import Namespace="System.Web.Util" %>
<%
MailMessage msgMail = new MailMessage();
msgMail.To = "mail@mail.com";
msgMail.Cc = "mail1@mail.com";
msgMail.From = "webmaster@mail.com";
msgMail.Subject = "Attachment ";
msgMail.BodyFormat = MailFormat.Html;
string strBody = "<b>here is an attachment</b>";
msgMail.Body = strBody;
msgMail.Attachments.Add(new MailAttachment("c://temp//test.txt"));
SmtpMail.Send(msgMail);
Response.Write("Email 已经发送成功");
%>
UXJHTML5中文学习网 - HTML5先行者学习网

上面的代码中,首先是引入System.Web.Util类库,这样才能调用MailMessage对象,有关它的属性的使用,上面的代码中已经很清楚了,要注意的地方有BodyFormat属性在为MailFormat.Html时,邮件正文是HTML格式,如果改为MailFormat.Text,则是文本格式,还有,请检查你的SMTP服务的设置,邮件发送需要它的支持。 UXJHTML5中文学习网 - HTML5先行者学习网

四、一个上传的例子 UXJHTML5中文学习网 - HTML5先行者学习网

ASP中上传文件需要自己写组件,代码,说明 UXJHTML5中文学习网 - HTML5先行者学习网

以下为引用的内容:

<html>
  <script language="VB" runat=server> UXJHTML5中文学习网 - HTML5先行者学习网

   Sub UploadBtn_Click(Sender as Object, E as EventArgs) UXJHTML5中文学习网 - HTML5先行者学习网

     UploadFile.PostedFile.SaveAs(Server.MapPath("test.jpg"))
     MyImage.ImageUrl = "test.jpg"
     MyImage.Visible = true UXJHTML5中文学习网 - HTML5先行者学习网

   End Sub UXJHTML5中文学习网 - HTML5先行者学习网

  </script> UXJHTML5中文学习网 - HTML5先行者学习网

  <body>
   <form enctype="multipart/form-data" runat=server>
     <h3>
  Select File To Upload: <input id="UploadFile" type=file runat=server>
  <asp:button Text="Upload Me!" OnClick="UploadBtn_Click" runat=server/> UXJHTML5中文学习网 - HTML5先行者学习网

     <hr> UXJHTML5中文学习网 - HTML5先行者学习网

     <asp:image id="MyImage" Visible=false runat=server/> UXJHTML5中文学习网 - HTML5先行者学习网

   </form>
  </body>
</html> UXJHTML5中文学习网 - HTML5先行者学习网

UXJHTML5中文学习网 - HTML5先行者学习网

直接调用UploadFile对象(它所在的类库是ASP.NET默认的,所以不用额外的 Import 一个 Namespace。)很容易的实现了上传,不用象在ASP中那样,要自己编写上传组件了。 UXJHTML5中文学习网 - HTML5先行者学习网

UXJHTML5中文学习网 - HTML5先行者学习网

UXJHTML5中文学习网 - HTML5先行者学习网
UXJHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助