javascript - jquery的$.ajax() 提交到php的post的数据不对
<code>$('#form1').submit(function(){ $.ajax({ url:'login.php?act=login', data:$('#form1').serialize(), type:'POST', dataType:'text', beforeSend:function(){ } if($('#password').val()==''){ alert('密碼不能為空'); return false; }else{ var p = $('#password').val(); alert(p); $('#password').val(hex_md5(p)); alert($('#password').val()); } }, success:function(msg){ ...... }; } }); return false; });</code>
是这样,我的目的是,在提交之前,对密码进行md5计算,达到加密传输密码的作用。
可是实际的效果是,当我password值为123的时候,alert($('#password').val()) 打印出来是对的202cb962ac59075b964b07152d234b70 ,可是post到后台php之后,还是123 。
我感觉像是data:$('#form1').serialize()已经在beforeSend之前取值了,所以传到后面还是旧值。
经过测试,如果我把md5加密那一块拿出来,放到$.ajax()之前进行操作,是没有问题的。只是这样用起来不方便,有没办法让serialize()在beforSend之后执行呢?
补充:
在使用后贴@lisfan 提供的方法后,提交正常了
<code>$('#form1').submit(function(){ $.ajax({ url:'login.php?act=login', **data:null,** type:'POST', dataType:'text', beforeSend:function(){ } if($('#password').val()==''){ alert('密碼不能為空'); return false; }else{ var p = $('#password').val(); alert(p); $('#password').val(hex_md5(p)); alert($('#password').val()); **this.data=$('#form1').serialize();** } }, success:function(msg){ ...... }; } }); return false; });</code>
但是后台php的$_REQUEST和$_POST都收不到数据。如下图:
下面是firebug看到的post数据,上面是php分别print $_REQUEST、$_POST和php://input的数据, 可以看到在file_get_contents("php://input")中是看到了原始数据的,但是为啥没有被封装到$_POST中去呢?
.
回复内容:
<code>$('#form1').submit(function(){ $.ajax({ url:'login.php?act=login', data:$('#form1').serialize(), type:'POST', dataType:'text', beforeSend:function(){ } if($('#password').val()==''){ alert('密碼不能為空'); return false; }else{ var p = $('#password').val(); alert(p); $('#password').val(hex_md5(p)); alert($('#password').val()); } }, success:function(msg){ ...... }; } }); return false; });</code>
是这样,我的目的是,在提交之前,对密码进行md5计算,达到加密传输密码的作用。
可是实际的效果是,当我password值为123的时候,alert($('#password').val()) 打印出来是对的202cb962ac59075b964b07152d234b70 ,可是post到后台php之后,还是123 。
我感觉像是data:$('#form1').serialize()已经在beforeSend之前取值了,所以传到后面还是旧值。
经过测试,如果我把md5加密那一块拿出来,放到$.ajax()之前进行操作,是没有问题的。只是这样用起来不方便,有没办法让serialize()在beforSend之后执行呢?
补充:
在使用后贴@lisfan 提供的方法后,提交正常了
<code>$('#form1').submit(function(){ $.ajax({ url:'login.php?act=login', **data:null,** type:'POST', dataType:'text', beforeSend:function(){ } if($('#password').val()==''){ alert('密碼不能為空'); return false; }else{ var p = $('#password').val(); alert(p); $('#password').val(hex_md5(p)); alert($('#password').val()); **this.data=$('#form1').serialize();** } }, success:function(msg){ ...... }; } }); return false; });</code>
但是后台php的$_REQUEST和$_POST都收不到数据。如下图:
下面是firebug看到的post数据,上面是php分别print $_REQUEST、$_POST和php://input的数据, 可以看到在file_get_contents("php://input")中是看到了原始数据的,但是为啥没有被封装到$_POST中去呢?
.
在不修改题主原有结构的前提下,试试修改如下,看带 *
星号的位置
<code>$('#form1').submit(function(){ $.ajax({ url:'login.php?act=login', **data:null,** type:'POST', dataType:'text', beforeSend:function(){ } if($('#password').val()==''){ alert('密碼不能為空'); return false; }else{ var p = $('#password').val(); alert(p); $('#password').val(hex_md5(p)); alert($('#password').val()); **this.data=$('#form1').serialize();** } }, success:function(msg){ ...... }; } }); return false; });</code>
你可以处理完密码再发送$.AJAX()请求 就是先处理 beforeSend 函数的内容,再发送请求,这样 $('#form1').serialize() 的数据就是正确的
这说明 $('#form1').serialize() 这一函数在 beforeSend 之前调用了。
建议 当你输入完密码之后的验证函数中 如果验证通过 则直接将其加密后赋值到表单某个隐藏域中
$('#form1').submit(function() { if ($('#password').val() == '') { alert('密碼不能為空'); return false; } var p = $('#password').val(); alert(p); $('#password').val(hex_md5(p)); alert($('#password').val()); $.post('login.php?act=login', $(this).serialize(), function(msg) { console.log(msg); } ); return false; });
把判断拿出来,ajax放到密码加密后面。
这是因为,在执行$.ajax时,js引擎会创建一个字面量对象,创建对象时,data的值被存为了当时的$('#form1').serialize()返回值,也就是123。
可以看下面的例子:
var c=1;
var a={
<code>b:c, d : function(){ c=2 }</code>
};
console.log(a.b);// 1
a.d();//c=2
console.log(a.b);// 1
这就可以解释上面的问题了。
可能解决方式只有将md5加密移动到创建字面量对象之前。
首先,既然要md5,为什么还要赋值到password的input上,没有安全隐患么?其次,beforeSend函数是在发送请求前调用,不是在Ajax方法前调用,你在调用ajax方法时已经将form表单数据取出,设置到函数的参数中,那后面才修改的表单值怎么可能会自动更新到ajax的data中,根本是异想天开了。把密码md5的操作提到Ajax方法调用之前就对了
在ajax方法前把密码加密后的字符串做好

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다
