.Net 学习笔记

我的学习笔记

博客园 首页 新随笔 联系 订阅 管理
  6 Posts :: 1 Stories :: 6 Comments :: 0 Trackbacks

2008年8月3日 #

最近帮朋友做一个报名站,非常简单,于是拿.NET 3.5特别是LINQ to SQL来练练手。

一切顺利,唯独遇到一个小问题:有些记录,我只想每个用户在数据库中只拥有一条记录,如果数据库中已经存在记录,则用新的内容对原数据UPDATE,没有的话则INSERT。利用异常处理走了个小偏门,感觉不能算是正统的办法,希望哪位看到给指导一下。


代码如下:

 1public partial class Test : System.Web.UI.Page
 2{
 3protected void InsertOrUpdateDate()
 4{
 5    GraduateRegisterDataContext context = new GraduateRegisterDataContext(StaticData.ConnectionString);
 6    try {
 7        // 记录存在,检索后修改ProvinceOf值为2
 8        FamilyInfo family = context.FamilyInfo.Single(f => f.NationalId == "3");
 9        family.ProvinceOf = "200";
10    }

11    catch (InvalidOperationException inex) {
12        // 记录不存在,触发InvalidOperationException异常,创建新对象后插入
13        FamilyInfo family = new FamilyInfo {
14            Address = "1",
15            ApplyReason = "1",
16            CityOf = "1",
17            NationalId = "3",
18            DistrictOf = "1",
19            FinacialStatus = "1",
20            IsApplyGrant = true,
21            ZipCode = "1",
22            ProvinceOf = "1"
23        }
;
24        context.FamilyInfo.InsertOnSubmit(family);
25    }

26    finally {
27        context.SubmitChanges();
28    }

29}

 

posted @ 2008-08-03 20:43 AntiGameZ 阅读(159) | 评论 (0)编辑

2006年12月31日 #

SiteMapDataSource.ShowStartingNode = false

就这样...解决了。

posted @ 2006-12-31 00:56 AntiGameZ 阅读(467) | 评论 (0)编辑

2006年12月30日 #

原文连接:http://www.w3cn.org/article/layout/2004/88.html

如何使整个页面内容居中,如何使高度适应内容自动伸缩。这是学习CSS布局最常见的问题。下面就给出一个实际的例子,并详细解释。(本文的经验和是蓝色理想论坛xpoint、guoshuang共同讨论得出的。)

首先先按这里看实际运行效果,这个页面在mozilla、opera和IE浏览器中均可以实现居中和高度自适应。我们来分析代码:

<html>
<head>
<style type="text/css">
body
{
background
:#999;
text-align
:center;
color
: #333;
font-family
:arial,verdana,sans-serif;
}
#header
{
width
:776px;
margin-right
: auto;
margin-left
: auto;
padding
: 0px;
background
: #EEE;
height
:60px;
text-align
:left;
} #contain{
margin-right
: auto;
margin-left
: auto;
width
: 776px;
} #mainbg{
width
:776px;
padding
: 0px;
background
: #60A179;
float
: left;
}
#right
{
float
: right;
margin
: 2px 0px 2px 0px;
padding
:0px;
width
: 574px;
background
: #ccd2de;
text-align
:left;
}
#left
{
float
: left;
margin
: 2px 2px 0px 0px;
padding
: 0px;
background
: #F2F3F7;
width
: 200px;
text-align
:left;
}
#footer
{
clear
:both;
width
:776px;
margin-right
: auto;
margin-left
: auto;
padding
: 0px;
background
: #EEE;
height
:60px;}
.text
{margin:0px;padding:20px;}
</style>
</head>
<body>
<div id="header">header</div>
<div id="contain">
<div id="mainbg">
<div id="right">
<div
class="text">right<p>1</p><p>1</p><p>1</p><p>1</p><p>1</p></div>
</div>
<div id="left">
<div class="text">left</div>
</div>
</div>
</div>
<div id="footer">footer</div>
</body>
</html>



首先我们定义body和顶部第一行#header,这里面的关键是body中的text-align:center;和header中的margin-right: auto;margin-left: auto;,通过这两句使得header居中。注:其实定义text-align:center;就已经在IE中实现居中,但在mozilla中无效,需要设置margin:auto;才可以实现mozilla中的居中。

接下来定义中间的两列#right和#left。为了使中间两列也居中,我们在它们外面嵌套一个层#contain,并对contain设置margin:auto;,这样#right和#left就自然居中了。

注意中间两列定义的顺序,我们首先定义#right,通过float: right;让它浮在#contain层的最右边。然后再定义#left,通过float: left;让它浮动在#right层的左面。这和我们以前表格从左到右定义的顺序正好相反(更正:先左后右、还是先右后左都可以实现,根据自己需要设计)。

我们看到代码中在#contain和两列之间还嵌套了一个层#mainbg,这个层是做什么用的呢?这个层就是用来定义#contain的背景的。 你肯定会问,为什么不直接在#contain中定义背景,而要多套一层呢?那是因为在#contain中直接定义的背景,在mozilla中将显示不出 来,必须定义高度值才可以。如果定义了高度值,#right层就无法实现根据内容的自动伸缩。为了解决背景和高度问题,就必须增加这么一个#mainbg 层。窍门在于#mainbh这个层定义float: left;,因为float使层自动有宽和高的属性。(暂且这么理解:)

最后是定义底部的#footer层。这个定义的关键是:clear:both;,这一句话的作用是取消#footer层的浮动继承。否则的话,你会看到#footer紧贴着#header显示,而不是在#right的下面。

主要的层定义完毕,这个布局就ok了。补充一点:你看到我还定义了一个.text{margin:0px;padding:20px;}, 这个class的作用是使内容的外围有20px的空白。为什么不直接在#right里定义margin或者padding呢,因为mozilla和IE对 css盒模型的解释不一致,直接定义margin/padding会造成mozilla里布局变形。我一般采用内部再套一层的做法来解决。



posted @ 2006-12-30 21:13 AntiGameZ 阅读(62) | 评论 (0)编辑

     摘要: 也许是之前被DropDownList折磨惨了,这两天时不时的都要研究下这个小玩意,今天写SiteMap的时候想起来DDL能和XMLDataSource绑定,不知道折腾起来怎么样。当然,DDL也可以直接和SiteMapDateSource进行绑定,但是我就不采用这个方法了。XML文件,太长,折叠了一下,展开察看:Code highlighting produced by Actipro CodeHi... 阅读全文
posted @ 2006-12-30 00:16 AntiGameZ 阅读(354) | 评论 (3)编辑

看了很多人都是自己程序获得用户的角色权限,再判断并编写相应的功能菜单,其实.net 中可以允许开发者自己拼合这些功能;
废话不说,网上也有很多这样的资料,但我感觉说教太多,自己来简单归纳一下方便给大家!

注:站点必须为asp.net 标准验证方式。自定义cookie认证,自定义Session方式的可以一边凉快去了!

具体条件
   1、为站点准备SiteMap
      在站点根目录建立一个Web.sitemap 配置文件,例:

 1 <?xml version="1.0" encoding="utf-8" ?>
 2 <siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
 3     <siteMapNode url="~/Default.aspx" title="首页"  description="" >
 4         <siteMapNode url="~/Register.aspx" title="注册"  description="" />
 5         <siteMapNode url="~/Login.aspx" title="登陆"  description="" />
 6       <siteMapNode url="~/Album/Default.aspx" title="个人管理" description="">
 7         <siteMapNode url="~/Album/AlbumManager.aspx" title="相册管理" description="" />
 8         <siteMapNode url="~/Album/ImageUploader.aspx" title="图片上传" description="" />
 9         <siteMapNode url="~/Album/ImageManager.aspx" title="图片管理" description="" />
10       </siteMapNode>
11     </siteMapNode>
12 </siteMap>

