<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="hu">
	<id>https://vik.wiki/index.php?action=history&amp;feed=atom&amp;title=P%C3%A9ldaprogram_n%C3%A9gyr%C3%A9teg%C5%B1_architekt%C3%BAr%C3%A1ra_php-ban</id>
	<title>Példaprogram négyrétegű architektúrára php-ban - Laptörténet</title>
	<link rel="self" type="application/atom+xml" href="https://vik.wiki/index.php?action=history&amp;feed=atom&amp;title=P%C3%A9ldaprogram_n%C3%A9gyr%C3%A9teg%C5%B1_architekt%C3%BAr%C3%A1ra_php-ban"/>
	<link rel="alternate" type="text/html" href="https://vik.wiki/index.php?title=P%C3%A9ldaprogram_n%C3%A9gyr%C3%A9teg%C5%B1_architekt%C3%BAr%C3%A1ra_php-ban&amp;action=history"/>
	<updated>2026-05-17T07:49:16Z</updated>
	<subtitle>Az oldal laptörténete a wikiben</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://vik.wiki/index.php?title=P%C3%A9ldaprogram_n%C3%A9gyr%C3%A9teg%C5%B1_architekt%C3%BAr%C3%A1ra_php-ban&amp;diff=138592&amp;oldid=prev</id>
		<title>Unknown user: Új oldal, tartalma: „{{GlobalTemplate|Infoalap|SzgLab5PHP4Tier}}   __TOC__  ==Konfiguráció &amp;mdash; /php-include/db/config.inc==  &lt;pre&gt; &lt;?php  /* Az itt használt globális változók mind…”</title>
		<link rel="alternate" type="text/html" href="https://vik.wiki/index.php?title=P%C3%A9ldaprogram_n%C3%A9gyr%C3%A9teg%C5%B1_architekt%C3%BAr%C3%A1ra_php-ban&amp;diff=138592&amp;oldid=prev"/>
		<updated>2012-10-21T20:21:54Z</updated>

		<summary type="html">&lt;p&gt;Új oldal, tartalma: „{{GlobalTemplate|Infoalap|SzgLab5PHP4Tier}}   __TOC__  ==Konfiguráció — /php-include/db/config.inc==  &amp;lt;pre&amp;gt; &amp;lt;?php  /* Az itt használt globális változók mind…”&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Új lap&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{GlobalTemplate|Infoalap|SzgLab5PHP4Tier}}&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
__TOC__&lt;br /&gt;
&lt;br /&gt;
==Konfiguráció &amp;amp;mdash; /php-include/db/config.inc==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
&lt;br /&gt;
/* Az itt használt globális változók mind konstansok! */&lt;br /&gt;
&lt;br /&gt;
$oracleuser = &amp;quot;neptun kód&amp;quot;;&lt;br /&gt;
$oraclepassword = &amp;quot;********&amp;quot;;&lt;br /&gt;
&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Adatbázis elérési réteg &amp;amp;mdash; /php-include/db/sql.inc==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
&lt;br /&gt;
require_once(&amp;quot;config.inc&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
class SQL {&lt;br /&gt;
	private $conn, $statement;&lt;br /&gt;
&lt;br /&gt;
	/* Kapcsolat megnyitása a konstruktorban */	&lt;br /&gt;
	function __construct() {&lt;br /&gt;
		global $oracleuser, $oraclepassword;&lt;br /&gt;
		return $this-&amp;gt;conn = OCILogon($oracleuser, $oraclepassword, &amp;quot;&amp;quot;);&lt;br /&gt;
		// return $this-&amp;gt;conn = OCILogon($oracleuser, $oraclepassword, &amp;quot;tnsnames.ora&amp;quot;);&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	/* Utasításnak lefoglalt terület felszabadítása, ha szükséges */&lt;br /&gt;
	private function freeStatement() {&lt;br /&gt;
		if ($this-&amp;gt;statement) OCIFreeStatement($this-&amp;gt;statement);&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	/* Paraméteres lekérdezés végrehajtása */&lt;br /&gt;
	function query($query, $bind=FALSE) {&lt;br /&gt;
		$this-&amp;gt;freeStatement();&lt;br /&gt;
		$this-&amp;gt;statement = OCIParse($this-&amp;gt;conn, $query);&lt;br /&gt;
&lt;br /&gt;
		$ok = true;&lt;br /&gt;
		if ($bind) {&lt;br /&gt;
			foreach ($bind as $key =&amp;gt; $value) {&lt;br /&gt;
				$ok &amp;amp;= OCIBindByName($this-&amp;gt;statement, $key, $bind[$key], -1);&lt;br /&gt;
			}&lt;br /&gt;
		}&lt;br /&gt;
		if ($ok) OCIExecute($this-&amp;gt;statement);&lt;br /&gt;
		return $ok;&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	/* Lekérdezés eredményének következő sora							  */&lt;br /&gt;
	/* Asszociatív tömb, OSZLOPNÉV =&amp;gt; érték formátumú elemekből áll */&lt;br /&gt;
	/* Ha nincs több találat, FALSE-szal tér vissza					  */&lt;br /&gt;
	function fetch() {&lt;br /&gt;
		OCIFetchInto($this-&amp;gt;statement, $line, OCI_ASSOC);&lt;br /&gt;
		return $line;&lt;br /&gt;
	}&lt;br /&gt;
&lt;br /&gt;
	/* Utasításnak lefoglalt terület felszabadítása, és kapcsolat bontása a destruktorban */&lt;br /&gt;
	function __destruct() {&lt;br /&gt;
		$this-&amp;gt;freeStatement();&lt;br /&gt;
		OCILogoff($this-&amp;gt;conn);&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Üzleti logika &amp;amp;mdash; /php-include/bom/search.inc==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
&lt;br /&gt;
require_once(&amp;quot;../db/sql.inc&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
/* Lekérdezi a keresési feltételeknek megfelelő könyvek számát */ &lt;br /&gt;
function search_count($cim, $szerzo) {&lt;br /&gt;
	$query = &amp;quot;SELECT count(*) AS count FROM konyv &amp;quot; .&lt;br /&gt;
				&amp;quot;WHERE LOWER(szerzo) LIKE LOWER(:szerzo) AND &amp;quot; .&lt;br /&gt;
				&amp;quot;LOWER(cim) LIKE LOWER(:cim)&amp;quot;;&lt;br /&gt;
	$sql = new SQL();&lt;br /&gt;
	$sql-&amp;gt;query($query, array(&amp;quot;:szerzo&amp;quot; =&amp;gt; $szerzo, &amp;quot;:cim&amp;quot; =&amp;gt; $cim));&lt;br /&gt;
	$result = $sql-&amp;gt;fetch();&lt;br /&gt;
	return $result[&amp;quot;COUNT&amp;quot;];			&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==Megjelenítés &amp;amp;mdash; /php-include/view/search.inc==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
&lt;br /&gt;
require_once(&amp;quot;../bom/search.inc&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
/* Keresőform kirajzolása */&lt;br /&gt;
function search_showform() {&lt;br /&gt;
	echo &amp;quot;&amp;lt;form action=&amp;#039;{$_SERVER[&amp;#039;PHP_SELF&amp;#039;]}&amp;#039; method=&amp;#039;GET&amp;#039;&amp;gt;\n&amp;quot;;&lt;br /&gt;
	echo &amp;quot;&amp;lt;p&amp;gt;Cím: &amp;lt;input name=&amp;#039;cim&amp;#039; value=&amp;#039;{$_GET[&amp;quot;cim&amp;quot;]}&amp;#039;&amp;gt;&amp;lt;/p&amp;gt;\n&amp;quot;;&lt;br /&gt;
	echo &amp;quot;&amp;lt;p&amp;gt;Szerző: &amp;lt;input name=&amp;#039;szerzo&amp;#039; value=&amp;#039;{$_GET[&amp;quot;szerzo&amp;quot;]}&amp;#039;&amp;gt;&amp;lt;/p&amp;gt;\n&amp;quot;;&lt;br /&gt;
	echo &amp;quot;&amp;lt;p&amp;gt;&amp;lt;input type=&amp;#039;submit&amp;#039; value=&amp;#039;Keres&amp;#039;&amp;gt;&amp;lt;/p&amp;gt;\n&amp;quot;;&lt;br /&gt;
	echo &amp;quot;&amp;lt;/form&amp;gt;&amp;quot;;	 &lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/* Eredmények felsorolása */&lt;br /&gt;
function search_showresults($cim, $szerzo) {&lt;br /&gt;
	$count = search_count($cim, $szerzo);&lt;br /&gt;
	if ($count) {&lt;br /&gt;
		echo &amp;quot;&amp;lt;p&amp;gt;$count találat&amp;lt;/p&amp;gt;&amp;quot;;&lt;br /&gt;
		// találatok felsorolása&lt;br /&gt;
	} else echo &amp;quot;&amp;lt;p&amp;gt;Nincs találat&amp;lt;/p&amp;gt;&amp;quot;;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==/public_html/php/search.php==&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
&amp;lt;?php&lt;br /&gt;
&lt;br /&gt;
require(&amp;quot;../../php-include/view/header.inc&amp;quot;);&lt;br /&gt;
require_once(&amp;quot;../../php-include/view/search.inc&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
search_showform();&lt;br /&gt;
if (isset ($_GET[&amp;quot;cim&amp;quot;]) &amp;amp;&amp;amp; isset ($_GET[&amp;quot;szerzo&amp;quot;])) {&lt;br /&gt;
	search_showresults($_GET[&amp;quot;cim&amp;quot;], $_GET[&amp;quot;szerzo&amp;quot;]);&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
require(&amp;quot;../../php-include/view/footer.inc&amp;quot;);&lt;br /&gt;
&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
-- [[PallosPeter|Peti]] - 2006.01.13.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
[[Category:Infoalap]]&lt;/div&gt;</summary>
		<author><name>Unknown user</name></author>
	</entry>
</feed>