ローカル環境では問題なく動いていたajax処理がレンタルサーバー上では機能しませんでした。
どのような原因が考えられるでしょうか。
処理の内容は「フォームに打ち込んだパスワードが正しい時のみボタンを押せるようにする」という物です。
jQuery
1 var textData = {pass:''}; 2 $('.unsubscribe-password').on('keyup',function(){ 3 textData['pass'] = $('.unsubscribe-password').val(); 4 console.log(textData); 5 $.ajax({ 6 type:'post', 7 url:'ajaxBtnBlock.php', 8 dataType:'json', 9 data:textData 10 }).done(function(result){ 11 console.log(result); 12 (result.msg) ? $('.form-msg').text(result.msg) : ''; 13 if(result.bool){ 14 $('.form-msg').text('') 15 $('.js-click-unsubscribe').prop('disabled',false); 16 $('.js-click-unsubscribe').toggleClass('unsubscribe-btn'); 17 console.log('btnを押せるようになりました');} 18 else{ 19 $('.js-click-unsubscribe').prop('disabled',true);} 20 }).fail(function(result,textStatus,errorThrown){ 21 console.log('通信に失敗しています'); 22 console.log(result); 23 console.log(textStatus); 24 console.log(errorThrown); 25 }) 26 })
php
1<?php 2require('function.php'); 3 4if(!empty($_POST)){ 5 try{ 6 debug('送信された値:'.print_r($_POST,true)); 7 $pass = $_POST['pass']; 8 $dbh = dbConnect(); 9 $sql = 'SELECT pass FROM users WHERE id = :id AND delete_flg = 0'; 10 $data = array(':id'=>$_SESSION['user_id']); 11 $stmt = queryPost($dbh,$sql,$data); 12 $get_pass = $stmt -> fetch(PDO::FETCH_ASSOC); 13 debug('取得パス'.print_r($get_pass,true)); 14 $result = password_verify($pass,array_shift($get_pass)); 15 if($result){ 16 debug('pass 一致'); 17 $result = array('bool'=>true); 18 echo json_encode($result); 19 }else{ 20 debug('pass 不一致'); 21 $result = array('msg'=>'passwordが違います', 22 'bool'=>false); 23 echo json_encode($result); 24 } 25 }catch(Exception $e){ 26 error_log('エラーメッセージ:'.$e->getMessage()); 27 } 28} 29?>
コンソールログには以下三つのエラーが表示されていました。
array_shift() expects parameter 1 to be array, boolean given in
parsererror
unsubscribe.php?userid=5:104 SyntaxError: Unexpected token < in JSON at position 0
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。