MVC初学笔记(2):前台使用Ajax调用后台方法

在用户修改密码时,需要输入正确的原密码,由于之前密码时经过加密的,因此要在前台调用后台加密的方法进行加密之后再与数据库中的密码进行比对,使用Ajax。先记录一下加密的方法和原理:

给数据库中的密码加密其实非常简单,方法中一句话搞定:

        public string encryptPwd(string pwd)
        {            
            return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(pwd, "MD5");

        }

MD5加密是单向的,也就是说,如果你的密码是“1”,给加密之后变成“C4CA4238A0B923820DCC509A6F75849B”,但是没办法将这一串字符串给解密成“1”的。在保存密码至数据库之前,使用该方法加密再保存。在需要输入密码然后判断密码是否正确的时候,再次把输入密码加密,然后与数据库中保存的密码进行比对就可以了。

 

这里是在输入原密码,密码框失去焦点之后,立刻进行加密,然后将加密后的数据放到一个隐藏控件上,最后点击确定提交时,与数据库中的密码进行比对

   $("#OPwd").blur(
    function () {
        var pass = $('#OPwd').val();//获取输入的密码
        
        var inputPwd = "@Model.Data.Password"; //获取数据库中的密码(经过加密的)       
$.ajax({
            type: "Post",
            url: "/User/encryptPwd",//调用UserController中的encryptPwd方法
            data: { "pwd": pass },//传过去的参数(即需要加密的密码)
            success: function (getpwd) {
                //若调用成功则返回已经经过加密的密码
                var p = getpwd;
                document.getElementById("hidcp").value = p;//赋值给隐藏控件
            },
            error: function (err) {
                alert("密码加密出错");
            }
        });
    })

 

这样在本地运行是OK的,但是在发布至测试服上后,老是报404的错误。后来把ajax中的url改为 url:"@Url.Content("~/User/encryptPwd")"就好了。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值