验证电子邮件并将其发送到 Lumen 控制器
Validate email and send it to Lumen controller
我正在尝试使用 lumen 控制器验证电子邮件。如果电子邮件输入正确,它应该弹出 "valid" 但在当前状态下它总是 "invalid" 即使输入了正确的电子邮件。
namespace App\Http\Controllers;
use Illuminate\Http\Request;
class NewsletterController extends Controller
{
public function subscribe(Request $request)
{
$email = $request->query('email');
echo $email;
function valid_email($email) {
return !!filter_var($email, FILTER_VALIDATE_EMAIL);
}
if( valid_email($email) ) {
return response()->json(["valid"]);
} else {
return response()->json(["invalid"]);
}
}
}
AJAX 通过 jQuery
调用
function msg() {
var email = document.getElementById("email").value;
console.log(email);
var email2 = $('input[type=email]').val();
console.log(email2);
event.preventDefault();
$.get("newsletter/subscribe?email + $('input[type=email]').val()", function(data, status){
console.log("data: " + data + "\nStatus: " + status);
})
.done(function() {
//console.log( "done" );
alert("DONE");
})
.fail(function() {
console.log( "error" );
alert("Fail");
})
.always(function() {
//console.log( "finished" );
alert("hz");
});
};
表格
<form class="join-newsletter">
<input id="email" name="email" type="email" placeholder="Enter your email address" class="email-address">
<input onclick="msg()" type="submit" value="Subscribe" class="submit-email button">
</form>
更新后的代码:仍然显示数据:无效。
我想您的 ajax 请求可以更改为。
$.get("/newsletter/subscribe?email="+ $('#email').val()
可能的问题是您没有将 email
值正确发送到您的控制器。
我正在尝试使用 lumen 控制器验证电子邮件。如果电子邮件输入正确,它应该弹出 "valid" 但在当前状态下它总是 "invalid" 即使输入了正确的电子邮件。
namespace App\Http\Controllers;
use Illuminate\Http\Request;
class NewsletterController extends Controller
{
public function subscribe(Request $request)
{
$email = $request->query('email');
echo $email;
function valid_email($email) {
return !!filter_var($email, FILTER_VALIDATE_EMAIL);
}
if( valid_email($email) ) {
return response()->json(["valid"]);
} else {
return response()->json(["invalid"]);
}
}
}
AJAX 通过 jQuery
调用 function msg() {
var email = document.getElementById("email").value;
console.log(email);
var email2 = $('input[type=email]').val();
console.log(email2);
event.preventDefault();
$.get("newsletter/subscribe?email + $('input[type=email]').val()", function(data, status){
console.log("data: " + data + "\nStatus: " + status);
})
.done(function() {
//console.log( "done" );
alert("DONE");
})
.fail(function() {
console.log( "error" );
alert("Fail");
})
.always(function() {
//console.log( "finished" );
alert("hz");
});
};
表格
<form class="join-newsletter">
<input id="email" name="email" type="email" placeholder="Enter your email address" class="email-address">
<input onclick="msg()" type="submit" value="Subscribe" class="submit-email button">
</form>
更新后的代码:仍然显示数据:无效。
我想您的 ajax 请求可以更改为。
$.get("/newsletter/subscribe?email="+ $('#email').val()
可能的问题是您没有将 email
值正确发送到您的控制器。