使用ajax请求,模态框调用并更改密码
前端页面
<a href="javascript:void(0);" onclick="changPassword()">
<i class="ace-icon fa fa-cog"></i>
修改密码
</a>
<script type="text/javascript">
//打开模态框
function changPassword(){
$("#navbar_edit").modal({
backdrop :'static'
});
}
</script>
<#include "/include/navbar_edit.html">
<!-- 模态框(Modal) -->
<div class="modal fade" id="navbar_edit" tabindex="-1" role="dialog"
aria-labelledby="roleEditLabel" aria-hidden="true">
<div class="modal-dialog" style="width:500px;">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">×</button>
<h4 class="modal-title" id="roleEditLabel">修改密码</h4>
</div>
<div class="modal-body">
<div style="width:90%;">
<form class="form-horizontal" id="navbar_pwd_reset">
<div class="form-group">
<label class="col-sm-4 control-label" for="old_password">旧密码:</label>
<div class="col-sm-8" style="padding:0">
<input class="col-sm-12" type="password" id="old_password"
name="old_password" placeholder="请输入旧密码 " />
</div>
</div>
<div class="form-group">
<label class="col-sm-4 control-label" for="new_password">新密码:</label>
<div class="col-sm-8" style="padding:0">
<input class="col-sm-12" type="password" id="new_password"
name="new_password" placeholder="请输入新密码 " />
</div>
</div>
<div class="form-group">
<label class="col-sm-4 control-label" for="confirm_password">确认新密码:</label>
<div class="col-sm-8" style="padding:0">
<input class="col-sm-12" type="password" id="confirm_password"
name="confirm_password" placeholder="确认新密码 " />
</div>
</div>
</form>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-xs btn-default"
data-dismiss="modal" id="navbar_close_btn">
<i class="ace-icon fa fa-times bigger-110"></i> <span
class="bigger-110 no-text-shadow">关闭</span>
</button>
<button type="button" class="btn btn-xs btn-primary" id="navbar_save_btn">
<i class="ace-icon fa fa-floppy-o bigger-110"></i> <span
class="bigger-110 no-text-shadow">保存</span>
</button>
</div>
</div>
<!-- /.modal-content -->
</div>
<!-- /.modal -->
</div>
<script type="text/javascript">
$("#navbar_edit").on("show.bs.modal", function() {
$("#navbar_edit #navbar_pwd_reset").formClear();
});
$("#navbar_edit").on("hidden.bs.modal", function() {
$(this).removeData("bs.modal");
});
$(document).on("click", "#navbar_save_btn", function(e) {
var old_psd = $("#navbar_pwd_reset #old_password").val();
var new_psd = $("#navbar_pwd_reset #new_password").val();
var con_psd = $("#navbar_pwd_reset #confirm_password").val();
//alert(old_psd);
//alert(new_psd);
//alert(con_psd);
if (old_psd == "" || new_psd == "" || con_psd == "") {
bootbox.alert("相关字段不为空,请输入!");
return false;
};
if (old_psd == new_psd) {
bootbox.alert("旧密码和新密码相同,请重新输入!");
return false;
};
if (new_psd != con_psd) {
bootbox.alert("两次输入新密码不相同,请重新输入!");
return false;
};
var params = $("#navbar_pwd_reset").serialize();
//alert(params);
$.ajax({
cache : true,
type : "POST",
url : "${ctx!}/modifyPassword",
data : params,
async : false,
error : function(request) {
bootbox.alert("服务器连接错误,请稍后再试");
},
success : function(data) {
if (SQ.isOK(data)) {
bootbox.alert("重置成功", function() {
$("#navbar_close_btn").click();
});
} else {
bootbox.alert("重置失败:" + SQ.getMessage(data));
}
},
});
});
</script>
后端页面
public void modifyPassword() {
BasMember sysUser = this.getLoginUser();
if (sysUser == null || sysUser.getInt(BasMember.IsDelete).equals(1)) {
render(new JsonRender(new AjaxResult(Constants.RESPONSE_STATUS_FAIL, "会话已过期,请重新登录!")).forIE());
return;
}
// 旧秘密
String password = getPara("old_password");
password = CommonUtil.getEncryptedPwd(password);
if (!password.equals(sysUser.get(BasMember.Password))) {
render(new JsonRender(new AjaxResult(Constants.RESPONSE_STATUS_FAIL, "旧密码不正确!")).forIE());
return;
}
// 新密码
password = getPara("new_password");
password = CommonUtil.getEncryptedPwd(password);
// 赋值
sysUser.set(BasMember.Password, password);
sysUser.set(BasMember.ModifyBy, this.getLoginId());
sysUser.set(BasMember.ModifyTime, StringUtil.getNowTime());
if (!sysUser.update()) {
render(new JsonRender(new AjaxResult(Constants.RESPONSE_STATUS_FAIL, "修改时出现异常")).forIE());
}
render(new JsonRender(new AjaxResult(Constants.RESPONSE_STATUS_OK, "修改成功!")).forIE());
}
使用ajax请求,模态框调用并更改密码的更多相关文章
- Ajax技术使用之ajax与模态框结合的妙用
Ajax技术使用之ajax与模态框结合的妙用 要求: 使用ajax的方式提交数据:https://www.cnblogs.com/-wenli/p/10470063.html 使用模态框完成增加数据, ...
- ajax+json模态框中分页(spring+struts+mybatis+easyui分页插件)
0.业务需求: 点击每个数字的时候可以显示每个对应的详细记录.也就是得点击11的时候拿着开采部与C级去查询.
- ajax请求,html调用js
1:html中调用js中的函数,js使用ajax请求向后台请求,返回数据. <!DOCTYPE html> <html lang="en"> <hea ...
- ajax 请求发出了,数据更改了,但是没进入success 函数 把success 换成 complete
$(function(){ $(document).on('tap','.w-location-group .mui-table-view-cell',function(){ var bool = $ ...
- jQuery delegate方法实现Ajax请求绑定事件不丢失
给元素绑定click事件后 ,遇到一个问题:当执行一些ajax请求,再次调用此页面,里面的这个click事件就失效了 比如说:我的分页是一个ajax请求 但我点下一页时 后生成的元素a就没有了clic ...
- Ajax请求过程中显示“进度”的简单实现
Ajax在Web应用中使用得越来越频繁.在进行Ajax调用过程中一般都具有这样的做法:显示一个GIF图片动画表明后台正在工作,同时阻止用户操作本页面(比如Ajax请求通过某个按钮触发,用户不能频繁点击 ...
- Ajax发送请求等待时弹出模态框等待提示
主要的代码分为两块,一个是CSS定义模态框,另一个是在Ajax中弹出模态框. 查看菜鸟教程中的模态框教程demo,http://www.runoob.com/try/try.php?filename= ...
- bootstrap模态框动态赋值, ajax异步请求数据后给id为queryInfo的模态框赋值并弹出模态框(JS)
/查询单个 function query(id) { $.ajax({ url : "/small/productServlet", async : true, type : &q ...
- bootstrap通过ajax请求JSON数据后填充到模态框
1. JSP页面中准备模态框 <!-- 详细信息模态框(Modal) --> <div> <div class="modal fade" id=& ...
随机推荐
- oracle 内联同时删除多表
在 MySql 中,内联同时删除多表可以使用这样的语法: DELETE t1,t2 FROM table1 AS t1 INNER JOIN table2 t2 ... INNER JOIN tabl ...
- BundleConfig 的使用 通配符
//是不是说一定要是前缀文件呢 OK 通过 通配符只能使用在前缀或后缀 //捆绑名称 bundles.Add(new StyleBundle("~/caijinhao/caijinhao&q ...
- Heterogeneous System Architecture
https://en.wikipedia.org/wiki/Heterogeneous_System_Architecture Steps performed when offloading calc ...
- Memory Allocation in the MySQL Server
https://dev.mysql.com/doc/internals/en/memory-allocation-mysql-server.html MySQL Internals Manual / ...
- android硬件调试之无法识别android设备解决办法
DDMS 中无法识别华为荣耀六手机, 用豌豆荚开始显示无法连接, 用豌豆荚安装完驱动后,就可以连接了 http://www.zhihu.com/question/30588024 http://w ...
- awk统计nginx日志访问前一百的ip
访问ip awk '{print $1}' access.log| sort | uniq -c | sort -n -k 1 -r | head -n 100 访问地址 awk '{print $ ...
- TCP的三次握手四次挥手
一.三次握手 1.wireshark 抓包 2.TCP报文手部 注意标志位: 1).同步 SYN = 1 表示这是一个连接请求或连接接受报文. 2).只有当 ACK = 1 时确认号字段才有效.当 A ...
- GetLogicalProcessorInformation(XP3才支持)和GetLogicalProcessorInformationEx(WIN7才支持)
https://msdn.microsoft.com/en-us/library/windows/desktop/ms683194(v=vs.85).aspx 例子执行结果如下: https://ms ...
- 设计模式:工厂方法模式(Factory Method)
定义:定义一个用于创建对象的接口,让子类决定实例化哪一个类. 工厂方法使一个类的实例化延迟到其子类. 结构图: 示例: HTML代码: <html xmlns="http://www. ...
- android 2.2 videoView 诡异bug
最近遇到一个问题,在2.2系统上,公司项目中使用VideoView,第一次播放正常,第二次播放黑屏. 由于公司项目使用lua + android 原生,所以试了下原生的android 的VideoVi ...