php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2009

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 17.11.2009, 14:56  
Erfahrener Benutzer
 
Registriert seit: 25.09.2009
Beiträge: 2.044
PHP-Kenntnisse:
Fortgeschritten
BlackScorp wird schon bald berühmt werdenBlackScorp wird schon bald berühmt werden
Standard

vlllt so:JScript Blog : JScript Debugger in Internet Explorer 8
__________________
Mein kleines Projekt
-Cruel Online-
5 von 3 Leuten können kein Bruchrechnen
BlackScorp ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 17.11.2009, 15:23  
Erfahrener Benutzer
 
Registriert seit: 08.08.2009
Beiträge: 195
PHP-Kenntnisse:
Fortgeschritten
da.eXecutoR befindet sich auf einem aufstrebenden Ast
Standard

Tut mir leid aber ich bin wirklich kein XML / JS Spezialist. Ich kann damit einfach nichts anfangen.

Ich habe jetzt auf jeden Fall die Datei super_calendar.php zweimal aufgerufen.

1. Die DB Informationen im File selber ( ergo es funktioniert ohne Fehler )
2. Die DB Informationen extern ( Fehler mit Zeile 20 erscheint )

Ich habe die beiden XML Ausgaben je in ein Word Dokument kopiert und sie vergleichen lassen. Die Ausgabe ist in beiden Fällen absolut identisch! ( Auch noch selber verglichen )

Also was hat dies dann mit meinem .js File zu tun?

Ich glaub ich sehe einfach den Wald vor lauter Bäumen nicht.

Gruss

eXe
da.eXecutoR ist offline  
Alt 17.11.2009, 15:38  
Erfahrener Benutzer
 
Registriert seit: 08.08.2009
Beiträge: 195
PHP-Kenntnisse:
Fortgeschritten
da.eXecutoR befindet sich auf einem aufstrebenden Ast
Standard

Licht im Dunkeln!

Das wird mir vermutlich keiner glauben aber der Fehler wird hier generiert:

PHP-Code:
$result mysql_query("SELECT DATE_FORMAT(`date`,'%Y-%m-%e') FROM `modul_kalender_events` WHERE MONTHNAME(`date`)='$name' AND DAYOFMONTH(`date`)=$cur AND YEAR(`date`)=$year2");
            if(
mysql_num_rows($result) > 0) {
                
$row mysql_fetch_row($result);
                
$xml.="<div class='calevent'>Event</div>";            
            } 
Bei dem Query welches aber erst auf Zeile 110 erscheint kommt der Fehler:

Access denied for user ODBC@localhost...

Warum nimmt er hier auf einmal den User ODBC? Ist an dem SQL Statement irgendwas ungewöhnlich oder falsch? ( Ich bin nur auf den Fehler gekommen als ich die header Informationen am Anfang entfernt habe )

Wenn ich diese Zeile auskommentiere dann erscheint mir der Kalender auch mit extern definierten User Angaben.

Gruss

eXe
da.eXecutoR ist offline  
Alt 17.11.2009, 15:45  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 4.651
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

Du übergibst die Datenbankverbindung nicht im mysql_query. Damit wird es je nach Konfiguration etwas Glückssache ob das Script eine zuvor angelegte Datenbankverbindung findet oder nicht. Eventuell existiert zu dem Zeitpunkt, wo du den mysql_query aufrufst, noch gar keine Verbindung zur Datenbank.
In solchen Fällen versucht der MySQL-Treiber eine Standardverbindung anzulegen, was eigentlich so gut wie immer schief geht. Du solltest nun nicht versuchen, die Konfiguration so anzupassen, dass die Standardverbindung erfolgreich ist, denn das wird spätestens auf gemietetem Webspace sicherlich nicht mehr funktionieren. Du solltest stattdessen schauen, was du da falsch machst.
__________________
Entwickler aus Leidenschaft und ein Zahnrad in einem der größten Java-Projekte der Welt.
mepeisen ist offline  
Alt 17.11.2009, 16:00  
Erfahrener Benutzer
 
