一个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) { |
以上是用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> dim parm1 as string = "sometextvalue" dim insertcmd as string = "insert into tablename values (@parm1, @parm2)" 'using the connection string mycommand.parameters.add(new sqlparameter("@parm1", sqldatatype.varchar, 50)) mycommand.parameters.add(new sqlparameter("@parm2", sqldatatype.varchar, 50)) mycommand.activeconnection.open() end sub |
在以上的代码中,在利用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> sub uploadbtn_click(sender as object, e as eventargs) uploadfile.postedfile.saveas(server.mappath("test.jpg")) end sub </script> <body> <hr> <asp:image id="myimage" visible=false runat=server/> </form> |
直接调用uploadfile对象(它所在的类库是asp.net默认的,所以不用额外的 import 一个 namespace。)很容易的实现了上传,不用象在asp中那样,要自己编写上传组件了。
新闻热点
疑难解答
图片精选