实现某一目录的forms身份验证

后台文件全部放在admin目录下,后台的登录口为admin_login.aspx,现在要实现的功能是:
不能直接访问admin目录下除了admin_login.aspx(即登录口)文件以外的文件,但是前台的文件,比如default.aspx等,要不受forms验证的影响,也就是说,即使没有登录,访问default.aspx时,也不能转到admin_login.aspx.

下面说一下实现过程:
在web.config文件中,设为forms身份验证:
  <authentication mode="Forms">  
    <forms name=".LoginUser" loginUrl="admin/admin_login.aspx" protection="All" timeout="30" />  
  </authentication>
    <authorization>              
        <allow users="*" />      
    </authorization>

然后在</system.web>后还要加入:

 <location path="admin">
    <system.web>
<authorization>
<deny users="?" />
<allow users="*" />
</authorization>
    </system.web>
</location>

否则无论访问哪个文件,都会转到登录口的,加了上面这段代码后,就只有访问admin目录下的文件时可能转到admin_login.aspx,以上就是web.config文件中的设置,接下来就是后台登录按钮的代码了:

//检查登录的用户名和密码是否正确,我用的是从数据库中检查的方法,你可以用其它方法,这里就不说了.
if (OpenData.CheckUser(strSql,"ToEmpire_UserInfo"))
{
//保存登录的用户名
Session["LoginUser"] = strLoginUser;

//这一句就是关键,strLoginUser为登录框中的用户名.false为不永久记录.
FormsAuthentication.RedirectFromLoginPage(strLoginUser,false);

         Response.Redirect("admin_index.aspx");
         }

以上就是forms身份验证的实现过程了

登录成功后,需要退出没写
FormsAuthentication.SignOut();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用 uni-forms 进行表单验证的示例代码: ```html <template> <form @submit.prevent="submitForm"> <div> <label for="username">用户名:</label> <input id="username" type="text" v-model="username" /> <span v-if="errors.username">{{ errors.username }}</span> </div> <div> <label for="password">密码:</label> <input id="password" type="password" v-model="password" /> <span v-if="errors.password">{{ errors.password }}</span> </div> <button type="submit">提交</button> </form> </template> <script> import { ValidationObserver, ValidationProvider } from 'vee-validate' import { required, min } from 'vee-validate/dist/rules' export default { components: { ValidationObserver, ValidationProvider }, data() { return { username: '', password: '', errors: {} } }, validations() { return { username: { required }, password: { required, min: min(6) } } }, methods: { async submitForm() { try { await this.$refs.observer.validate() // 表单验证通过,可以提交表单了 console.log('表单验证通过,可以提交表单了') } catch (err) { // 表单验证不通过,显示错误信息 console.log('表单验证不通过', err) this.errors = err.errors } } } } </script> ``` 在这个示例代码,我们使用了 VeeValidate 库来进行表单验证。我们首先导入了 `ValidationObserver` 和 `ValidationProvider` 组件,这两个组件提供了表单验证所需的基本功能。在 `data` 定义了需要验证的表单字段和错误信息。在 `validations` 定义了各个表单字段的验证规则。在 `submitForm` 方法,我们使用 `$refs.observer.validate()` 方法来进行表单验证,如果验证通过,就可以提交表单了,否则就显示错误信息。 注意,这只是一个简单的示例代码,实际上您需要根据您的具体需求来修改和扩展代码。如果您需要更详细的帮助,请告诉我。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值