繁体   English   中英

使用jQuery Ajax和PHP更新SQL数据库

[英]Updating SQL database using jQuery Ajax and PHP

所以我试图通过抓取被点击的链接并在数据库中找到该链接来使用ajax来更新我的sql数据库中的值。 我不确定为什么它不起作用:

$('.visit').click( function() {
var thisLink = $(this).attr('href'); 
$.post("visit.php", { link: thisLink});
});

<?php
$link = $_POST['link'];
mysql_query("UPDATE items SET visited = 1 WHERE link = $link");
include("print.php");
?>

为了防止SQL注入使用类似下面的内容(从内存中键入...双重检查)。

<?php
    $db = new PDO('connection string', 'username', 'password');

    $query = "UPDATE items SET visited=1 WHERE link=:link";

    $stmt = $db->prepare($query);
    $stmt->execute(array(':link' => $link));
?>

短发

    $('.visit').click( function() {
         var thisLink = $(this).attr('href'); 
         $.post("visit.php", { link: thisLink});
    });

    <?php
         $link = $_POST['link'];
         mysql_query("UPDATE items SET visited = '1' WHERE link = '".mysql_real_escape_string($link)."'");
         include("print.php");
    ?>

在SET和WHERE参数周围使用单引号。 此外,mysql_escape_real_string输入到数据库以进行SQL注入

 <?php 
  $link = $_POST['link']; 
  mysql_query("UPDATE items SET visited = 1 WHERE link = '$link'"); 
  include("print.php"); // what print.php does ?
 ?> 

在$ link附近加上引号

将$ link与数据库字段中的值进行比较 - 它需要与exaclly匹配

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM