首页 > 编程 > .NET > 正文

ASP.NET学习篇(3)——几个简单的ASP.ENT的例子

2024-07-10 13:12:21
字体:
来源:转载
供稿:网友

一个webform——这里将介绍asp.net webform的基本概念,以及其中表单项的变化。

*一个数据库的应用——如何利用config.web中设置的dns连接数据库,数据库操作对象的一些基本用法。

*email发送——在 引入一个系统类库后(用import 标识符 ),利用msgmail对象,可以很方便的操作邮件发送过程。

*上传——<input type=file …… 这样一个input 项在asp.net中有postedfile属性,结合saveas 事件,就可以实现上传了。

一、 webform的使用

以下为引用的内容:

<script language="c#" runat=server>

    void submitbtn_click(object sender, eventargs e) {
      message.text = "hi " + name.text + ", you selected: " + category.selecteditem;
    }
</script>

以上是用c#写的一个事件处理函数,void submitbtn_click(object sender , eventargs e) , void代表该函数没有返回值,sender是事件中触发的对象,在这里就是button对象,e是触发事件的参数。该函数中的message、name、category并没有定义,它们来自下面的代码:

以下为引用的内容:
    <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>

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

<asp:<控件类别> id=[id] 属性= runat="server"/>

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

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

<input type="hidden" name="__viewstate" value="a0z-1715863018__x">

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

需要提出的一点,在asp.net中,还可以有另一种方式添加服务器端控件:

以下为引用的内容:
<script language="c#" runat=server>
void addtext(){
textbox text1=new textbox();
text1.text="test";
……
}
</script>

这一段代码添加了一个textbox控件。更多内容,可参看: 什么是asp.net的webform

二、一个数据库连接的例子

使用dns连接,代码,说明

config.web 中的设置:

以下为引用的内容:

<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中插入数据

dim parm1 as string = "sometextvalue"
dim parm1 as string = "sometextvalue2"

dim insertcmd as string = "insert into tablename values (@parm1, @parm2)"

'using the connection string
'使用连接字符串
mycommand = new sqlcommand(insertcmd, myconnection)

mycommand.parameters.add(new sqlparameter("@parm1", sqldatatype.varchar, 50))
mycommand.parameters("@parm1").value = parm1

mycommand.parameters.add(new sqlparameter("@parm2", sqldatatype.varchar, 50))
mycommand.parameters("@parm2").value = parm2

mycommand.activeconnection.open()
mycommand.execute()
mycommand.activeconnection.close()

end sub
</script>

在以上的代码中,在利用config.web中设置的dns建立连接后,又用一个command 的对象完成了插入数据的操作.和从前的ado没什么不同,只是对象名字有些改变。

三、一个发送邮件的例子

下面给出一段代码,非常容易的实现了发送一封html格式,带有附件的email。而不象asp中需要自己编写组件来实现。

以下为引用的内容:
<% @page language="c#" %>
<% @import namespace="system.web.util" %>
<%
mailmessage msgmail = new mailmessage();
msgmail.to = "[email protected]";
msgmail.cc = "[email protected]";
msgmail.from = "[email protected]";
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 已经发送成功");
%>

上面的代码中,首先是引入system.web.util类库,这样才能调用mailmessage对象,有关它的属性的使用,上面的代码中已经很清楚了,要注意的地方有bodyformat属性在为mailformat.html时,邮件正文是html格式,如果改为mailformat.text,则是文本格式,还有,请检查你的smtp服务的设置,邮件发送需要它的支持。

四、一个上传的例子

asp中上传文件需要自己写组件,代码,说明

以下为引用的内容:

<html>
  <script language="vb" runat=server>

   sub uploadbtn_click(sender as object, e as eventargs)

     uploadfile.postedfile.saveas(server.mappath("test.jpg"))
     myimage.imageurl = "test.jpg"
     myimage.visible = true

   end sub

  </script>

  <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/>

     <hr>

     <asp:image id="myimage" visible=false runat=server/>

   </form>
  </body>
</html>

直接调用uploadfile对象(它所在的类库是asp.net默认的,所以不用额外的 import 一个 namespace。)很容易的实现了上传,不用象在asp中那样,要自己编写上传组件了。



收集最实用的网页特效代码!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表