source: trunk/info/info/alkisn/alkisausk.php @ 387

Revision 387, 10.8 KB checked in by frank.jaeger, 7 years ago (diff)

Überarbeitung der Buchauskunft: FS-Nachweis enthält optional die berechtigten Buchungen, Input-Validation, Styling, kleinere Korrekturen, HTML-Profilierung

Line 
1<?php
2/*      alkisausk.php
3
4        ALKIS-Buchauskunft, Kommunales Rechenzentrum Minden-Ravensberg/Lippe (Lemgo).
5        Dies Programm wird aus dem Mapserver-Template (FeatureInfo) aufgerufen.
6        Parameter: &gkz, &gml_id (optional &id)
7        Dies Programm gibt einen kurzen Überblick zum FlurstÃŒck, z.B. Eigentuemer ohne Adresse
8        FÃŒr detaillierte Angaben wird zum GB- oder FS-Nachweis verlinkt.
9        Siehe auch alkisinlayausk.php - eine Variante fÃŒr den Einbau in einen iFrame
10
11        Version:
12        2016-02-24 Version fuer norGIS-ALKIS-Import
13        2016-11-29 HTML5, Gemeinsam genutzte Datenbanken ermöglichen (Berechtigung fÃŒr Gemeinde prÃŒfen)
14
15        H i n w e i s :  Dies Modul wird beim Entwickler nicht mehr produktiv eingesetzt.
16                Statt dessen wird "alkisinlayausk.php" verwendet um von einer WMS-FeatureInfo in ein Fenster ÃŒberzuleiten.
17                Mangels Praxis bleiben Fehler möglicherweise unerkannt.
18*/
19session_start();
20$cntget = extract($_GET);
21
22require_once("alkis_conf_location.php");
23if ($auth == "mapbender") {require_once($mapbender);}
24include("alkisfkt.php");
25$keys = isset($_GET["showkey"]) ? $_GET["showkey"] : "n";
26if ($keys == "j") {$showkey=true;} else {$showkey=false;}
27echo <<<END
28<!doctype html>
29<html lang="de">
30<head>
31        <meta charset="utf-8">
32        <link rel="stylesheet" type="text/css" href="alkisauszug.css">
33        <link rel="shortcut icon" type="image/x-icon" href="ico/Flurstueck.ico">
34        <title>ALKIS-Auskunft</title>
35</head>
36<body>
37END;
38$con = pg_connect($dbconn." options='--application_name=ALKIS-Auskunft_alkisausk.php'");
39if (!$con) {echo "<br>Fehler beim Verbinden der DB.\n<br>";}
40
41// *** F L U R S T U E C K ***
42$sql ="SELECT f.flurnummer, f.zaehler, f.nenner, f.amtlicheflaeche, g.gemarkungsnummer, g.bezeichnung, f.regierungsbezirk, f.kreis, f.gemeinde
43FROM ax_flurstueck f LEFT JOIN ax_gemarkung g ON f.land=g.land AND f.gemarkungsnummer=g.gemarkungsnummer
44WHERE f.gml_id= $1 AND f.endet IS NULL;";
45
46$v = array($gmlid);
47$res = pg_prepare("", $sql);
48$res = pg_execute("", $v);
49if (!$res) {
50        echo "\n<p class='err'>Fehler bei Flurstuecksdaten.</p>";
51        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
52}
53
54if ($row = pg_fetch_array($res)) {
55        $gemkname=htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8");
56        $gmkgnr=$row["gemarkungsnummer"];
57        $flurnummer=$row["flurnummer"];
58        $flstnummer=$row["zaehler"];
59        $nenner=$row["nenner"];
60        if ($nenner > 0) $flstnummer.="/".$nenner; // BruchNr
61        $flae=$row["amtlicheflaeche"];
62        $flae=number_format($flae,0,",",".") . " m&#178;";
63        $fsreg=$row["regierungsbezirk"]; // Filter ZustÀndigkeit
64        $fskrs=$row["kreis"];
65        $fsgem=$row["gemeinde"];
66} else {
67        echo "\n<p class='err'>Kein Treffer fuer gml_id=".$gmlid."</p>";
68}
69
70// Balken
71echo "\n<p class='fsausk'>ALKIS-Auskunft Flurst&uuml;ck-&Uuml;bersicht ".$gmkgnr."-".$flurnummer."-".$flstnummer."</p>";
72
73// PrÃŒfung der Gebiets-Berechtigung bei gemeinsam genutzten Datenbanken (Kreis und Gemeinde)
74// FÃŒr das gkz (z.B. aus dem Mapfile-Namen) wird in der Konfiguration ein Filter gesetzt.
75if ( ($filtkreis != '' and $filtkreis != $fskrs) or ($filtgem != '' and $filtgem != $fsgem) ) {
76        // Einer der gesetzten Filter passt nicht
77        if ($debug > 2) {
78                echo "\n<p class='err'>Filter Kreis='".$filtkreis."', Gemeinde='".$filtgem."'</p>";
79                echo "\n<p class='err'>Flstk. Kreis='".$fskrs."', Gemeinde='".$fsgem."'</p>";
80        }
81        echo "\n<br><p class='stop1'>Zugriff nicht erlaubt</p>
82        \n<br><p class='stop2'>Dies Flurst&uuml;ck liegt ausserhalb der zust&auml;ndigen Stadt oder Gemeinde.</p>\n</body>\n</html>";
83        pg_free_result($res);
84        exit;
85}
86
87echo "\n<table class='outer'>\n<tr><td>";
88        // linke Seite
89        echo "\n<h1>ALKIS-Auskunft</h1>"
90        ."\n<h2><img src='ico/Flurstueck.png' width='16' height='16' alt=''> Flurst&uuml;ck - &Uuml;bersicht</h2>";
91echo "</td><td align='right'>";
92        // rechte Seite
93        echo "<img src='pic/AAA.gif' alt=''>"
94."</td></tr></table>";
95
96echo "\n<table class='outer'>\n<tr>\n<td>"
97        ."\n\t<table class='kennzfs' title='Flurst&uuml;ckskennzeichen'>\n\t<tr>"
98        ."\n\t\t<td class='head'>Gmkg</td>\n\t\t<td class='head'>Flur</td>\n\t\t<td class='head'>Flurst-Nr.</td>\n\t</tr>"
99        ."\n\t<tr>\n\t\t<td title='Gemarkung'>";
100        if ($showkey) {echo "<span class='key'>".$gmkgnr."</span><br>";}
101        echo $gemkname."</td>"
102        . "\n\t\t<td title='Flurnummer'>".$flurnummer."</td>"
103        ."\n\t\t<td title='Flurst&uuml;cksnummer (Z&auml;hler / Nenner)'><span class='wichtig'>".$flstnummer."</span></td>\n\t</tr>"
104        ."\n\t</table>"
105."\n</td>\n<td>"
106."\n\t<p class='nwlink'>weitere Auskunft:<br>";
107
108// Flurstuecksnachweis (o. Eigent.)
109echo "\n\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=n";
110        if ($showkey) {echo "&amp;showkey=j";}
111        echo "' title='Flurst&uuml;cksnachweis, alle Flurst&uuml;cksdaten'>Flurst&uuml;ck "
112        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
113."</a><br>";
114
115// FS- u. Eigent.-NW
116echo "\n\t\t<a href='alkisfsnw.php?gkz=".$gkz."&amp;gmlid=".$gmlid."&amp;eig=j";
117        if ($showkey) {echo "&amp;showkey=j";}
118        echo "' title='Flurst&uuml;ck mit Eigent&uuml;mer'>Flurst&uuml;ck mit Eigent&uuml;mer "
119        ."<img src='ico/Flurstueck_Link.png' width='16' height='16' alt=''>"
120."</a><br>";
121
122// FS-Historie
123echo "\n\t\t<a href='alkisfshist.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
124        if ($showkey) {echo "&amp;showkey=j";}
125        echo "' title='Vorg&auml;nger des Flurst&uuml;cks'>Historie "
126        ."<img src='ico/Flurstueck_Historisch.png' width='16' height='16' alt=''>"
127."</a><br>";
128
129// Gebaeude-NW
130echo "\n\t\t<a href='alkisgebaeudenw.php?gkz=".$gkz."&amp;gmlid=".$gmlid;
131        if ($showkey) {echo "&amp;showkey=j";}
132        echo "' title='Geb&auml;udenachweis'>Geb&auml;ude "
133        ."<img src='ico/Haus.png' width='16' height='16' alt=''>"
134."</a>"
135. "\n\t</p>\n</td>";
136
137// Lagebezeichnung MIT Hausnummer (Adresse)
138$sql ="SELECT DISTINCT l.gml_id, s.gml_id AS kgml, l.gemeinde, l.lage, l.hausnummer, s.bezeichnung
139FROM ax_flurstueck f JOIN ax_lagebezeichnungmithausnummer l ON l.gml_id=ANY(f.weistauf)
140LEFT JOIN ax_lagebezeichnungkatalogeintrag s ON l.kreis=s.kreis AND l.gemeinde=s.gemeinde AND l.lage=s.lage
141WHERE f.gml_id= $1 AND f.endet IS NULL AND l.endet IS NULL AND s.endet IS NULL ORDER BY l.gemeinde, l.lage, l.hausnummer;";
142
143$v = array($gmlid);
144$res = pg_prepare("", $sql);
145$res = pg_execute("", $v);
146if (!$res) {
147        echo "\n<p class='err'>Fehler bei Lagebezeichnung mit Hausnummer.</p>";
148        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
149}
150$j=0;
151while($row = pg_fetch_array($res)) {
152        $sname = htmlentities($row["bezeichnung"], ENT_QUOTES, "UTF-8"); // Str.-Name
153        echo "\n<tr>\n\t"
154                ."\n\t<td class='lr'>".$sname."&nbsp;".$row["hausnummer"]."</td>"
155                ."\n\t<td>\n\t\t<p class='nwlink noprint'>"
156                        ."\n\t\t\t<a title='Lagebezeichnung mit Hausnummer' href='alkislage.php?gkz=".$gkz."&amp;ltyp=m&amp;gmlid=".$row["gml_id"]."'>Lage "
157                        ."<img src='ico/Lage_mit_Haus.png' width='16' height='16' alt=''></a>&nbsp;"
158                        ."\n\t\t\t<a href='alkisstrasse.php?gkz=".$gkz."&amp;gmlid=".$row["kgml"]
159                        ."' title='Stra&szlig;e'>Stra&szlig;e <img src='ico/Strassen.png' width='16' height='16' alt=''></a>"
160                ."\n\t\t</p>\n\t</td>"
161        ."\n</tr>";
162        $j++;
163}
164echo "\n</tr>\n</table>";
165
166// Flurstuecksflaeche
167echo "\n<p class='fsd'>Flurst&uuml;cksfl&auml;che: <b>".$flae."</b></p>";
168
169// *** G R U N D B U C H ***
170echo "\n<h2><img src='ico/Grundbuch_zu.png' width='16' height='16' alt=''> Grundbuch</h2>";
171// ALKIS: FS >istgebucht> GS >istBestandteilVon> GB.
172$sql ="SELECT b.gml_id, b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung as blatt, b.blattart, wa.v AS blattartv,
173s.gml_id AS s_gml, s.buchungsart, s.laufendenummer, s.zaehler, s.nenner, z.bezeichnung, wb.v AS bart
174FROM ax_flurstueck f
175JOIN ax_buchungsstelle s ON f.istgebucht=s.gml_id
176JOIN ax_buchungsblatt b ON s.istbestandteilvon=b.gml_id
177LEFT JOIN ax_buchungsblattbezirk z ON z.land=b.land AND z.bezirk=b.bezirk
178LEFT JOIN alkis_wertearten wa ON cast(b.blattart AS character varying)=wa.k AND wa.element='ax_buchungsblatt' AND wa.bezeichnung='blattart'
179LEFT JOIN alkis_wertearten wb ON cast(s.buchungsart AS character varying)=wb.k AND wb.element='ax_buchungsstelle' AND wb.bezeichnung='buchungsart'
180WHERE f.gml_id= $1 AND f.endet IS NULL AND s.endet IS NULL AND b.endet IS NULL
181ORDER BY b.bezirk, b.buchungsblattnummermitbuchstabenerweiterung, s.laufendenummer;";
182
183$v = array($gmlid);
184$resg = pg_prepare("", $sql);
185$resg = pg_execute("", $v);
186if (!$resg) {
187        echo "\n<p class='err'>Keine Buchungen.</p>";
188        if ($debug > 2) {echo "\n<p class='err'>SQL=<br>".$sql."<br>$1 = gml_id = '".$gmlid."'</p>";}
189}
190
191$j=0; // Z.Blatt
192while($rowg = pg_fetch_array($resg)) {
193        $beznam=$rowg["bezeichnung"];
194        echo "\n<table class='outer'>\n<tr>\n<td>";
195                $blattkey=$rowg["blattart"];
196                $blattart=$rowg["blattartv"];
197                if ($blattkey == 1000) {
198                        echo "\n\t<table class='kennzgb' title='Bestandskennzeichen'>";
199                } else {
200                        echo "\n\t<table class='kennzgbf' title='Bestandskennzeichen'>"; // dotted
201                }
202                        echo "\n\t<tr>"
203                                ."\n\t\t<td class='head'>Bezirk</td>"
204                                ."\n\t\t<td class='head'>".$blattart."</td>"
205                                ."\n\t\t<td class='head'>Lfd-Nr.</td>"
206                                ."\n\t\t<td class='head'>Buchungsart</td>"
207                        ."\n\t</tr>";
208                        echo "\n\t<tr>"
209                                ."\n\t\t<td title='Grundbuchbezirk'>";
210                                        if ($showkey) {echo "<span class='key'>".$rowg["bezirk"]."</span><br>";}
211                                echo $beznam."</td>"
212                                ."\n\t\t<td title='Grundbuch-Blatt'><span class='wichtig'>".$rowg["blatt"]."</span></td>"
213                                ."\n\t\t<td title='Bestandsverzeichnis-Nummer (BVNR, Grundst&uuml;ck)'>".$rowg["laufendenummer"]."</td>"
214                                ."\n\t\t<td title='Buchungsart'>";
215                                        if ($showkey) {echo "<span class='key'>".$rowg["buchungsart"]."</span><br>";}
216                                        echo $rowg["bart"]
217                                ."</td>"
218                        ."\n\t</tr>"
219                ."\n\t</table>";
220
221                if ($rowg["zaehler"] <> "") {
222                        echo "\n<p class='ant'>".$rowg["zaehler"]."/".$rowg["nenner"]."&nbsp;Anteil am Flurst&uuml;ck</p>";
223                }
224                echo "\n</td>\n<td>"
225                ."\n\t<p class='nwlink'>weitere Auskunft:<br>"
226                        ."\n\t\t<a href='alkisbestnw.php?gkz=".$gkz."&amp;gmlid=".$rowg[0];
227                                if ($showkey) {echo "&amp;showkey=j";}
228                                echo "' title='Grundbuchnachweis'>".$blattart." <img src='ico/GBBlatt_link.png' width='16' height='16' alt=''>"
229                        ."</a>"
230                ."\n\t</p>"
231        ."\n</td>\n</tr>\n</table>";
232
233        // E I G E N T U E M E R
234        if ($blattkey == 5000) { // SchlÃŒssel Blatt-Art
235                echo "\n<p>Keine Angaben zum Eigentum bei fiktivem Blatt</p>\n"
236                ."\n<p>Siehe weitere Grundbuchbl&auml;tter mit Rechten an dem fiktiven Blatt.</p>";
237        } else { // kein Eigent. bei fiktiv. Blatt
238                echo "\n<h3><img src='ico/Eigentuemer_2.png' width='16' height='16' alt=''> Angaben zum Eigentum</h3>";
239
240                // Ausgabe Name in Function
241                $n = eigentuemer($rowg["gml_id"], false, "imFenster"); // ohne Adressen
242
243                if ($n == 0) { // keine NamNum, kein Eigent.
244                        echo "\n<p class='err'>Keine Eigent&uuml;mer gefunden.</p>"
245                        ."\n<p class='err'>Bezirk ".$rowg["bezirk"]." Blatt ".$rowg["blatt"]." Blattart ".$blattkey." (".$blattart.")</p>";
246                }
247        }
248        $j++;
249}
250if ($j == 0) {echo "\n<p class='err'>Keine Buchungen gefunden.</p>";}
251echo "\n<hr>";
252
253footer($gmlid, $_SERVER['PHP_SELF']."?", "");
254
255?>
256</body>
257</html>
Note: See TracBrowser for help on using the repository browser.