- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有下面给出的星级评级脚本。它工作正常,但是当我想在处理文件中使用 $_GET 变量时,它没有使用它。
我还想在这个脚本中使用注释,但我不能在 tuto-star-rating.php
中使用 $_POST 或 $_GET| .
我可以得到 $_GET['sid']
在index.php
但我无法在 tuto-start-rating.php
中获取 sid .这tuto-start-rating.php
通过JS调用。
在 index.php 中,url 是 index.php?sid=1
在tuto-star-rating.php
我想使用 $_GET 保存餐厅 ID 但无法这样做。我尝试如下,但它不接受它只接受直接输入的数字,正如您在下面的文件代码中看到的那样:
$getRest = mysql_real_escape_string($_GET['sid']);
$query = $bdd->execute('INSERT INTO rest_rating (sr_id, media, rate, ip, user)
VALUES ('.$getRest.', '.$mediaId.', "'.$rate.'", "'.$ipaddress.'", "'.$user.'")'); // We insert the new rate
我需要帮助来使用不同的形式或通过集成来将评论系统与此代码集成。
index.php
<?php
include('comment/dbClass.php');
$bdd = new db();
?>
<style>
.no_star { display: inline-block; background: url("comment/star.png") no-repeat; width: 16px; height: 16px }
.star { display: inline-block; background: url("comment/star.png") no-repeat; background-position: 0 -16px; width: 16px; height: 16px }
.star_hover { display: inline-block; background: url("comment/star.png") no-repeat; background-position: 0 -32px; width: 16px; height: 16px }
.star_selected { display: inline-block; background: url("comment/star.png") no-repeat; background-position: 0 -48px; width: 16px; height: 16px }
</style>
<?php
function starBar($numStar, $mediaId, $starWidth) { // function with arguments: number of stars, media ID, width of the star image
global $bdd;
$getRest = mysql_real_escape_string($_GET['sid']);
$cookie_name = 'tcRatingSystem'.$mediaId; // Set up the cookie name
// We get the rate average and number of rate from the database
$query = $bdd->getOne('SELECT round(avg(rate), 2) AS average, count(rate) AS nbrRate, sr_id AS sr_id FROM rest_rating WHERE media='.$mediaId.' and sr_id = "'.$getRest.'"');
$avgCeil = round($query['average'], 0); // round above or below to show how many selected stars we display
$getJSON = array('numStar' => $numStar, 'mediaId' => $mediaId); // We create a JSON with the number of stars and the media ID
$getJSON = json_encode($getJSON);
// We create the DIV block with selected stars and unselected stars depending of the rate
$starBar = '<div id="'.$mediaId.'">';
$starBar .= '<div class="';
if( !isset($_COOKIE[$cookie_name]) ) $starBar .= 'star_bar';
$starBar .= '" rel='.$getJSON.' style="width:'.($numStar*$starWidth).'px">';
for ($i=1; $i<=$numStar; $i++) {
$starBar .= '<div class="';
if ($i <= $avgCeil) $starBar .= 'star_selected'; else $starBar .= 'star';
$starBar .= '"></div>';
}
$starBar .= '</div>';
$starBar .= '<div class="resultMedia'.$mediaId.'" style="font-size: small; color: grey">'; // We show the rate score and number of rates
if ($query['nbrRate'] == 0) $starBar .= 'Not rated yet';
else $starBar .= 'Rating: ' . $query['average'] . '/' . $numStar . ' (' . $query['nbrRate'] . ' votes)';
$starBar .= '</div>';
$starBar .= '<div class="box'.$mediaId.'"></div>'; // Return the text "Thank you for rating" when someone rate
$starBar .= '</div>';
return $starBar;
}
echo starBar(5, 59, 16); // We create star bar
?>
tuto-start-rating.php
<?php
session_start();
include('dbClass.php');
$bdd = new db();
//$getRest = mysql_real_escape_string($_GET['sid']);
$ipaddress = $_SERVER["REMOTE_ADDR"];
$user = session_id();
if($_POST) {
$mediaId = $_POST['mediaId']; // Media ID
$rate = $_POST['rate']; // Your rate
$expire = 24*3600; // 1 day
setcookie('tcRatingSystem'.$mediaId, 'voted', time() + $expire, '/'); // Place a cookie
$query = $bdd->execute('INSERT INTO rest_rating (sr_id, media, rate, ip, user)
VALUES (1, '.$mediaId.', "'.$rate.'", "'.$ipaddress.'", "'.$user.'")
'); // We insert the new rate
// We calculate the new average and new number of rate
$result = $bdd->getOne('SELECT round(avg(rate), 2) AS average, count(rate) AS nbrRate FROM rest_rating WHERE media='.$mediaId.'');
$avgCeil = round($result['average'], 0); // Round the average
// Send JSON back with the new average, the number of rate and rounded average
$dataBack = array('avg' => $result['average'], 'nbrRate' => $result['nbrRate'], 'avgCeil' => $avgCeil);
$dataBack = json_encode($dataBack);
echo $dataBack;
}
?>
tuto-star-rating.js
function rateMedia(mediaId, rate, numStar) {
$('.box' + mediaId).html('<img src="comment/loader-small.gif" alt="" />'); // Display a processing icon
var data = {mediaId: mediaId, rate: rate}; // Create JSON which will be send via Ajax
$.ajax({ // JQuery Ajax
type: 'POST',
url: 'comment/tuto-star-rating.php', // URL to the PHP file which will insert new value in the database
data: data, // We send the data string
dataType: 'json',
timeout: 3000,
success: function(data) {
$('.box' + mediaId).html('<div style="font-size: small; color: green">Thank you for rating</div>'); // Return "Thank you for rating"
// We update the rating score and number of rates
$('.resultMedia' + mediaId).html('<div style="font-size: small; color: grey">Rating: ' + data.avg + '/' + numStar + ' (' + data.nbrRate + ' votes)</div>');
// We recalculate the star bar with new selected stars and unselected stars
var ratingBar = '';
for ( var i = 1; i <= numStar; i++ ) {
ratingBar += '<div class="';
if (i <= data.avgCeil) ratingBar += 'star_selected'; else ratingBar += 'star';
ratingBar += '"></div>';
}
$('#' + mediaId + ' .star_bar').html(ratingBar).off('mouseenter');
},
error: function() {
$('#box').text('Problem');
}
});
}
$(function () {
$('.star_bar').on('mouseenter', function overBar(event) { // Mouse enter the star bar
var relData = $.parseJSON($(this).attr('rel')); // Get JSON values: number of stars and media ID
$(this).css('cursor','pointer');
// We create a new star bar OVER the previous one with transparent stars
var newStarBar = '';
for ( var i = 1; i <= relData.numStar; i++ ) {
newStarBar += '<div class="no_star" id="' + i + '" title="' + i + '/' + relData.numStar + '" onclick="rateMedia(' + relData.mediaId + ', ' + i + ', ' + relData.numStar + '); return false;"></div>';
}
$(this).css('position', 'relative').append('<div id="over' + relData.mediaId + '" style="position:absolute; top:0; left:0;">' + newStarBar + '</div>');
// When we move the mouse over the new transparent star bar they become blue
$('#over' + relData.mediaId + ' > div').mouseover(function() {
var myRate = $(this).attr('id');
for ( var i = 1; i <= relData.numStar; i++ ) {
if (i <= myRate) $('#over' + relData.mediaId + ' #' + i).attr('class', 'star_hover');
else $('#over' + relData.mediaId + ' #' + i).attr('class', 'no_star');
}
});
});
// Mouse leaves the star bar, we remove the rating bar
$('.star_bar').on('mouseleave', function overBar(event) {
var relData = $.parseJSON($(this).attr('rel'));
$('#over' + relData.mediaId).remove();
});
});
**tuto-star-rating.php**
<?php
session_start();
include('dbClass.php');
$bdd = new db();
//$getRest = mysql_real_escape_string($_GET['sid']);
$ipaddress = $_SERVER["REMOTE_ADDR"];
$user = session_id();
if($_POST) {
$mediaId = $_POST['mediaId']; // Media ID
$rate = $_POST['rate']; // Your rate
$expire = 24*3600; // 1 day
setcookie('tcRatingSystem'.$mediaId, 'voted', time() + $expire, '/'); // Place a cookie
$query = $bdd->execute('INSERT INTO rest_rating (sr_id, media, rate, ip, user)
VALUES (1, '.$mediaId.', "'.$rate.'", "'.$ipaddress.'", "'.$user.'")
'); // We insert the new rate
// We calculate the new average and new number of rate
$result = $bdd->getOne('SELECT round(avg(rate), 2) AS average, count(rate) AS nbrRate FROM rest_rating WHERE media='.$mediaId.'');
$avgCeil = round($result['average'], 0); // Round the average
// Send JSON back with the new average, the number of rate and rounded average
$dataBack = array('avg' => $result['average'], 'nbrRate' => $result['nbrRate'], 'avgCeil' => $avgCeil);
$dataBack = json_encode($dataBack);
echo $dataBack;
}
?>
dbClass.php
<?php
class db {
private $conn;
private $host;
private $user;
private $password;
private $baseName;
private $port;
private $Debug;
function __construct($params=array()) {
$this->conn = false;
$this->host = 'localhost'; //hostname
$this->user = 'root'; //username
$this->password = ''; //password
$this->baseName = 'lepetit'; //name of your database
$this->port = '3306';
$this->debug = true;
$this->connect();
}
function __destruct() {
$this->disconnect();
}
function connect() {
if (!$this->conn) {
$this->conn = mysql_connect($this->host, $this->user, $this->password);
mysql_select_db($this->baseName, $this->conn);
mysql_set_charset('utf8',$this->conn);
if (!$this->conn) {
$this->status_fatal = true;
echo 'Connection BDD failed';
die();
}
else {
$this->status_fatal = false;
}
}
return $this->conn;
}
function disconnect() {
if ($this->conn) {
@pg_close($this->conn);
}
}
function getOne($query) { // getOne function: when you need to select only 1 line in the database
$cnx = $this->conn;
if (!$cnx || $this->status_fatal) {
echo 'GetOne -> Connection BDD failed';
die();
}
$cur = @mysql_query($query, $cnx);
if ($cur == FALSE) {
$errorMessage = @pg_last_error($cnx);
$this->handleError($query, $errorMessage);
}
else {
$this->Error=FALSE;
$this->BadQuery="";
$tmp = mysql_fetch_array($cur, MYSQL_ASSOC);
$return = $tmp;
}
@mysql_free_result($cur);
return $return;
}
function getAll($query) { // getAll function: when you need to select more than 1 line in the database
$cnx = $this->conn;
if (!$cnx || $this->status_fatal) {
echo 'GetAll -> Connection BDD failed';
die();
}
mysql_query("SET NAMES 'utf8'");
$cur = mysql_query($query);
$return = array();
while($data = mysql_fetch_assoc($cur)) {
array_push($return, $data);
}
return $return;
}
function execute($query,$use_slave=false) { // execute function: to use INSERT or UPDATE
$cnx = $this->conn;
if (!$cnx||$this->status_fatal) {
return null;
}
$cur = @mysql_query($query, $cnx);
if ($cur == FALSE) {
$ErrorMessage = @mysql_last_error($cnx);
$this->handleError($query, $ErrorMessage);
}
else {
$this->Error=FALSE;
$this->BadQuery="";
$this->NumRows = mysql_affected_rows();
return;
}
@mysql_free_result($cur);
}
function handleError($query, $str_erreur) {
$this->Error = TRUE;
$this->BadQuery = $query;
if ($this->Debug) {
echo "Query : ".$query."<br>";
echo "Error : ".$str_erreur."<br>";
}
}
}
?>
最佳答案
来自 your comment ,
I can get sid in index.php but i can not get sid in tuto-start-rating.php. This tuto-start-rating.php is called through JS
由于您将 JavaScript 作为外部文件包含在内,因此您不能在 tuto-star-rating.js< 中使用/访问像 $_GET['sid']
这样的 PHP 变量/em> 文件。您需要按以下方式更改您的 index.php 和 tuto-star-rating.js 文件,
index.php
在 index.php 页面中包含 tuto-star-rating.js 文件之前,添加以下行,
<script>var sid = "<?php echo $_GET['sid']; ?>";</script>
// include your tuto-star-rating.js file
tuto-star-rating.js
您需要按以下方式更改您的 AJAX 请求,
function rateMedia(mediaId, rate, numStar) {
// your code
$.ajax({
type: 'POST',
url: 'comment/tuto-star-rating.php?sid=' + sid,
// your code
});
}
这样,您就可以使用$_GET
访问tuto-star-rating.php页面中的sid超全局,像这样:
$getRest = mysql_real_escape_string($_GET['sid']);
旁注: 不要使用 mysql_*
函数,它们从 PHP 5.5 开始被弃用,并在 PHP 7.0 中被完全删除。使用 mysqli
或 pdo
反而。 And this is why you shouldn't use mysql_*
functions .
关于javascript - php mysql 用户评分和评论系统,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39537771/
我有这个代码: System.err.print("number of terms = "); System.out.println(allTerms.size()); System.err
我有以下问题:在操作系统是 Linux 的情况下和在操作系统是 MacOs 的情况下,我必须执行不同的操作。 所以我创建了以下 Ant 脚本目标: /u
我正在调用 system("bash ../tools/bashScript\"This is an argument!\"&"),然后我正在调用 close(socketFD) 直接在 system
使用最初生成的随机元素来约束随机数组的连续元素是否有效。 例如:我想生成一组 10 个 addr、size 对来模拟典型的内存分配例程并具有如下类: class abc; rand bit[5:0
我正在创建一个必须使用system(const char*)函数来完成一些“繁重工作”的应用程序,并且我需要能够为用户提供粗略的进度百分比。例如,如果操作系统正在为您移动文件,它会为您提供一个进度条,
我即将编写一些项目经理、开发人员和业务分析师会使用的标准/指南和模板。目标是更好地理解正在开发或已经开发的解决方案。 其中一部分是提供有关记录解决方案的标准/指南。例如。记录解决/满足业务案例/用户需
在开发使用压缩磁盘索引或磁盘文件的应用程序时,其中部分索引或文件被重复访问(为了论证,让我们说一些类似于 Zipfian 分布的东西),我想知道什么时候足够/更好地依赖操作系统级缓存(例如,Debia
我们编写了一个 powershell 脚本,用于处理来自内部系统的图像并将其发送到另一个系统。现在,业务的另一部分希望加入其中,对数据进行自己的处理,并将其推送到另一个系统。打听了一下,公司周围有几个
我正在尝试朗姆酒我的应用程序,但我收到以下错误:System.Web.HttpUnhandledException:引发了“System.Web.HttpUnhandledException”类型的异
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
所以我在其他程序中没有收到此错误,但我在这个程序中收到了它。 这个程序是一个我没有收到错误的示例。 #include int main() { system("pause"); } // en
我在 c# System.URI.FormatExption 中遇到问题 为了清楚起见,我使用的是 Segseuil 的 Matlab 方法,并且它返回一个图片路径 result。我想为其他用户保存此
我正在尝试像这样设置文本框的背景色: txtCompanyName.BackColor = Drawing.Color.WhiteSmoke; 它不喜欢它,因为它要我在前面添加系统,例如: txtCo
请帮助我解决 System.StackOverflowException我想用 .aspx 将记录写入数据库我使用 4 层架构来实现这一切都正常但是当我编译页面然后它显示要插入数据的字段时,当我将数据
我使用了一些通常由系统调用的API。 因此,我将 android:sharedUserId="android.uid.system" 添加到 manifest.xml, 并使用来自 GIT 的 And
我正在尝试创建一个小型应用程序,它需要对/system 文件夹进行读/写访问(它正在尝试删除一个文件,并创建一个新文件来代替它)。我可以使用 adb 毫无问题地重新挂载该文件夹,如果我这样做,我的应用
我想从没有 su 的系统 priv-app 将/system 重新挂载为 RW。如何以编程方式执行此操作?只会用 Runtime.getruntime().exec() 执行一个 shell 命令吗
我正在尝试制作一个带有登录系统的程序我对此很陌生,但我已经连续工作 8 个小时试图解决这个问题。这是我得到的错误代码 + ServerVersion 'con.ServerVersion' threw
当我“构建并运行”Code::Blocks 中的程序时,它运行得非常好!但是当我从“/bin”文件夹手动运行它时,当它试图用 system() 调用“temp.bat”时,它会重置。这是为什么?它没有
我想使用 system/pipe 命令来执行具有特殊字符的命令。下面是示例代码。通过系统/管道执行命令后,它通过改变特殊字符来改变命令。我很惊讶地看到系统命令正在更改作为命令传递的文本。 run(ch
我是一名优秀的程序员,十分优秀!