注意:第一级节点只能有1个,其他节点就随意了,可以把全站所有有关的页都编写进来,也可以只写有权限      控制相关的页,这个是可以继承的。
   安装有MSDN2005的朋友可以看此内容:ASP.NET 站点地图
      ms-help://MS.VSCC.v80/MS.MSDN.v80/MS.VisualStudio.v80.chs/dv_aspnetcon/html/6b85a558-1df8-44cf-bea6-62e61bcc8d20.htm
  
   2、为文件或目录设置访问权限
      在相关目录的Web.config 中设置就可以,跟平时设置一样

 1 <system.web>
 2       <authorization>
 3         <!-- 当前目录由Album 角色的用户才可以访问 -->
 4         <allow roles="Album" />
 5         <deny users ="*"/>
 6       </authorization>
 7     </system.web>
 8   
 9   <location path="ImageUploader.aspx">
10     <system.web>
11       <authorization>
12         <!-- ImageUploader.aspx 只能带Blog角色的用户才可以访问 -->
13         <allow roles="Blog"/>
14         <deny users ="*"/>
15       </authorization>
16     </system.web>
17   </location>


   3、在根Web.config 中启用站点地图角色过滤配置,想省事可以直接复制粘贴
 1   <system.web>
 2     <siteMap defaultProvider="XmlSiteMapProvider" enabled="true">
 3       <providers>
 4         <add name="XmlSiteMapProvider"
 5           description="Default SiteMap provider."
 6           type="System.Web.XmlSiteMapProvider "
 7           siteMapFile="Web.sitemap"
 8           securityTrimmingEnabled="true" />
 9       </providers>
10     </siteMap>
11   </system.web>
12 


就这样就OK了!测试一把~~!

   1、拖一个Menu 控件到页面上,并新建一个数据源类型为“站点地图”类型,名字随意。点OK就配置好了!

    测试用例1:(没有登陆以前,只显示根目录下谁都可以访问的文件)
    
   测试用例2:(登陆后,具备Album 角色但不具备Blog 角色能力)
   
   测试用例3:(登陆后,具备Album角色也具备Blog 角色)
   

完成收工,回家了,显然这样的方式,大量减少的代码,而且把页面文件或目录跟角色绑定起来,实在是非常方便的。
posted @ 2006-12-30 00:03 AntiGameZ 阅读(83) | 评论 (1)编辑

2006年12月28日 #

从晚上九点到现在,10个多小时了,终于把DropListDown的问题搞定。

用FormView做了一个Movie的添加页面,其中Category的添加是用DropDownList做的,DropDownList控件绑定了Category表。一开始不知道为什么,选定了Category,填完了数据,却总是报错说Category字段不能为NULL。自己研究许久无功而返,无意之中还是在博克园看到一篇文章:“ASP.NET 2.0中的数据操作::定制数据修改界面”,终于明白:

此外,如果点击更新,你会发现该产品的CategoryID 和 SupplierID都变成了NULL。这些都是由于EditItemTemplate模板中的下拉框没有根据数据库中的实际数据进行绑定。

为DropDownList绑定CategoryID 和 SupplierID 数据。

为了使product编辑状态下的category和supplier下拉列表选中实际数据,并使其可以根据用户选择调用BLL的UpdateProduct方法对数据库进行更新,我们需要对两个下拉框的SelectedValue分别绑定到CategoryID 和 SupplierID。例如对于Categories下拉框,我们直接在元素标记中增加SelectedValue='<%# Bind("CategoryID") %>'。

另一种做法是在设计器中,通过下拉框的智能标记,点击“编辑DataBinding”链接,设置编辑模板中的下拉框的数据绑定。接下来,用双重模式指定SelectedValue绑定到CategoryID字段(见图10)。重复上面的方法之一,为Suppliers下拉框绑定SupplierID 数据。

终于恍然大悟,问题就出在这个“双向数据绑定上”。

花了10个小时搞定这么一个小问题实在效率低下,不过终究是解决了,一宿没睡,好歹有了一个交待。同时也准备积极启用博客园的这个博客作为自己的技术仓库。 
posted @ 2006-12-28 05:50 AntiGameZ 阅读(234) | 评论 (2)编辑