Registriert seit: 08.08.2009
Beiträge: 195
PHP-Kenntnisse:
Fortgeschritten
da.eXecutoR befindet sich auf einem aufstrebenden Ast
Standard

Aber was macht es für einen Sinn dass auf Zeile 12:

PHP-Code:
if($_GET['event'] != '') {
    
$fields explode("-",$_GET['event']);
    
$result mysql_query("SELECT *,DATE_FORMAT(`date`,'%b %e, %Y at %l:%i%p') as thedate,DATE_FORMAT(`date`,'%c') as themonth,DATE_FORMAT(`date`,'%Y') as theyear FROM `modul_kalender_events` WHERE YEAR(`date`) = ".$fields[0]." AND MONTH(`date`) = ".$fields[1]." AND DAYOFMONTH(`date`) = ".$fields[2]." ORDER BY `num` ASC"); 
Dieses SQL Query funktioniert und dann auf Zeile 110 die DB Verbindung weg ist?. Vielen Dank für deine Antwort. Du meinst also ich müsste das config.inc.php umschreiben und die DB anders anbinden?

PHP-Code:
// MySQL Datenbank Informationen
define('MYSQL_HOST',     'localhost');    
define('MYSQL_USER',     'root');    
define('MYSQL_PASS',     '');    
define('MYSQL_DATABASE''test');

// Verbindung aufbauen
@mysql_connect(MYSQL_HOSTMYSQL_USERMYSQL_PASS) OR
        die(
"Keine Verbindung zur Datenbank. Fehlermeldung:".mysql_error());    
mysql_select_db(MYSQL_DATABASE) OR
        die(
"Konnte Datenbank nicht benutzen, Fehlermeldung: ".mysql_error()); 
Was gibt es denn hier für bessere Lösungen?

MFG

eXe
da.eXecutoR ist offline  
Alt 17.11.2009, 16:18  
Erfahrener Benutzer
 
Benutzerbild von Dark Guardian
 
Registriert seit: 10.10.2009
Beiträge: 2.201
PHP-Kenntnisse:
Fortgeschritten
Dark Guardian ist ein sehr geschätzer MenschDark Guardian ist ein sehr geschätzer MenschDark Guardian ist ein sehr geschätzer MenschDark Guardian ist ein sehr geschätzer Mensch
Standard

mysql_connect() gibt eine Verbindungkennung zurück.

$con = mysql_connect....

mysql_query() kann als zwieten Parameter neben dem Query noch eine Verbindungskennung kriegen.

mysql_query("DER QUERY", $con); <--- stellt sicher das immer $con genutzt wird. Wenn $con aber keine gültige Verbindung mehr sit gibt es einen Fehler.
Dark Guardian ist offline  
Alt 17.11.2009, 23:08  
Erfahrener Benutzer
 
Registriert seit: 08.08.2009
Beiträge: 195
PHP-Kenntnisse:
Fortgeschritten
da.eXecutoR befindet sich auf einem aufstrebenden Ast
Standard

Danke Guardian für deine Antwort. Ich hab das mal versucht, bringt aber keinen Unterschied.

Und nochmals, wieso genau funktioniert das Query auf der Zeile 14 und das Query welches dann später verarbeitet wird auf Zeile 115 nicht mehr?

Ich würde gerne den Zusammenhang verstehen damit ich hier was lernen kann. Ich blick aber immernoch nicht durch wo genau das Problem nun liegen soll

Also hier nochmals. Diese Query auf Zeile 14 funktioniert:

PHP-Code:
$result mysql_query("SELECT *,DATE_FORMAT(`date`,'%b %e, %Y at %l:%i%p') as thedate,DATE_FORMAT(`date`,'%c') as themonth,DATE_FORMAT(`date`,'%Y') as theyear FROM `modul_kalender_events` WHERE YEAR(`date`) = ".$fields[0]." AND MONTH(`date`) = ".$fields[1]." AND DAYOFMONTH(`date`) = ".$fields[2]." ORDER BY `num` ASC"); 
Und das Query auf Zeile 115 wirft den Fehler Access denied for user ODBC@localhost:

PHP-Code:
$result mysql_query("SELECT DATE_FORMAT(`date`,'%Y-%m-%e') FROM `modul_kalender_events` WHERE MONTHNAME(`date`)='$name' AND DAYOFMONTH(`date`)=$cur AND YEAR(`date`)=$year2"); 
Und dies in der selben Datei: super_calendar.php

Was kapier ich hier nicht? Ich dachte ich hätte langsam eine Ahnung von PHP/MySQL - jetzt fühl ich mich mal wieder als wär ich der Dümmste *nerv*

Geändert von da.eXecutoR (17.11.2009 um 23:12 Uhr).
da.eXecutoR ist offline  
Alt 18.11.2009, 08:08  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 4.651
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

Vielleicht kam zwischendrin schon ein mysql_close? Und ich sehe in deinem neuen Auszug nicht, dass du die Verbindungskennung übergibst.
__________________
Entwickler aus Leidenschaft und ein Zahnrad in einem der größten Java-Projekte der Welt.
mepeisen ist offline  
Alt 21.11.2009, 09:53  
Erfahrener Benutzer
 
Registriert seit: 08.08.2009
Beiträge: 195
PHP-Kenntnisse:
Fortgeschritten
da.eXecutoR befindet sich auf einem aufstrebenden Ast
Standard

Salü mepeisen

Nein dazwischen kommt gar nichts. Hier mal die ganze Datei:

PHP-Code:
<?PHP 
header
("Expires: Mon, 26 Jul 1997 05:00:00 GMT" ); 
header("Last-Modified: " gmdate"D, d M Y H:i:s" ) . "GMT" ); 
header("Cache-Control: no-cache, must-revalidate" ); 
header("Pragma: no-cache" );
header("Content-Type: text/xml; charset=utf-8");

