eigenes Modul läuft auf Windows aber nicht auf Linux
Eingetragen von AndyLicht (260)
am 07.10.2013 - 17:44 Uhr in
am 07.10.2013 - 17:44 Uhr in
Hi Forum,
mein Modul, welches durch den Aufruf einer URL einen Node-Content updaten soll, funktioniert leider unter Linux nicht. Ich habe die Ownereigenschaft schon auf 6226:6226 gesetzt und die Benutzererechte schauen aus, wie bei jedem anderen Modul auch. Das Modul an sich scheint zu funktionieren, jedenfalls läuft es bei Microsoft. Auf meiner Linux-Kiste scheint es die URL nicht zu geben und es gibt auch in keinem Menü einen Aufruf.
Hier ist einfach mal der Code meines Modules:
<?php
/**
* Implements hook_menu().
*/
function nodeupdate_menu() {
$items = array();
$items['nodeupdate'] = array(
'title' => 'nodeupdate',
'description' => 'mit Hilfe dieses Moduls, soll es möglich werden ein Nodeupdate durchzufuehren',
'page_arguments'=> array(1,'foo'),
'access callback' => TRUE,
'page callback' => 'nodeupdate_function_nodeupdate',
);
return $items;
}
function nodeupdate_function_nodeupdate($nodeid,$wert) { //Nodeid muss vorhanden sein
//var_dump(node_load($nodeid));
//var_dump($wert);
//$node = node_load($nodeid);
//var_dump(node_load($nodeid));
$node = node_load($nodeid);
//$field = $node->field_running['und'][0]['value'];
//var_dump($node->field_running['und'][0]['value']);
$node->field_running['und'][0]['value'] = $wert;
node_save($node);
var_dump($node);
}
?>
Ich habe leider keine Ahnung an was es sonst noch liegen kann, ausser an einem der ganzen Zusatzmodule. (AutoPath und so).
mfg
Andy
- Anmelden oder Registrieren um Kommentare zu schreiben
Evtl. ein Zeichensatzproblem,
am 07.10.2013 - 19:54 Uhr
Evtl. ein Zeichensatzproblem, das auf einem System auftritt und auf dem anderen nicht? Konkret meine ich das "möglich" in der Description. (Außerdem ist dort ein Komma zu viel drin, aber das hat dann eher mit korrekter deutscher Zeichensetzung als mit Drupal zu tun.)
Drupal Freelancer im Rheinland gesucht?
was steht in den logs?
am 07.10.2013 - 19:55 Uhr
Welcher Webserver ist im Einsatz?
Ist der Windows Host ein localhost?
Grüße
Ronald
Hi, sowohl bei Linux als auch
am 08.10.2013 - 05:45 Uhr
Hi,
sowohl bei Linux als auch bei Windows bin ich localhost, es läuft ein Apache, PHP 5.5 und Postgres. Ich habe alle Umlaute auch schon umgeändert.
mfg
Andy
Vorallem, weil ich gerade feststelle das auf meiner zweiten reallen Linux-Kiste das Modul läuft. Mein Provider bei dem das Problem auftritt ist 1und1 ein virtueller Server. Kann es an anderweitigen Modulen liegen?
Aller Anfang ist schwer...
was steht in den logs?
am 08.10.2013 - 07:39 Uhr
Wenn es Zugriffsprobleme gibt, werden diese in den LOGs notiert.
Schau in die LOGs von Apache und PHP, um dort festzustellen, was wann aufgetreten ist.
Windows und LINUX haben im Bereich der Berechtigungen ein paar kleine Unterschiede, und im Handling von Groß- und Kleinschreibung.
Grüße
Ronald
HI, ich habe jetzt folgenden
am 08.10.2013 - 17:27 Uhr
HI, ich habe jetzt folgenden Code komplett händisch auf dem Debian-Server geschrieben:
<?php
/**
* Imlements hook_menu().
*/
function node_update_menu(){
$items = array();
$items['nodeupdate'] = array(
<------>'title'=>'NodeUpdate',
<------>'description'=>'Mit Hilfe dieses Moduls lassen sich Nodes updaten',
<------>'page arguments'=>array(1,'foo'),
<------>'access callback'=>TRUE,
<------>'page callback'=>'weathernode_update',
);
return $items;
}
function weathernode_update($nodeid,$wert){
var_dump(node_load($nodeid));
}
<-------> entspricht den Tab´s
Ich habe in den Drupal Logs lediglich die Fehlermeldung, dass die Seite nicht verfügbar ist. Im error.log des Apache steht auch ncihts und in der access.log steht folgendes (was einigermaßen mit dem Modul in Verbindung gebracht werden kann) drinnen:
??.??.??.??- - [08/Oct/2013:18:19:46 +0200] "GET /js/admin_menu/cache/6178bf7ce1d2f514268dacbc55925184 HTTP/1.1" 200 4398 "http://www.andylicht.de/nodeupdate" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/30.0.1599.69 Safari/537.36"
127.0.0.1 - - [08/Oct/2013:18:20:04 +0200] "OPTIONS * HTTP/1.0" 200 152 "-" "Apache/2.2.16 (Debian) (internal dummy connection)
??.??.??.?? ist lediglich eine IP.
Ich habe keine Ahnung was ich noch machen kann.
mit besten Grüßen
Andy
Aller Anfang ist schwer...
Nichts im PHP-LOG?
am 08.10.2013 - 17:29 Uhr
200 heißt, dass die Seite geladen werden konnte.
Der PHP-Code ist unabhängig vom Betriebssystem.
Grüße
Ronald
Ja, heißt das aber nicht
am 08.10.2013 - 17:34 Uhr
Ja, heißt das aber nicht eigentlich nur, dass die Fehlerseite geladen werden konnte?
Den Cache habe ich auch mehrfach gelöscht.
Normalerweise, sollte Drupal doch auch automatisiert einen link im Menü (Navigation) anlegen.
Aller Anfang ist schwer...