Form验证之简单应用

1,创建四个文件夹 Admin AdminFolder,DataClass,UserFolder。

Admin:登录以及注册页面

AdminFolder:放入拥有Admin权限的页面

UserFolder:放入拥有User权限的页面

DataClass:Serialize.cs  序列化以及反序列化

                 LoginInfo.cs:存入登录信息

                 BasePage.cs  每个页面所要继承取值的类

2,创建一些Web.config

AdminFolder下的config:

<?xml version="1.0"?>
<configuration>
    <system.web>
        <authorization>
            <allow roles="Admin"/>
            <deny users="*"/>
        </authorization>
    </system.web>
</configuration>


roles为Admin,如果没有权限,拒绝一切用户。

UserFolder同理。

根目录下Config:

<authentication mode="Forms">
            <forms loginUrl="Admin/Login.aspx" timeout="20" path="/" protection="All" />
        </authentication>

    <location path="Admin/Register.aspx">
        <system.web>
            <authorization>
                <allow users="*"/>
            </authorization>
        </system.web>
    </location>


 

location写为regist.aspx,代表不限制注册页用户。

loginUrl:默认登录页面。

3,一些代码:

BasePage.cs:

public class BasePage:Page
    {
        public LoginInfo LoginUser
        {
            get
            {
                //从票据中返回UserData,并反序列化为对象
                string strUser = ((FormsIdentity)this.Context.User.Identity).Ticket.UserData;
                return Serialize.DnSerializeFun(strUser);
            }
        }
    }


LoginInfo.cs:

[Serializable]
    public class LoginInfo
    {
        public int id { get; set; }
        public string Name { get; set; }
        public DateTime LoginTime { get; set; }
        public string Roles { get; set; }
    }


 

Serializable代表可被序列化。

Serialize.cs:

//对象序列化为字符串
        public string SerializeFun(LoginInfo Li)
        {
            BinaryFormatter bf = new BinaryFormatter();
            MemoryStream ms = new MemoryStream();
            bf.Serialize(ms, Li);
            byte[] objbyte = ms.ToArray();
            return Convert.ToBase64String(objbyte, 0, objbyte.Length);
        }
        //字符串序列化为对象
        public  static LoginInfo DnSerializeFun(string SerializeStr)
        {
            byte[] byt = Convert.FromBase64String(SerializeStr);
            BinaryFormatter bf = new BinaryFormatter();
            MemoryStream ms = new MemoryStream(byt, 0, byt.Length);
            return bf.Deserialize(ms) as LoginInfo;           
        }


Global.asax:

protected void Application_AuthenticateRequest(Object sender, EventArgs e)
        {
            if (this.Context.User != null)
            {
                if (this.Context.User.Identity.IsAuthenticated)
                {
                    if (this.Context.User.Identity is FormsIdentity)
                    {
                        string strUser = ((FormsIdentity)this.Context.User.Identity).Ticket.UserData;

                        string[] roles = DataClass.Serialize.DnSerializeFun(strUser).Roles.Split(',');

                        this.Context.User = new GenericPrincipal(this.Context.User.Identity, roles);
                    }
                }
            }
        }


 

GenericPrincipal:用户属于哪个权限

两种登录方法:

//自动设置Ticket
        private void AutoLogin()
        {
            FormsAuthentication.SetAuthCookie(TextBox1.Text, false);
            Response.Redirect("Main.aspx"); 

        }
        //手动设置Ticket
        private void TicketLogin()
        {
            LoginInfo dl = new LoginInfo();
            Serialize sr = new Serialize();

            if (TextBox1.Text == "123" && TextBox2.Text == "123")
            {
                //LoginInfo赋值
                dl.id = 1;
                dl.Name = TextBox1.Text;
                dl.LoginTime = DateTime.Now;

                //判断什么Roles,用,分开
                dl.Roles = "User,Admin";
                //序列化LoginInfo
                string SeStr = sr.SerializeFun(dl);

                //定义ticket
                FormsAuthenticationTicket ft = new FormsAuthenticationTicket(1, "Admin", DateTime.Now, DateTime.Now.AddMinutes(20), false, SeStr);

                //加密ticket
                string strTicket = FormsAuthentication.Encrypt(ft);

                //使用userdata保存cookie
                HttpCookie cookie = new HttpCookie(FormsAuthentication.FormsCookieName, strTicket);
                cookie.Expires = ft.Expiration;
                Response.Cookies.Add(cookie);
                Response.Redirect("../AdminFolder/AdminPage.aspx");
            }
            else
            {
                Response.Write("密码错误");
            }
        }