@include(
'../../include/config.inc.php') or die ("<?xml version=\"1.0\" ?><response><content><![CDATA[<span class='error'>Database connection failed.</span>]]></content></response>");

$xml '<?xml version="1.0" ?><response><content><![CDATA[';

if(
$_GET['event'] != '') {
    
$fields explode("-",$_GET['event']);
    
$result mysql_query("SELECT *,DATE_FORMAT(`date`,'%b %e, %Y at %l:%i%p') as thedate,DATE_FORMAT(`date`,'%c') as themonth,DATE_FORMAT(`date`,'%Y') as theyear FROM `modul_kalender_events` WHERE YEAR(`date`) = ".$fields[0]." AND MONTH(`date`) = ".$fields[1]." AND DAYOFMONTH(`date`) = ".$fields[2]." ORDER BY `num` ASC");
    
    
$i 0;
    while(
$row mysql_fetch_array($result)) {
        
$xml .= "<div id='event'";
        if(
$i < (mysql_num_rows($result)-1)) $xml .= " style='border-bottom:none'";
        
$xml .= "><div class='heading'><div class='title'>".$row['heading']."</div><div class='posted'>".$row['thedate']."</div>";
        if(
$i == 0$xml .= "<div class='back'><a href='javascript:navigate(".$row['themonth'].",".$row['theyear'].",\"\")'>Return to calendar</a></div>";
        
$xml .= "</div><div class='line'>".$row['body']."</div><br /></div><br />";
        
$i++;
    }
    
} else {
    
$month $_GET['month'];
    
$year $_GET['year'];
        
    if(
$month == '' && $year == '') { 
        
$time time();
        
$month date('n',$time);
        
$year date('Y',$time);
    }
    
    
$date getdate(mktime(0,0,0,$month,1,$year));
    
$today getdate();
    
$hours $today['hours'];
    
$mins $today['minutes'];
    
$secs $today['seconds'];
    
    if(
strlen($hours)<2$hours="0".$hours;
    if(
strlen($mins)<2$mins="0".$mins;
    if(
strlen($secs)<2$secs="0".$secs;
    
    
$days=date("t",mktime(0,0,0,$month,1,$year));
    
$start $date['wday']+1;
    
$name $date['month'];
    
$year2 $date['year'];
    
$offset $days $start 1;
     
    if(
$month==12) { 
        
$next=1
        
$nexty=$year 1
    } else { 
        
$next=$month 1
        
$nexty=$year
    }
    
    if(
$month==1) { 
        
$prev=12
        
$prevy=$year 1
    } else { 
        
$prev=$month 1
        
$prevy=$year
    }
    
    if(
$offset <= 28$weeks=28
    elseif(
$offset 35$weeks 42
    else 
$weeks 35
    
    
$xml .= "<table class='cal' cellpadding='0' cellspacing='1'>
            <tr>
                <td colspan='7' class='calhead'>
                    <table>
                    <tr>
                        <td>
                            <a href='javascript:navigate($prev,$prevy,\"\")' style='border:none'><img src='../../module/kalender/images/calLeft.gif' alt='prev' /></a> <a href='javascript:navigate(\"\",\"\",\"\")' style='border:none'><img src='../../module/kalender/images/calCenter.gif' alt='current' /></a> <a href='javascript:navigate($next,$nexty,\"\")' style='border:none'><img src='../../module/kalender/images/calRight.gif' alt='next' /></a> <a href='javascript:void(0)' onClick='showJump(this)' style='border:none'><img src='../../module/kalender/images/calDown.gif' alt='jump' /></a> 
                        </td>
                        <td align='right'>
                            $name $year2
                        </td>
                    </tr>
                    </table>
                </td>
            </tr>
            <tr class='dayhead'>
                <td>Son</td>
                <td>Mon</td>
                <td>Die</td>
                <td>Mit</td>
                <td>Don</td>
                <td>Fre</td>
                <td>Sam</td>
            </tr>"
;
    
    
$col=1;
    
$cur=1;
    
$next=0;
    
    for(
$i=1;$i<=$weeks;$i++) { 
        if(
$next==3$next=0;
        if(
$col==1$xml.="\n<tr class='dayrow'>"
          
        
$xml.="\t<td valign='top' onMouseOver=\"this.className='dayover'\" onMouseOut=\"this.className='dayout'\">";
    
        if(
$i <= ($days+($start-1)) && $i >= $start) {
            
$xml.="<div class='day'><b";
    
            if((
$cur==$today[mday]) && ($name==$today[month]) && ($year2==$today[year])) $xml.=" style='color:#C00'";
    
            
$xml.=">$cur</b></div>";
            
$result mysql_query("SELECT DATE_FORMAT(`date`,'%Y-%m-%e') FROM `modul_kalender_events` WHERE MONTHNAME(`date`)='$name' AND DAYOFMONTH(`date`)=$cur AND YEAR(`date`)=$year2",$dbcon);
            if(
mysql_num_rows($result) > 0) {
                
$row mysql_fetch_row($result);
                
$xml.="<div class='calevent'>Event</div>";            
            }
            
            
$xml.="\n\t</td>\n";
    
            
$cur++; 
            
$col++; 
            
        } else { 
            
$xml.="&nbsp;\n\t</td>\n"
            
$col++; 
        }  
            
        if(
$col==8) { 
            
$xml.="\n</tr>\n"
            
$col=1
        }
    }
    
    
$xml.="</table>";
      
}
    
$xml .= "]]></content>";

$xml .= "<termine><![CDATA[";
$xml .= "Termine im $name 2009";
$xml .= "<ul>";
/*
$result = mysql_query("SELECT * FROM `modul_kalender_events` WHERE MONTHNAME(`date`)='$name' AND YEAR(`date`)=$year2");
while($row = mysql_fetch_assoc($result)){
        $noevents = 0;
        $xml.= "<li>".$row['heading']."</li>";
}
if(!isset($noevents)){
    $xml .= "<li>Keine Termine in diesem Monat.</li>";
}
*/
$xml .="</ul>]]></termine>";
$xml .= "</response>";
echo 
$xml;
?>
Da kommt weder ein mysql_close nocht sonst irgendwas das mit SQL zu tun hätte. Im config file hab ich die Verbindung wie folgt definiert:

PHP-Code:
// MySQL Datenbank Informationen
define('MYSQL_HOST',     'localhost');    
define('MYSQL_USER',     'root');    
define('MYSQL_PASS',     '');    
define('MYSQL_DATABASE''test');

// Verbindung aufbauen
@$dbcon mysql_connect(MYSQL_HOSTMYSQL_USERMYSQL_PASS) OR
        die(
"Keine Verbindung zur Datenbank. Fehlermeldung:".mysql_error());    
mysql_select_db(MYSQL_DATABASE) OR
        die(
"Konnte Datenbank nicht benutzen, Fehlermeldung: ".mysql_error()); 
Und die $dbcon dann beim Problem Query auch übergeben. Das bringt aber eigentlich nur eine Meldung mehr:

HTML-Code:
Warning: mysql_connect() [function.mysql-connect]: Access denied for user 'ODBC'@'localhost' (using password: NO) in C:\xampp\htdocs\module\kalender\super_calendar.php on line 109

Warning: mysql_query() expects parameter 2 to be resource, null given in C:\xampp\htdocs\module\kalender\super_calendar.php on line 110
Das wissen wir ja bereits, dass er da keine Abfrage machen kann. Bitte ich dreh bald durch wegen dem kleinen *** Problem

Gruss
da.eXecutoR ist offline  
Alt 21.11.2009, 10:10  
Erfahrener Benutzer
 
Registriert seit: 21.12.2004
Beiträge: 4.651
PHP-Kenntnisse:
Fortgeschritten
mepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblickmepeisen ist ein Lichtblick
mepeisen eine Nachricht über ICQ schicken mepeisen eine Nachricht über Skype™ schicken
Standard

So. Bei mir ist die query nicht in Zeile 109/110, sondern in Zeile 113. Ansonsten solltest du das @ mal nicht vor $dbcon machen in deiner config.inc.

Solange du hier Scripte postest, die nicht zur Fehlermeldung passen bzw. umgekehrt, kann ich dir auch wirklich nicht weiterhelfen.
__________________
Entwickler aus Leidenschaft und ein Zahnrad in einem der größten Java-Projekte der Welt.
mepeisen ist offline  
 


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Einfache Abfrage aus mySQL Datenbank Problem ThomasM PHP Tipps 2009 7 05.06.2009 21:06
[Erledigt] datenbank abfrage mit group by mit php xstefxanx PHP Tipps 2009 2 27.04.2009 23:39
[Erledigt] Daten von Datenbank NACH der Abfrage sortieren Supeede PHP Tipps 2009 21 10.04.2009 00:33
datenbank abfrage mit php xstefxanx PHP Tipps 2009 11 04.04.2009 18:33
Zufallsbild -> Abfrage MySQL Datenbank nic_ Datenbanken 4 24.11.2008 12:43
innerHTML funktioniert nicht bei AJAX request Plague HTML, Usability und Barrierefreiheit 1 21.12.2006 14:30
Abfrage mit NOT LIKE funktioniert nicht wirklich PsychoEagle Datenbanken 6 26.09.2006 11:45
DB Abfrage nach email funktioniert nicht tinchen Datenbanken 3 15.05.2006 13:20
datenbank Abfrage in Var schreiben web2 PHP Tipps 2005-2 3 22.07.2005 12:59
Verbindung zur Datenbank funktioniert nicht picco PHP Tipps 2005 5 30.05.2005 17:15
[Erledigt] MYSQL Abfrage (mit Optimierter Datenbank) -&gt; PhP Datenbanken 2 02.03.2005 18:50
Abfrage funktioniert unter MySQL aber nicht unter MS SQL Schiedsrichter Datenbanken 2 27.01.2005 15:43
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
Newbie-Frage: Abfrage funktioniert nicht Datenbanken 3 13.08.2004 12:28
[Erledigt] Abfrage funktioniert nicht! Datenbanken 6 29.07.2004 14:59

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
mysql_query() [function.mysql-query]: access denied for user \'odbc\'@\'localhost\' (using password: no) in d:\\xampp\\htdocs\\terminanzeige.php on line was tun?, warning: mysql_fetch_assoc() expects parameter 1 to be resource, null given, ajax abfrage access

Alle Zeitangaben in WEZ +1. Es ist jetzt 23:05 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum