asp.net权限控制

有人说asp.net很简单,其实呢这只是表面现象。要把asp.net学的很深真的是一件不容易的事情,从开发的角度来说asp.net要方便一些,只是移植性差了一些。学过java之后再来学习就会觉得很简单,很快就可以上手。

下面就接着前面的博客写一个权限控制和内置对象相结合的小例子,这个例子在学校里可谓经典。所以我就借这个小例子来弄下。

1.开发一个用户登录表单,这里只有登录后的用户才能进入下载页面

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="downloadfile._Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>用户登录</title>
</head>
<body>
    <form id="form1" runat="server" action="ashx/ToLogin.ashx">
     用户名:<input type="text" name="fname"/><br /><br/>
     密码:<input type="password" name="password"/><br /><br/>
     <input type="submit" value="登录"/>
      <input type="reset" value="取消"/>
    </form>
</body>
</html>

2.新建一个数据库文件,并创建一个数据表

3.添加一个数据集,后面会使用类型化dataset来查询数据库


4.编写一般处理程序处理用户登录

using System;
using System.Collections;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;
using System.Web.SessionState;
using downloadfile.DataSetTeacherTableAdapters;

namespace downloadfile.ashx
{
    /// <summary>
    /// $codebehindclassname$ 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    public class ToLogin : IHttpHandler, IRequiresSessionState
    {

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            string fname = context.Request["fname"];
            string password = context.Request["password"];
            m_teacherTableAdapter adpater = new m_teacherTableAdapter();
          
            var data = adpater.GetDataByFname(fname);
            var single = data.Single();
          if (data.Count <= 0)
          {
              context.Response.Write("用户名不存在");
          }
          else {
              //判断数据的唯一性,防止出现未知错误
            
              //如果用户输入的密码和数据库的相同,则可以登录成功
              if (single.fpassword.Equals(password))
              {
                  context.Session["status"] = "login";
                  context.Session["username"] = fname;
                  context.Session["password"] = password;
                  context.Session["userid"] = single.fid;
                  //context.Response.Write("登录成功");
                  context.Response.Redirect("../manage/allpicture.htm");

              }else{
                  context.Response.Redirect("../Default.aspx");
              }
             
          }
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}


5.编写图片的下载页面

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>图片下载页面</title>
</head>
<body>
 <center>
   <div>
     <a href="../ashx/Download.ashx?filename=1.jpg">1.jpg</a>
     <a href="../ashx/Download.ashx?filename=2.jpg">2.jpg</a>
     <a href="../ashx/Download.ashx?filename=3.jpg">3.jpg</a>
     <a href="../ashx/Download.ashx?filename=4.jpg">4.jpg</a>
   </div> 
 </center>
  
</body>
</html>


6.编写下载的处理程序,如果是普通用户则下载的图片加水印

using System;
using System.Collections;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;
using downloadfile.DataSetTeacherTableAdapters;
using System.Web.SessionState;
using System.Drawing;
using System.Drawing.Imaging;

namespace downloadfile.ashx
{
    /// <summary>
    /// $codebehindclassname$ 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    public class Download : IHttpHandler,IRequiresSessionState  
    {

        public void ProcessRequest(HttpContext context)
        {
           
            
          
            //如果用户已经
            string status = (string)context.Session["status"];
          
           if (status!=null)
            {
              

               
               //取得文件名称
               string filename=context.Request["filename"];
                //设置消息头用来下载文件
                context.Response.ContentType="application/octet-stream";
                context.Response.AddHeader("Content-Disposition", string.Format("attachment;filename=\"{0}\"", filename));
                //从session取得登录用户的fid
               int fid=(int)context.Session["userid"];
                //根据用户id查询该用户的级别,根据级别获得不同的下载
                //数据集
              
                //通过用户的id查询用户的级别
                m_teacherTableAdapter adpater = new m_teacherTableAdapter();
                var data = adpater.GetDataById(fid);
                var single = data.Single();
                if (single.level == 1)
                {
                    //context.Response.WriteFile("../image/" + filename);
                    using (Bitmap bitmap = new Bitmap(context.Server.MapPath("../image/" + filename)))
                    {
                        using (Graphics gra = Graphics.FromImage(bitmap))
                        {
                            gra.DrawString("免费下载", new Font("宋体", 20), Brushes.Red, 0, 0);
                           
                        }
                        bitmap.Save(context.Response.OutputStream, ImageFormat.Jpeg);

                    } 
                  
                }
                else {
                    context.Response.WriteFile("../image/" + filename);
                }


            }
            else
            {
                context.Response.Write(status);
                //context.Response.Write("请先登录");
            }
          
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}


7.最后来看下程序的运行效果

不好意思了,刚要上传图片的,运气不好遇到了csdn升级。代码我已经上传了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ASP.NET权限控制是指在ASP.NET应用程序中对不同用户或角色的访问权限进行管理和控制的一种机制。通过权限控制,可以确保只有具备相应权限的用户才能访问特定的页面、功能或资源,从而保障系统的安全性和合规性。 ASP.NET提供了多种权限控制的方式。其中一种常见的方式是使用角色和认证。角色是对用户进行分类的一种方式,通过为用户分配角色,在系统中可以根据角色对用户的权限进行管理和控制。而认证是指验证用户的身份是否合法,只有通过了认证的用户才可以访问受限资源。 ASP.NET可以通过使用ASP.NET提供的内置的认证和授权机制来进行权限控制。其中认证可以使用Forms身份验证、Windows身份验证等方式,授权可以使用基于角色的授权、基于声明的授权等方式。通过在应用程序中配置认证和授权的策略,可以在代码中对用户进行身份验证和权限验证,实现对不同资源的不同访问控制。 除了使用内置的认证和授权机制外,ASP.NET还支持自定义的权限控制方式。可以根据具体需求,自定义一些过滤器或模块来实现特定的权限控制逻辑。比如可以使用自定义的授权过滤器来对请求做进一步的权限验证,或者使用自定义的模块来拦截请求并根据用户的角色或权限判断是否可以访问某个资源。 总之,ASP.NET权限控制是通过认证和授权机制,对不同用户或角色的访问权限进行管理和控制的一种机制。ASP.NET提供了多种内置的认证和授权方式,同时也支持自定义的权限控制方式。通过合理配置和使用这些机制,可以实现对系统中不同资源的灵活权限控制
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值