页面取值:

public partial class UserPage : DataClass.BasePage
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            Response.Write(LoginUser.Roles);
        }
    }


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您可以使用uni-app自带的表单验证组件来验证表单。首先,在表单中添加验证规则,然后在提交表单时,使用uni-app提供的验证方法来验证表单数据。如果表单数据验证失败,则可以提示用户错误信息。具体实现方法可以参考uni-app官方文档中的表单验证部分。 ### 回答2: Uniapp是一个跨平台的开发框架,可以用于开发多种类型的应用程序,包括 Web 应用程序。在 Uniapp 中,我们可以使用 Vue.js 的表单验证方式来验证表单。下面是简单的步骤: 1. 导入验证插件:在 main.js 文件中导入 `vee-validate` 或其他验证插件。 2. 创建表单:在页面中创建表单,并为表单中的每个输入字段添加相应的验证规则和消息提示。 3. 添加验证代码:在表单的提交事件或其他需要验证的事件中,编写验证代码。 4. 运行验证:通过调用验证函数来运行验证,根据验证结果执行相应的操作。 具体步骤如下所述: 1. 导入验证插件:在 main.js 文件中,使用以下代码导入 `vee-validate` 插件: ``` import { ValidationProvider, ValidationObserver, extend } from 'vee-validate'; import { required, email } from 'vee-validate/dist/rules'; Vue.component('ValidationProvider', ValidationProvider); Vue.component('ValidationObserver', ValidationObserver); extend('required', required); extend('email', email); ``` 2. 创建表单:在页面中,使用 `ValidationProvider` 组件来包裹输入字段,并在组件上添加 `rules` 和 `message` 属性来设置相应的验证规则和消息提示。例如: ``` <ValidationProvider rules="required" v-slot="{ errors }"> <input type="text" v-model="name" /> <span>{{ errors[0] }}</span> </ValidationProvider> ``` 3. 添加验证代码:在表单的提交事件或其他需要验证的事件中,编写相应的验证代码。例如: ``` methods: { submitForm() { this.$refs.observer.validate().then(valid => { if (valid) { // 验证通过,执行相应的操作 // ... } else { // 验证失败,对错误进行处理 // ... } }); } } ``` 4. 运行验证:通过调用 `$refs` 对象中的 `observer` 组件的 `validate` 方法来运行验证。根据验证的结果执行相应的操作。 这只是一个简单的使用示例,你还可以根据具体需求自定义更复杂的验证规则和逻辑。希望对你有帮助! ### 回答3: uniapp提供了一种方便的方式来验证form表单。以下是一个简单的步骤: 1. 在form表单中,给每个需要验证的input添加一个`name`属性。例如:`<input name="username" />` 2. 创建一个`data`对象来存储需要验证的字段。例如:`data: { username: '', password: '', email: '' }` 3. 在form表单外部创建一个`methods`对象,用于存放验证的方法。例如: ``` methods: { // 验证用户名 validateUsername() { if (this.data.username === '') { // 验证失败,给出提示 uni.showToast({ title: '请输入用户名', icon: 'none' }) return false } // 验证成功 return true }, // 验证密码 validatePassword() { // ... }, // 验证邮箱 validateEmail() { // ... }, // 提交表单 submitForm() { if (this.validateUsername() && this.validatePassword() && this.validateEmail()) { // 所有字段验证通过,可以提交表单 // ... } } } ``` 4. 在form表单中的提交按钮上绑定`submitForm`方法。例如:`<button @click="submitForm">提交</button>` 5. 在`submitForm`方法中调用各个字段的验证方法,如果所有字段验证通过,则可以提交form表单。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值