一些记录,已备后用

本文介绍了一个基于C#的用户管理系统,实现了用户登录、获取用户信息等功能,并通过角色分配不同的权限,支持按ID获取特定用户及更新用户角色。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using MyBookShop.DAL;
using myRole.Models;

namespace myRole.DAL
{
    public class UserService
    {
        /// <summary>
        /// 获得所有的用户
        /// </summary>
        /// <returns></returns>
        public static IList<User> GetAllUser()
        {

            DataTable tbl = DBHelper.GetDataSet("select*from Users");
            IList<User> lis = new List<User>();
            foreach (DataRow row in tbl.Rows)
            {
                User user = new User();
                user.Uid = Int32.Parse(row["uid"].ToString());
                user.Uname = row["uname"].ToString();
                user.Upass = row["upass"].ToString();
                user.Rid = Int32.Parse(row["rid"].ToString());
                lis.Add(user);
            }
            return lis;
        }
        /// <summary>
        /// 用户登陆
        /// </summary>
        /// <param name="pass"></param>
        /// <param name="uname"></param>
        /// <returns></returns>
        public static User LoginUser(String pass, String uname)
        {
            String sql = "select*from Users where uname=@uname and upass=@upass";
            SqlParameter[] prr = new SqlParameter[] { 
            new SqlParameter("@uname",uname),
            new SqlParameter("@upass",pass)
            };
            SqlDataReader reader = DBHelper.GetReader(sql,prr);
            User user = new User();
            if (reader.Read())
            {
                user.Uid = Int32.Parse(reader["uid"].ToString());
                user.Uname = reader["uname"].ToString();
                user.Upass = reader["upass"].ToString();
                user.Rid = Int32.Parse(reader["rid"].ToString());
            }
            reader.Close();
            reader.Dispose();
            return user;
        }
        /// <summary>
        /// 根据id获取用户信息
        /// </summary>
        /// <param name="uid"></param>
        /// <returns></returns>
        public static User GetUserByUId(int uid)
        {

            String sql = "select*from Users where Uid=@uid";
            SqlParameter[] pp = new SqlParameter[] {
                new SqlParameter("@uid",uid)
            };
            SqlDataReader reader = DBHelper.GetReader(sql, pp);
            User user = new User();
            if (reader.Read())
            {
                user.Uid = Int32.Parse(reader["uid"].ToString());
                user.Uname = reader["uname"].ToString();
                user.Upass = reader["upass"].ToString();
                user.Rid = Int32.Parse(reader["rid"].ToString());
            }
            reader.Close();
            reader.Dispose();
            return user;
        }
        /// <summary>
        /// 根据角色获取所有的角色所拥有的权限
        /// </summary>
        /// <param name="rid"></param>
        /// <returns></returns>
        public static IList<Rules> GetRuleByRoleId(int rid)
        {
            IList<MidRoleAndRule> midRule= MidServices.GetRoleByRoleId(rid);
            IList<Rules> ruleList = new List<Rules>();
            foreach (MidRoleAndRule mid in midRule)
            {
             int ruid=mid.Ruid;//权限信息id
             Rules rule=RuleService.GetRuleByRuid(ruid);
             ruleList.Add(rule);
            }
            return ruleList;
        }
        /// <summary>
        /// 修改用户的角色
        /// </summary>
        /// <param name="roleId"></param>
        /// <returns></returns>
        public static int UpdateUserRole(int roleId,int uid)
        {
            String sql="update Users set rid=@rid where Uid=@uid";
            SqlParameter[] prar = new SqlParameter[] { 
            new SqlParameter("@rid",roleId),
            new SqlParameter("@uid",uid)
            };
          return  DBHelper.ExecuteCommand(sql,prar);
        }
    }
}

using System;
using System.Data;
using System.Data.SqlClient;

namespace MyBookShop.DAL
{
    public static class DBHelper
    {
        private static SqlConnection connection;
        public static SqlConnection Connection
        {
            get
            {
                string connectionString = "Data Source=localhost;Initial Catalog=myRole; uid=sa;Password=123";
                if (connection == null)
                {
                    connection = new SqlConnection(connectionString);
                    connection.Open();
                }
                else if (connection.State == System.Data.ConnectionState.Closed)
                {
                    connection.Open();
                }
                else if (connection.State == System.Data.ConnectionState.Broken)
                {
                    connection.Close();
                    connection.Open();
                }
                return connection;
            }
        }

        public static int ExecuteCommand(string safeSql)
        {
            SqlCommand cmd = new SqlCommand(safeSql, Connection);
            int result = cmd.ExecuteNonQuery();
            return result;
        }

        public static int ExecuteCommand(string sql, params SqlParameter[] values)
        {
            SqlCommand cmd = new SqlCommand(sql, Connection);
            cmd.Parameters.AddRange(values);
            return cmd.ExecuteNonQuery();
        }

        public static int GetScalar(string safeSql)
        {
            SqlCommand cmd = new SqlCommand(safeSql, Connection);
            int result = Convert.ToInt32(cmd.ExecuteScalar());
            return result;
        }

        public static int GetScalar(params SqlParameter[] values)
        {
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = Connection;
            cmd.CommandText = "Pro_InsertOrder";
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Parameters.AddRange(values);
            int result = Convert.ToInt32(cmd.ExecuteScalar());
            return result;
        }

        public static int GetScalar(string sql, params SqlParameter[] values)
        {
            SqlCommand cmd = new SqlCommand(sql, Connection);
            cmd.Parameters.AddRange(values);
            int result = Convert.ToInt32(cmd.ExecuteScalar());
            return result;
        }

        public static SqlDataReader GetReader(string safeSql)
        {
            SqlCommand cmd = new SqlCommand(safeSql, Connection);
            SqlDataReader reader = cmd.ExecuteReader();
            return reader;
        }

        public static SqlDataReader GetReader(string sql, params SqlParameter[] values)
        {
            SqlCommand cmd = new SqlCommand(sql, Connection);
            cmd.Parameters.AddRange(values);
            SqlDataReader reader = cmd.ExecuteReader();
            return reader;
        }

        public static DataTable GetDataSet(string safeSql)
        {
            DataSet ds = new DataSet();
            SqlCommand cmd = new SqlCommand(safeSql, Connection);
            SqlDataAdapter da = new SqlDataAdapter(cmd);
            da.Fill(ds);
            return ds.Tables[0];
        }

        public static DataTable GetDataSet(string sql, params SqlParameter[] values)
        {
            DataSet ds = new DataSet();
            SqlCommand cmd = new SqlCommand(sql, Connection);
            cmd.Parameters.AddRange(values);
            SqlDataAdapter da = new SqlDataAdapter(cmd);
            da.Fill(ds);
            return ds.Tables[0];
        }
    }
}




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值