Merge pull request 'dev/m6_robert_after_final' (#3) from dev/m6_robert_after_final into main
Reviewed-on: http://ds723plus:3000/Safak/DBWT/pulls/3
22
.idea/dataSources.local.xml
generated
Normal file
@@ -0,0 +1,22 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="dataSourceStorageLocal" created-in="PS-232.10072.32">
|
||||
<data-source name="@localhost" uuid="a1d1df29-b94a-4ad6-bd6f-a458b97a6c0c">
|
||||
<database-info product="MariaDB" version="11.1.3-MariaDB" jdbc-version="4.2" driver-name="MariaDB Connector/J" driver-version="3.0.7" dbms="MARIADB" exact-version="11.1.3" exact-driver-version="3.0">
|
||||
<extra-name-characters>#@</extra-name-characters>
|
||||
<identifier-quote-string>`</identifier-quote-string>
|
||||
</database-info>
|
||||
<case-sensitivity plain-identifiers="lower" quoted-identifiers="lower" />
|
||||
<secret-storage>master_key</secret-storage>
|
||||
<user-name>root</user-name>
|
||||
<schema-mapping>
|
||||
<introspection-scope>
|
||||
<node kind="schema">
|
||||
<name qname="emensawerbeseite" />
|
||||
<name qname="@" />
|
||||
</node>
|
||||
</introspection-scope>
|
||||
</schema-mapping>
|
||||
</data-source>
|
||||
</component>
|
||||
</project>
|
||||
12
.idea/dataSources.xml
generated
Normal file
@@ -0,0 +1,12 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="DataSourceManagerImpl" format="xml" multifile-model="true">
|
||||
<data-source source="LOCAL" name="@localhost" uuid="a1d1df29-b94a-4ad6-bd6f-a458b97a6c0c">
|
||||
<driver-ref>mariadb</driver-ref>
|
||||
<synchronize>true</synchronize>
|
||||
<jdbc-driver>org.mariadb.jdbc.Driver</jdbc-driver>
|
||||
<jdbc-url>jdbc:mariadb://localhost:3306</jdbc-url>
|
||||
<working-dir>$ProjectFileDir$</working-dir>
|
||||
</data-source>
|
||||
</component>
|
||||
</project>
|
||||
1944
.idea/dataSources/a1d1df29-b94a-4ad6-bd6f-a458b97a6c0c.xml
generated
Normal file
@@ -0,0 +1,2 @@
|
||||
#n:emensawerbeseite
|
||||
!<md> [1705632330000, 0, null, null, -2147483648, -2147483648]
|
||||
@@ -0,0 +1,2 @@
|
||||
#n:information_schema
|
||||
!<md> [null, 0, null, null, -2147483648, -2147483648]
|
||||
2
.idea/dataSources/a1d1df29-b94a-4ad6-bd6f-a458b97a6c0c/storage_v2/_src_/schema/mysql.osA4Bg.meta
generated
Normal file
@@ -0,0 +1,2 @@
|
||||
#n:mysql
|
||||
!<md> [null, 0, null, null, -2147483648, -2147483648]
|
||||
@@ -0,0 +1,2 @@
|
||||
#n:performance_schema
|
||||
!<md> [null, 0, null, null, -2147483648, -2147483648]
|
||||
35
.idea/php.xml
generated
Normal file
@@ -0,0 +1,35 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="MessDetectorOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PHPCSFixerOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PHPCodeSnifferOptionsConfiguration">
|
||||
<option name="highlightLevel" value="WARNING" />
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PhpIncludePathManager">
|
||||
<include_path>
|
||||
<path value="$PROJECT_DIR$/M5/vendor/monolog/monolog" />
|
||||
<path value="$PROJECT_DIR$/M5/vendor/psr/log" />
|
||||
<path value="$PROJECT_DIR$/M5/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/M4/emensa/vendor/eftec/bladeone" />
|
||||
<path value="$PROJECT_DIR$/M4/emensa/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/eftec/bladeone" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/psr/log" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/monolog/monolog" />
|
||||
</include_path>
|
||||
</component>
|
||||
<component name="PhpProjectSharedConfiguration" php_language_level="7.4">
|
||||
<option name="suggestChangeDefaultLanguageLevel" value="false" />
|
||||
</component>
|
||||
<component name="PhpStanOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PsalmOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
57
.idea/shelf/Uncommitted_changes_before_rebase_[Changes]/shelved.patch
generated
Normal file
4
.idea/shelf/Uncommitted_changes_before_rebase__Changes_.xml
generated
Normal file
@@ -0,0 +1,4 @@
|
||||
<changelist name="Uncommitted_changes_before_rebase_[Changes]" date="1703077231768" recycled="false" toDelete="true">
|
||||
<option name="PATH" value="$PROJECT_DIR$/.idea/shelf/Uncommitted_changes_before_rebase_[Changes]/shelved.patch" />
|
||||
<option name="DESCRIPTION" value="Uncommitted changes before rebase [Changes]" />
|
||||
</changelist>
|
||||
11
.idea/sqlDataSources.xml
generated
Normal file
@@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="DdlMappings">
|
||||
<mapping uuid="be6b29fb-6598-43a2-941f-0bba6d782429" name="emensawerbeseite@localhost Mapping">
|
||||
<data-sources db="24dddfdb-38aa-45e9-b936-a3dd64f77e86" ddl="260cbe83-f68f-4636-a591-fef81902f80c" />
|
||||
<scope>
|
||||
<node kind="database" negative="1" />
|
||||
</scope>
|
||||
</mapping>
|
||||
</component>
|
||||
</project>
|
||||
6
.idea/sqldialects.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="SqlDialectMappings">
|
||||
<file url="file://$PROJECT_DIR$/M3/werbeseite_daten.sql" dialect="MariaDB" />
|
||||
</component>
|
||||
</project>
|
||||
6
.idea/vcs.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
||||
215
.idea/workspace.xml
generated
Normal file
@@ -0,0 +1,215 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="AutoImportSettings">
|
||||
<option name="autoReloadType" value="SELECTIVE" />
|
||||
</component>
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" id="6dcbe3e4-9d68-41d8-8c39-5cfbe5cd4a21" name="Changes" comment="Alles">
|
||||
<change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/M6/emensamobile/public/css/style.css" beforeDir="false" afterPath="$PROJECT_DIR$/M6/emensamobile/public/css/style.css" afterDir="false" />
|
||||
<change beforePath="$PROJECT_DIR$/M6/emensamobile/resources/views/main/bewertung.blade.php" beforeDir="false" afterPath="$PROJECT_DIR$/M6/emensamobile/resources/views/main/bewertung.blade.php" afterDir="false" />
|
||||
</list>
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ComposerConfigs">
|
||||
<option name="configs">
|
||||
<option value="$PROJECT_DIR$/M4/emensa/composer.json" />
|
||||
<option value="$PROJECT_DIR$/M5/emensa/composer.json" />
|
||||
</option>
|
||||
</component>
|
||||
<component name="ComposerSettings" synchronizationState="SYNCHRONIZE">
|
||||
<pharConfigPath>$PROJECT_DIR$/M5/composer.json</pharConfigPath>
|
||||
<execution />
|
||||
</component>
|
||||
<component name="Git.Settings">
|
||||
<option name="RECENT_BRANCH_BY_REPOSITORY">
|
||||
<map>
|
||||
<entry key="$PROJECT_DIR$" value="dev/m5_safak" />
|
||||
</map>
|
||||
</option>
|
||||
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
|
||||
</component>
|
||||
<component name="MarkdownSettingsMigration">
|
||||
<option name="stateVersion" value="1" />
|
||||
</component>
|
||||
<component name="PhpWorkspaceProjectConfiguration" interpreter_name="Xampp">
|
||||
<include_path>
|
||||
<path value="$PROJECT_DIR$/M5/vendor/monolog/monolog" />
|
||||
<path value="$PROJECT_DIR$/M5/vendor/psr/log" />
|
||||
<path value="$PROJECT_DIR$/M5/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/M4/emensa/vendor/eftec/bladeone" />
|
||||
<path value="$PROJECT_DIR$/M4/emensa/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/eftec/bladeone" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/psr/log" />
|
||||
<path value="$PROJECT_DIR$/M5/emensa/vendor/monolog/monolog" />
|
||||
</include_path>
|
||||
</component>
|
||||
<component name="ProjectColorInfo">{
|
||||
"customColor": "",
|
||||
"associatedIndex": 0
|
||||
}</component>
|
||||
<component name="ProjectId" id="2YZcMNXBUidjAecPVKM66b1DdlE" />
|
||||
<component name="ProjectViewState">
|
||||
<option name="hideEmptyMiddlePackages" value="true" />
|
||||
<option name="showLibraryContents" value="true" />
|
||||
</component>
|
||||
<component name="PropertiesComponent">{
|
||||
"keyToString": {
|
||||
"RunOnceActivity.OpenProjectViewOnStart": "true",
|
||||
"RunOnceActivity.ShowReadmeOnStart": "true",
|
||||
"WebServerToolWindowFactoryState": "false",
|
||||
"database.data.extractors.current.export.id": "Comma-separated (CSV)_id",
|
||||
"git-widget-placeholder": "dev/m6__robert",
|
||||
"last_opened_file_path": "C:/Users/rober/Documents/GitHub/DBWT-Praktika/M6/Dossier",
|
||||
"node.js.detected.package.eslint": "true",
|
||||
"node.js.detected.package.tslint": "true",
|
||||
"node.js.selected.package.eslint": "(autodetect)",
|
||||
"node.js.selected.package.tslint": "(autodetect)",
|
||||
"nodejs_package_manager_path": "npm",
|
||||
"settings.editor.selected.configurable": "preferences.pluginManager",
|
||||
"vue.rearranger.settings.migration": "true"
|
||||
},
|
||||
"keyToStringList": {
|
||||
"DatabaseDriversLRU": [
|
||||
"mariadb"
|
||||
]
|
||||
}
|
||||
}</component>
|
||||
<component name="RecentsManager">
|
||||
<key name="CopyFile.RECENT_KEYS">
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\Dossier" />
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\emensamobile\public" />
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\emensamobile\resources\views" />
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\emensamobile\app\Models" />
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\emensamobile\resources\css" />
|
||||
</key>
|
||||
<key name="MoveFile.RECENT_KEYS">
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\emensamobile\app\Models\Anmeldung" />
|
||||
<recent name="C:\Users\rober\Documents\GitHub\DBWT-Praktika\M6\emensamobile\app\Models\Main" />
|
||||
</key>
|
||||
</component>
|
||||
<component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="application-level" UseSingleDictionary="true" transferred="true" />
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="6dcbe3e4-9d68-41d8-8c39-5cfbe5cd4a21" name="Changes" comment="" />
|
||||
<created>1700736495450</created>
|
||||
<option name="number" value="Default" />
|
||||
<option name="presentableId" value="Default" />
|
||||
<updated>1700736495450</updated>
|
||||
<workItem from="1700736497007" duration="15223000" />
|
||||
<workItem from="1702027267170" duration="12429000" />
|
||||
<workItem from="1704879915312" duration="5579000" />
|
||||
<workItem from="1704901745332" duration="7535000" />
|
||||
<workItem from="1705063082944" duration="2121000" />
|
||||
<workItem from="1705065239294" duration="1925000" />
|
||||
<workItem from="1705405736678" duration="5488000" />
|
||||
<workItem from="1705414744237" duration="1967000" />
|
||||
<workItem from="1705488930166" duration="3342000" />
|
||||
<workItem from="1705492444098" duration="553000" />
|
||||
<workItem from="1705493014644" duration="21207000" />
|
||||
<workItem from="1705627589042" duration="2719000" />
|
||||
<workItem from="1705630465063" duration="13412000" />
|
||||
<workItem from="1706091740788" duration="2624000" />
|
||||
</task>
|
||||
<task id="LOCAL-00001" summary="Webseite ohne Anmeldung läuft auf laravel">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705491845444</created>
|
||||
<option name="number" value="00001" />
|
||||
<option name="presentableId" value="LOCAL-00001" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705491845444</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00002" summary="Webseite ohne Anmeldung läuft auf laravel">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705491897073</created>
|
||||
<option name="number" value="00002" />
|
||||
<option name="presentableId" value="LOCAL-00002" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705491897073</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00003" summary="Anmeldung läuft">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705501430071</created>
|
||||
<option name="number" value="00003" />
|
||||
<option name="presentableId" value="LOCAL-00003" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705501430071</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00004" summary="Abmeldung gefixt">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705501770457</created>
|
||||
<option name="number" value="00004" />
|
||||
<option name="presentableId" value="LOCAL-00004" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705501770457</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00005" summary="Aufgabe 1 ca 80%">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705630515269</created>
|
||||
<option name="number" value="00005" />
|
||||
<option name="presentableId" value="LOCAL-00005" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705630515269</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00006" summary="Aufgabe 1">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705673592045</created>
|
||||
<option name="number" value="00006" />
|
||||
<option name="presentableId" value="LOCAL-00006" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705673592045</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00007" summary="Bewertungs model">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705675225498</created>
|
||||
<option name="number" value="00007" />
|
||||
<option name="presentableId" value="LOCAL-00007" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705675225498</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00008" summary="Alles bis auf paar sachen">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705679416721</created>
|
||||
<option name="number" value="00008" />
|
||||
<option name="presentableId" value="LOCAL-00008" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705679416721</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00009" summary="Alles bis auf paar sachen">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705682140622</created>
|
||||
<option name="number" value="00009" />
|
||||
<option name="presentableId" value="LOCAL-00009" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705682140622</updated>
|
||||
</task>
|
||||
<task id="LOCAL-00010" summary="Alles">
|
||||
<option name="closed" value="true" />
|
||||
<created>1705683562748</created>
|
||||
<option name="number" value="00010" />
|
||||
<option name="presentableId" value="LOCAL-00010" />
|
||||
<option name="project" value="LOCAL" />
|
||||
<updated>1705683562748</updated>
|
||||
</task>
|
||||
<option name="localTasksCounter" value="11" />
|
||||
<servers />
|
||||
</component>
|
||||
<component name="TypeScriptGeneratedFilesManager">
|
||||
<option name="version" value="3" />
|
||||
</component>
|
||||
<component name="VcsManagerConfiguration">
|
||||
<MESSAGE value="Webseite ohne Anmeldung läuft auf laravel" />
|
||||
<MESSAGE value="Anmeldung läuft" />
|
||||
<MESSAGE value="Abmeldung gefixt" />
|
||||
<MESSAGE value="Aufgabe 1 ca 80%" />
|
||||
<MESSAGE value="Aufgabe 1" />
|
||||
<MESSAGE value="Bewertungs model" />
|
||||
<MESSAGE value="Alles bis auf paar sachen" />
|
||||
<MESSAGE value="Alles" />
|
||||
<option name="LAST_COMMIT_MESSAGE" value="Alles" />
|
||||
</component>
|
||||
</project>
|
||||
BIN
Buch1.xlsx
Normal file
BIN
M1/Werbeseite/fh-logo.jpg
Normal file
|
After Width: | Height: | Size: 64 KiB |
203
M1/Werbeseite/index.html
Normal file
@@ -0,0 +1,203 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en" xmlns="http://www.w3.org/1999/html">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Ihre E-Mensa</title>
|
||||
<style>
|
||||
* {
|
||||
font-family: Arial;
|
||||
}
|
||||
|
||||
.grid {
|
||||
display: grid;
|
||||
grid-template-columns: 200px auto 200px;
|
||||
}
|
||||
|
||||
img {
|
||||
width: 100%;
|
||||
height: auto;
|
||||
}
|
||||
|
||||
.speisen {
|
||||
border: solid;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
.speisen td {
|
||||
border: solid;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
.speisen td:not(:first-of-type) {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
p {
|
||||
text-align: justify;
|
||||
}
|
||||
|
||||
.zahlen {
|
||||
list-style-type: none;
|
||||
display: grid;
|
||||
grid-template-columns: auto auto auto;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.zahlen p {
|
||||
text-align: center;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.formular {
|
||||
display: grid;
|
||||
grid-template-columns: auto auto auto;
|
||||
justify-content: start;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.wichtig {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.wichtigListe {
|
||||
display: inline-block;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.freude {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
footer {
|
||||
border-top: 1px solid;
|
||||
}
|
||||
|
||||
.fusszeile {
|
||||
padding-top: 20px;
|
||||
padding-bottom: 20px;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
border: none;
|
||||
}
|
||||
|
||||
.fusszeile td:first-child {
|
||||
border-left: none;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
.fusszeile td {
|
||||
border-left: 3px solid;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
</style>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
<div class="grid">
|
||||
<div>
|
||||
<img src="fh-logo.jpg" alt="FH-Logo">
|
||||
</div>
|
||||
<div>
|
||||
<a href="#ankündigung">Ankündigung</a>
|
||||
<a href="#speisen">Speisen</a>
|
||||
<a href="#zahlen">Zahlen</a>
|
||||
<a href="#kontakt">Kontakt</a>
|
||||
<a href="#wichtig">Wichtig für uns</a>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<hr>
|
||||
<div class="grid">
|
||||
<div></div>
|
||||
<div>
|
||||
<img src="mensa21.jpg" alt="Essen">
|
||||
<h1 id="ankündigung">Bald gibt es auch Essen online ;)</h1>
|
||||
<p>Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et
|
||||
dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet
|
||||
clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet,
|
||||
consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat,
|
||||
sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no
|
||||
sea takimata sanctus est Lorem ipsum dolor sit amet.</p>
|
||||
<h1 id="speisen">Köstlichkeiten die Sie erwarten</h1>
|
||||
<table class="speisen">
|
||||
<tr class="speisen">
|
||||
<td></td>
|
||||
<td>Preis intern</td>
|
||||
<td>Preis extern</td>
|
||||
</tr>
|
||||
<tr class="speisen">
|
||||
<td>Rindfleich mit Bambus, Kaiserschoten und roter Paprika, dazu Mie Nudeln</td>
|
||||
<td>3,50</td>
|
||||
<td>6,20</td>
|
||||
</tr>
|
||||
<tr class="speisen">
|
||||
<td>Spinatrisotto mit kleinen Samosateigecken und gemischter Salat</td>
|
||||
<td>2,90</td>
|
||||
<td>5,30</td>
|
||||
</tr>
|
||||
<tr class="speisen">
|
||||
<td>...</td>
|
||||
<td>...</td>
|
||||
<td>...</td>
|
||||
</tr>
|
||||
</table>
|
||||
<h1 id="zahlen">E-Mensa in Zahlen</h1>
|
||||
<div class="zahlen">
|
||||
<p>X Besuche</p>
|
||||
<p>Y Anmeldungen zum Newsletter</p>
|
||||
<p>Z Speisen</p>
|
||||
</div>
|
||||
<h1 id="kontakt">Interesse geweckt? Wir informieren</h1>
|
||||
<div class="formular">
|
||||
<div>
|
||||
<label for="name">Name</label> <br>
|
||||
<input type="text" name="name" id="name" placeholder="Bitte geben Sie Ihren Namen ein">
|
||||
</div>
|
||||
<div>
|
||||
<label for="mail">E-Mail</label> <br>
|
||||
<input type="text" name="name" id="mail" placeholder="Bitte geben Sie Ihren Namen ein">
|
||||
</div>
|
||||
<div>
|
||||
<label for="sprache">Newsletter bitte in</label> <br>
|
||||
<select name="sprache" id="sprache">
|
||||
<option value="deutsch">Deutsch</option>
|
||||
<option value="englisch">Englisch</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<br>
|
||||
<input required type="checkbox" name="datenschutz" id="datenschutz"
|
||||
placeholder="Bitte geben Sie Ihren Namen ein">
|
||||
<label for="datenschutz">Den Datenschutzbestimmungen stimme ich zu</label>
|
||||
<button type="submit">Zum Newsletter anmelden</button>
|
||||
<h1 id="wichtig">Das ist uns wichtig</h1>
|
||||
<div class="wichtig">
|
||||
<ul class="wichtigListe">
|
||||
<li>Beste frische saisonale Zutaten</li>
|
||||
<li>Ausgewogen abwechslungsreiche Gerichte</li>
|
||||
<li>Sauberkeit</li>
|
||||
</ul>
|
||||
</div>
|
||||
<h1 class="freude">Wir freuen uns auf Ihren Besuch!</h1>
|
||||
</div>
|
||||
</div>
|
||||
<footer>
|
||||
<table class="fusszeile">
|
||||
<tr>
|
||||
<td>(c) E-Mensa GmbH</td>
|
||||
<td>Şafak Hazinedar & Robert Joel</td>
|
||||
<td><a href="">Impressum</a></td>
|
||||
</tr>
|
||||
</table>
|
||||
</footer>
|
||||
</body>
|
||||
|
||||
</html>
|
||||
BIN
M1/Werbeseite/mensa21.jpg
Normal file
|
After Width: | Height: | Size: 153 KiB |
132
M1/beispiele/css_table.html
Normal file
@@ -0,0 +1,132 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>CSS Übung</title>
|
||||
<style>
|
||||
* {
|
||||
font-family: Arial;
|
||||
}
|
||||
|
||||
a {
|
||||
color: darkorange;
|
||||
font-weight: bold;
|
||||
text-decoration-line: none;
|
||||
}
|
||||
|
||||
p.center {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
table {
|
||||
border: 3px solid #ecc3a4;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
}
|
||||
|
||||
td {
|
||||
border: 1px solid white;
|
||||
}
|
||||
|
||||
thead tr th {
|
||||
background: #faebd7;
|
||||
}
|
||||
|
||||
tbody tr:nth-child(even) {
|
||||
background: #faebd7;
|
||||
}
|
||||
|
||||
ol {
|
||||
line-height: 40px;
|
||||
}
|
||||
|
||||
footer {
|
||||
border-top: 3px solid #ecc3a4;
|
||||
}
|
||||
|
||||
ul {
|
||||
float: right;
|
||||
}
|
||||
|
||||
ul li {
|
||||
display: inline;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
ul li:not(:first-child) {
|
||||
border-left: 3px solid #ecc3a4;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<main>
|
||||
<div class="elektro zeile">
|
||||
<h1 id="elektro">Wofür steht das E in E-Mensa?</h1>
|
||||
<p>Am besten zeigt man das in einer <a href="#etabelle">Tabelle</a>.</p>
|
||||
<table id="etabelle">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Bedeutung</th>
|
||||
<th>Philosophie</th>
|
||||
<th>Beispiele</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr>
|
||||
<td>Elektro</td>
|
||||
<td>Alles geht elektronisch</td>
|
||||
<td>
|
||||
<ol>
|
||||
<li class="pflicht">Bestellung digital</li>
|
||||
<li class="pflicht">Bezahlen digital</li>
|
||||
<li>Essen digital</li>
|
||||
<li>Spülen digital</li>
|
||||
</ol>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Extravagant</td>
|
||||
<td>Es gibt auch Ausgefallenes</td>
|
||||
<td><p>Wir sind die einzige Mensa weit und breit mit </p>
|
||||
<ol>
|
||||
<li class="pflicht">Vanillesauerkraut</li>
|
||||
<li class="pflicht">Bohnensenfbrot</li>
|
||||
<li>Habaneroeiscreme</li>
|
||||
<li>Bananengulasch</li>
|
||||
</ol>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Effizient</td>
|
||||
<td>Schnell, lecker und qualitativ</td>
|
||||
<td>
|
||||
<ol>
|
||||
<li class="pflicht">Frisch für Sie zubereitet, wann Sie es wollen</li>
|
||||
<li class="pflicht">Die Zutaten sind nachverfolgbar und immer tiefgekühlt</li>
|
||||
<li>Wir haben auch Samstags geöffnet. Sie sehen, wie effizient wir sind.</li>
|
||||
</ol>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<p class="center">Da geht natürlich noch viel mehr, siehe nur <abbr title="Extra">E</abbr>.<br>Die Tabelle ist
|
||||
aber schon ganz schön imposant so oder?</p>
|
||||
</div>
|
||||
</main>
|
||||
<footer>
|
||||
<ul>
|
||||
<li>(c) DBWT</li>
|
||||
<li>Hilfe</li>
|
||||
<li>Datenschutz</li>
|
||||
<li>Impressum</li>
|
||||
</ul>
|
||||
</footer>
|
||||
</body>
|
||||
</html>
|
||||
BIN
M1/beispiele/img.png
Normal file
|
After Width: | Height: | Size: 30 KiB |
BIN
M1/beispiele/logo-FH.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
50
M1/beispiele/m1_4a_textauszeichnung.html
Normal file
@@ -0,0 +1,50 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Title</title>
|
||||
</head>
|
||||
<body>
|
||||
Listen
|
||||
<ol>
|
||||
<li>a</li>
|
||||
<li>b</li>
|
||||
<li>c</li>
|
||||
</ol>
|
||||
<ul>
|
||||
<li>a</li>
|
||||
<li>b</li>
|
||||
<li>c</li>
|
||||
</ul>
|
||||
Schriften
|
||||
<br>
|
||||
<b>Fett</b>
|
||||
<i>Kursiv</i>
|
||||
<s>durchgestriche</s>
|
||||
<br>
|
||||
Linie
|
||||
<hr>
|
||||
<br>
|
||||
Überschriften
|
||||
<h1>H1</h1>
|
||||
<h2>H2</h2>
|
||||
<h3>H3</h3>
|
||||
<h4>H4</h4>
|
||||
<br>
|
||||
Exponent & Indizes
|
||||
<br>
|
||||
x<sup>2</sup> x<sub>2</sub>
|
||||
<br>
|
||||
Sonderzeichen
|
||||
<br>
|
||||
& < > "
|
||||
<br>
|
||||
Paragraph
|
||||
<p>Lorem Ipsum</p>
|
||||
</body>
|
||||
</html>
|
||||
44
M1/beispiele/m1_4b_tabelle.html
Normal file
@@ -0,0 +1,44 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Tabelle</title>
|
||||
</head>
|
||||
<body>
|
||||
<table border="solid">
|
||||
<tr>
|
||||
<th>Art</th>
|
||||
<th>Gericht</th>
|
||||
<th>Preis</th>
|
||||
<th>Werktag</th>
|
||||
<th>Wochenende</th>
|
||||
<th>Inhaltsstoffe</th>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Vegetarisch</td>
|
||||
<td>Kürbis-Chai-Teller</td>
|
||||
<td>2,10€</td>
|
||||
<td rowspan="2" colspan="2">Ganze Woche</td>
|
||||
<td></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td rowspan="2">Pasta</td>
|
||||
<td>Spaghetti Carciofo</td>
|
||||
<td>3,50€</td>
|
||||
<td>A,A1</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>Bandnudeln</td>
|
||||
<td>3,50€</td>
|
||||
<td></td>
|
||||
<td>x</td>
|
||||
<td>A, D, A1</td>
|
||||
</tr>
|
||||
</table>
|
||||
</body>
|
||||
</html>
|
||||
15
M1/beispiele/m1_4c_bild.html
Normal file
@@ -0,0 +1,15 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Bild</title>
|
||||
</head>
|
||||
<body>
|
||||
<img src="logo-FH.png" alt="FH-Logo">
|
||||
</body>
|
||||
</html>
|
||||
19
M1/beispiele/m1_4d_links.html
Normal file
@@ -0,0 +1,19 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Links</title>
|
||||
</head>
|
||||
<body>
|
||||
<a href="https://www.fh-aachen.de/">FH Aachen</a>
|
||||
<br>
|
||||
<a href="https://www.fh-aachen.de/" target="_blank">FH Aachen</a>
|
||||
<br>
|
||||
<a href="mailto:safak.hazinedar@alumni.fh-aachen.de">E-Mail</a>
|
||||
</body>
|
||||
</html>
|
||||
38
M1/beispiele/m1_4e_spandiv.html
Normal file
@@ -0,0 +1,38 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Span Div</title>
|
||||
</head>
|
||||
<body>
|
||||
<!-- <span style="background: beige"> -->
|
||||
<div style="color: darkorange">
|
||||
<p>
|
||||
<span style="background: aqua">Lorem ipsum dolor sit amet, consetetur sadipscing elitr,
|
||||
sed diam nonumy eirmod tempor invidunt ut labore et dolore
|
||||
magna aliquyam erat, sed diam voluptua. </span> At vero eos et accusam
|
||||
et justo duo dolores et ea rebum. Stet clita kasd gubergren,
|
||||
no sea takimata sanctus est Lorem ipsum dolor sit amet.
|
||||
</p>
|
||||
<p>
|
||||
Lorem ipsum dolor sit amet, consetetur sadipscing elitr,
|
||||
sed diam nonumy eirmod tempor invidunt ut labore et dolore
|
||||
magna aliquyam erat, sed diam voluptua. At vero eos et accusam
|
||||
et justo duo dolores et ea rebum. Stet clita kasd gubergren,
|
||||
no sea takimata sanctus est Lorem ipsum dolor sit amet.
|
||||
</p>
|
||||
<p>
|
||||
Lorem ipsum dolor sit amet, consetetur sadipscing elitr,
|
||||
sed diam nonumy eirmod tempor invidunt ut labore et dolore
|
||||
magna aliquyam erat, sed diam voluptua. At vero eos et accusam
|
||||
et justo duo dolores et ea rebum. Stet clita kasd gubergren,
|
||||
no sea takimata sanctus est Lorem ipsum dolor sit amet.
|
||||
</p>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
40
M1/beispiele/m1_8a_text.html
Normal file
@@ -0,0 +1,40 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<style>
|
||||
body {
|
||||
font-family: Arial;
|
||||
|
||||
}
|
||||
h1 {
|
||||
text-decoration-line: underline;
|
||||
}
|
||||
.untertitel {
|
||||
font-style: italic;
|
||||
}
|
||||
.haupt {
|
||||
font-weight: bold;
|
||||
}
|
||||
.beilage {
|
||||
font-weight: normal;
|
||||
color: green;
|
||||
}
|
||||
</style>
|
||||
<meta charset="UTF-8">
|
||||
<title>Title</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>Currywurst mit Pommes</h1>
|
||||
<h3 class="untertitel">Der Klassiker</h3>
|
||||
<ul class="haupt">
|
||||
<li>Bratwurst</li>
|
||||
<li class="beilage">Fritten</li>
|
||||
<li>Currysauce</li>
|
||||
</ul>
|
||||
</body>
|
||||
</html>
|
||||
45
M1/beispiele/m1_8b_layout.html
Normal file
@@ -0,0 +1,45 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<style>
|
||||
.grid-container1 {
|
||||
display: grid;
|
||||
grid-template-columns: 100px 100px 100px;
|
||||
justify-content: space-between;
|
||||
}
|
||||
.grid-container2 {
|
||||
display: grid;
|
||||
grid-template-rows: 50px 50px 50px;
|
||||
}
|
||||
.grid-container3 {
|
||||
display: grid;
|
||||
justify-content: center;
|
||||
}
|
||||
.grid-item {
|
||||
background: green;
|
||||
}
|
||||
</style>
|
||||
<meta charset="UTF-8">
|
||||
<title>Grid</title>
|
||||
</head>
|
||||
<body>
|
||||
<div class="grid-container1">
|
||||
<p class="grid-item">Test</p>
|
||||
<p class="grid-item">Test</p>
|
||||
<p class="grid-item">Test</p>
|
||||
</div>
|
||||
<div class="grid-container2">
|
||||
<p class="grid-item">Test</p>
|
||||
<p class="grid-item">Test</p>
|
||||
<p class="grid-item">Test</p>
|
||||
</div>
|
||||
<div class="grid-container3">
|
||||
<p class="grid-item">Test</p>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
15
M1/beispiele/m1_ersteSeite.html
Normal file
@@ -0,0 +1,15 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="de">
|
||||
<head>
|
||||
<title>Werbeseite</title>
|
||||
</head>
|
||||
<body>
|
||||
Inhalt der Werbeseite für die E-Mensa
|
||||
</body>
|
||||
</html>
|
||||
110
M1/beispiele/newsletteranmeldung.html
Normal file
@@ -0,0 +1,110 @@
|
||||
<!--
|
||||
- Praktikum DBWT. Autoren:
|
||||
- Robert, Joel, 3672729
|
||||
- Şafak, Hazinedar, 3108590
|
||||
-->
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Newsletteranmeldung</title>
|
||||
</head>
|
||||
<body>
|
||||
<form method="post" action="formadata.html">
|
||||
<fieldset>
|
||||
<legend>
|
||||
<h1>Anmeldung</h1>
|
||||
</legend>
|
||||
|
||||
<b>Anrede</b><br>
|
||||
|
||||
<input type="radio" name="anrede" value="frau">Frau <br>
|
||||
<input type="radio" name="anrede" value="herr">Herr<br>
|
||||
<br>
|
||||
<label for="vorname"><b>Vorname<sup>*</sup></b></label><br>
|
||||
<input type="text" name="vorname" id="vorname" placeholder="Vorname" required>
|
||||
<br><br>
|
||||
<label for="nachname"><b>Nachname<sup>*</sup></b></label><br>
|
||||
<input type="text" name="nachname" id="nachname" placeholder="Nachname" required>
|
||||
<br>
|
||||
<label for="email"><b>Email<sup>*</sup></b></label><br>
|
||||
<input type="email" name="email" id="email" placeholder="user@email.com" required>
|
||||
|
||||
<br><br>
|
||||
|
||||
<b>Benachrichtigungsinterval</b><br>
|
||||
<select name="interval">
|
||||
<option value="1">Täglich</option>
|
||||
<option value="2" selected>Wöchentlich</option>
|
||||
<option value="3">Monatlich</option>
|
||||
</select>
|
||||
|
||||
<br><br>
|
||||
|
||||
<input type="checkbox" required>Ich habe die Datenschutzhinweise gelesen<sup>*</sup>
|
||||
|
||||
<br><br>
|
||||
|
||||
<input type="submit" value="Zum Newsletter anmelden!">
|
||||
|
||||
<br><br>
|
||||
|
||||
Felder mit * sind Pflicht
|
||||
</fieldset>
|
||||
</form>
|
||||
</body>
|
||||
</html>
|
||||
|
||||
<!--
|
||||
Aufgabe 6
|
||||
Bib
|
||||
Request URL: https://www.fh-aachen.de/fh-aachen/hochschulstruktur/zentrale-betriebseinheiten/bibliothek
|
||||
Request Method: GET
|
||||
Status Code: 200 OK
|
||||
Remote Address: 149.201.122.100:443
|
||||
Referrer Policy: strict-origin-when-cross-origin
|
||||
Cache-Control: max-age=78453
|
||||
Connection: keep-alive
|
||||
Content-Encoding: gzip
|
||||
Content-Language: de Sprache
|
||||
Content-Length: 17579
|
||||
Content-Type: text/html; charset=utf-8
|
||||
Date: Wed, 18 Oct 2023 13:22:53 GMT Zeitpunkt der Anfrage
|
||||
Etag: "34fe7c7dd23fa1091245f8693488dc18"
|
||||
Expires: Thu, 19 Oct 2023 11:10:26 GMT
|
||||
Pragma: public
|
||||
Server: nginx/1.18.0 (Ubuntu)
|
||||
Strict-Transport-Security: max-age=31536000
|
||||
Vary: Accept-Encoding
|
||||
|
||||
Formular
|
||||
|
||||
Request URL: http://localhost:63342/M1/M1/beispiele/formadata.html
|
||||
Request Method: POST
|
||||
Status Code: 404 Not Found
|
||||
Remote Address: 127.0.0.1:63342
|
||||
Referrer Policy: strict-origin-when-cross-origin
|
||||
Access-Control-Allow-Credentials: true
|
||||
Access-Control-Allow-Origin: http://localhost:63342
|
||||
Content-Length: 92
|
||||
Content-Type: text/html
|
||||
Date: Wed, 18 Oct 2023 13:30:14 GMT
|
||||
Server: PhpStorm 2023.2.2
|
||||
Vary: origin
|
||||
X-Content-Type-Options: nosniff
|
||||
X-Frame-Options: SameOrigin
|
||||
X-Xss-Protection: 1; mode=block
|
||||
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8
|
||||
Accept-Encoding: gzip, deflate, br
|
||||
Accept-Language: de-DE,de
|
||||
Cache-Control: max-age=0
|
||||
Connection: keep-alive
|
||||
Content-Length: 67
|
||||
Content-Type: application/x-www-form-urlencoded
|
||||
Cookie: Phpstorm-dabb33c1=6794e646-30f2-42e3-ac04-b05acb4f79a9
|
||||
Dnt: 1
|
||||
Host: localhost:63342
|
||||
Origin: http://localhost:63342
|
||||
Referer: http://localhost:63342/M1/M1/beispiele/newsletteranmeldung.html?_ijt=dk0nu23t2f8uk826fkcqu2n7fn&_ij_reload=RELOAD_ON_SAVE
|
||||
|
||||
-->
|
||||
BIN
M1/dossier.xlsx
Normal file
@@ -1,10 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Title</title>
|
||||
</head>
|
||||
<body>
|
||||
Hello World
|
||||
</body>
|
||||
</html>
|
||||
1
M2/.idea/php.xml
generated
@@ -10,6 +10,7 @@
|
||||
<option name="highlightLevel" value="WARNING" />
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PhpProjectSharedConfiguration" php_language_level="8.0" />
|
||||
<component name="PhpStanOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
|
||||
210
M2/.idea/shelf/Uncommitted_changes_before_Checkout_at_15_11_2023_12_24_[Changes]/shelved.patch
generated
Normal file
@@ -0,0 +1,210 @@
|
||||
Index: ../M1/.idea/vcs.xml
|
||||
===================================================================
|
||||
diff --git a/../M1/.idea/vcs.xml b/../M1/.idea/vcs.xml
|
||||
deleted file mode 100644
|
||||
--- a/../M1/.idea/vcs.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,6 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<project version="4">
|
||||
- <component name="VcsDirectoryMappings">
|
||||
- <mapping directory="$PROJECT_DIR$/.." vcs="Git" />
|
||||
- </component>
|
||||
-</project>
|
||||
\ No newline at end of file
|
||||
Index: ../M1/.idea/.gitignore
|
||||
===================================================================
|
||||
diff --git a/../M1/.idea/.gitignore b/../M1/.idea/.gitignore
|
||||
deleted file mode 100644
|
||||
--- a/../M1/.idea/.gitignore (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-# Default ignored files
|
||||
-/shelf/
|
||||
-/workspace.xml
|
||||
-# Editor-based HTTP Client requests
|
||||
-/httpRequests/
|
||||
-# Datasource local storage ignored files
|
||||
-/dataSources/
|
||||
-/dataSources.local.xml
|
||||
Index: ../.idea/modules.xml
|
||||
===================================================================
|
||||
diff --git a/../.idea/modules.xml b/../.idea/modules.xml
|
||||
deleted file mode 100644
|
||||
--- a/../.idea/modules.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<project version="4">
|
||||
- <component name="ProjectModuleManager">
|
||||
- <modules>
|
||||
- <module fileurl="file://$PROJECT_DIR$/.idea/DBWT-Praktika.iml" filepath="$PROJECT_DIR$/.idea/DBWT-Praktika.iml" />
|
||||
- </modules>
|
||||
- </component>
|
||||
-</project>
|
||||
\ No newline at end of file
|
||||
Index: ../M1/.idea/M1.iml
|
||||
===================================================================
|
||||
diff --git a/../M1/.idea/M1.iml b/../M1/.idea/M1.iml
|
||||
deleted file mode 100644
|
||||
--- a/../M1/.idea/M1.iml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<module type="WEB_MODULE" version="4">
|
||||
- <component name="NewModuleRootManager">
|
||||
- <content url="file://$MODULE_DIR$" />
|
||||
- <orderEntry type="inheritedJdk" />
|
||||
- <orderEntry type="sourceFolder" forTests="false" />
|
||||
- </component>
|
||||
-</module>
|
||||
\ No newline at end of file
|
||||
Index: ../.idea/php.xml
|
||||
===================================================================
|
||||
diff --git a/../.idea/php.xml b/../.idea/php.xml
|
||||
deleted file mode 100644
|
||||
--- a/../.idea/php.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,20 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<project version="4">
|
||||
- <component name="MessDetectorOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PHPCSFixerOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PHPCodeSnifferOptionsConfiguration">
|
||||
- <option name="highlightLevel" value="WARNING" />
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PhpProjectSharedConfiguration" php_language_level="8.2" />
|
||||
- <component name="PhpStanOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PsalmOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
-</project>
|
||||
\ No newline at end of file
|
||||
Index: ../.idea/DBWT-Praktika.iml
|
||||
===================================================================
|
||||
diff --git a/../.idea/DBWT-Praktika.iml b/../.idea/DBWT-Praktika.iml
|
||||
deleted file mode 100644
|
||||
--- a/../.idea/DBWT-Praktika.iml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<module type="WEB_MODULE" version="4">
|
||||
- <component name="NewModuleRootManager">
|
||||
- <content url="file://$MODULE_DIR$" />
|
||||
- <orderEntry type="inheritedJdk" />
|
||||
- <orderEntry type="sourceFolder" forTests="false" />
|
||||
- </component>
|
||||
-</module>
|
||||
\ No newline at end of file
|
||||
Index: ../M1/.idea/php.xml
|
||||
===================================================================
|
||||
diff --git a/../M1/.idea/php.xml b/../M1/.idea/php.xml
|
||||
deleted file mode 100644
|
||||
--- a/../M1/.idea/php.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,19 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<project version="4">
|
||||
- <component name="MessDetectorOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PHPCSFixerOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PHPCodeSnifferOptionsConfiguration">
|
||||
- <option name="highlightLevel" value="WARNING" />
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PhpStanOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
- <component name="PsalmOptionsConfiguration">
|
||||
- <option name="transferred" value="true" />
|
||||
- </component>
|
||||
-</project>
|
||||
\ No newline at end of file
|
||||
Index: ../.idea/.gitignore
|
||||
===================================================================
|
||||
diff --git a/../.idea/.gitignore b/../.idea/.gitignore
|
||||
deleted file mode 100644
|
||||
--- a/../.idea/.gitignore (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-# Default ignored files
|
||||
-/shelf/
|
||||
-/workspace.xml
|
||||
-# Editor-based HTTP Client requests
|
||||
-/httpRequests/
|
||||
-# Datasource local storage ignored files
|
||||
-/dataSources/
|
||||
-/dataSources.local.xml
|
||||
Index: .idea/.gitignore
|
||||
===================================================================
|
||||
diff --git a/.idea/.gitignore b/.idea/.gitignore
|
||||
deleted file mode 100644
|
||||
--- a/.idea/.gitignore (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-# Default ignored files
|
||||
-/shelf/
|
||||
-/workspace.xml
|
||||
-# Editor-based HTTP Client requests
|
||||
-/httpRequests/
|
||||
-# Datasource local storage ignored files
|
||||
-/dataSources/
|
||||
-/dataSources.local.xml
|
||||
Index: ../M1/.idea/modules.xml
|
||||
===================================================================
|
||||
diff --git a/../M1/.idea/modules.xml b/../M1/.idea/modules.xml
|
||||
deleted file mode 100644
|
||||
--- a/../M1/.idea/modules.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,8 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<project version="4">
|
||||
- <component name="ProjectModuleManager">
|
||||
- <modules>
|
||||
- <module fileurl="file://$PROJECT_DIR$/.idea/M1.iml" filepath="$PROJECT_DIR$/.idea/M1.iml" />
|
||||
- </modules>
|
||||
- </component>
|
||||
-</project>
|
||||
\ No newline at end of file
|
||||
Index: ../.idea/vcs.xml
|
||||
===================================================================
|
||||
diff --git a/../.idea/vcs.xml b/../.idea/vcs.xml
|
||||
deleted file mode 100644
|
||||
--- a/../.idea/vcs.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ /dev/null (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
@@ -1,6 +0,0 @@
|
||||
-<?xml version="1.0" encoding="UTF-8"?>
|
||||
-<project version="4">
|
||||
- <component name="VcsDirectoryMappings">
|
||||
- <mapping directory="" vcs="Git" />
|
||||
- </component>
|
||||
-</project>
|
||||
\ No newline at end of file
|
||||
Index: .idea/php.xml
|
||||
IDEA additional info:
|
||||
Subsystem: com.intellij.openapi.diff.impl.patch.BaseRevisionTextPatchEP
|
||||
<+><?xml version=\"1.0\" encoding=\"UTF-8\"?>\r\n<project version=\"4\">\r\n <component name=\"MessDetectorOptionsConfiguration\">\r\n <option name=\"transferred\" value=\"true\" />\r\n </component>\r\n <component name=\"PHPCSFixerOptionsConfiguration\">\r\n <option name=\"transferred\" value=\"true\" />\r\n </component>\r\n <component name=\"PHPCodeSnifferOptionsConfiguration\">\r\n <option name=\"highlightLevel\" value=\"WARNING\" />\r\n <option name=\"transferred\" value=\"true\" />\r\n </component>\r\n <component name=\"PhpProjectSharedConfiguration\" php_language_level=\"8.0\" />\r\n <component name=\"PhpStanOptionsConfiguration\">\r\n <option name=\"transferred\" value=\"true\" />\r\n </component>\r\n <component name=\"PsalmOptionsConfiguration\">\r\n <option name=\"transferred\" value=\"true\" />\r\n </component>\r\n</project>
|
||||
Subsystem: com.intellij.openapi.diff.impl.patch.CharsetEP
|
||||
<+>UTF-8
|
||||
===================================================================
|
||||
diff --git a/.idea/php.xml b/.idea/php.xml
|
||||
--- a/.idea/php.xml (revision 1b5faa0d69e292e2649269e271b773eaad28f5d1)
|
||||
+++ b/.idea/php.xml (date 1700047317911)
|
||||
@@ -10,7 +10,6 @@
|
||||
<option name="highlightLevel" value="WARNING" />
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
- <component name="PhpProjectSharedConfiguration" php_language_level="8.0" />
|
||||
<component name="PhpStanOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
4
M2/.idea/shelf/Uncommitted_changes_before_Checkout_at_15_11_2023_12_24__Changes_.xml
generated
Normal file
@@ -0,0 +1,4 @@
|
||||
<changelist name="Uncommitted_changes_before_Checkout_at_15_11_2023_12_24_[Changes]" date="1700047474245" recycled="true" deleted="true">
|
||||
<option name="PATH" value="$PROJECT_DIR$/.idea/shelf/Uncommitted_changes_before_Checkout_at_15_11_2023_12_24_[Changes]/shelved.patch" />
|
||||
<option name="DESCRIPTION" value="Uncommitted changes before Checkout at 15.11.2023 12:24 [Changes]" />
|
||||
</changelist>
|
||||
62
M2/.idea/workspace.xml
generated
Normal file
@@ -0,0 +1,62 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="AutoImportSettings">
|
||||
<option name="autoReloadType" value="SELECTIVE" />
|
||||
</component>
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" id="3addb60f-b39d-430d-91ac-acb76c147edc" name="Changes" comment="" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ComposerSettings">
|
||||
<execution />
|
||||
</component>
|
||||
<component name="Git.Settings">
|
||||
<option name="RECENT_BRANCH_BY_REPOSITORY">
|
||||
<map>
|
||||
<entry key="$PROJECT_DIR$/.." value="dev/m2_safak" />
|
||||
</map>
|
||||
</option>
|
||||
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$/.." />
|
||||
</component>
|
||||
<component name="PhpWorkspaceProjectConfiguration" interpreter_name="C:\Program Files\php-8.2.11-Win32-vs16-x64\php.exe" />
|
||||
<component name="ProjectColorInfo">{
|
||||
"associatedIndex": 8
|
||||
}</component>
|
||||
<component name="ProjectId" id="2YD5QUlQAhlJaWMg3ierW7DDTbq" />
|
||||
<component name="ProjectViewState">
|
||||
<option name="hideEmptyMiddlePackages" value="true" />
|
||||
<option name="showLibraryContents" value="true" />
|
||||
</component>
|
||||
<component name="PropertiesComponent"><![CDATA[{
|
||||
"keyToString": {
|
||||
"RunOnceActivity.OpenProjectViewOnStart": "true",
|
||||
"RunOnceActivity.ShowReadmeOnStart": "true",
|
||||
"WebServerToolWindowFactoryState": "false",
|
||||
"git-widget-placeholder": "dev/m3__safak",
|
||||
"node.js.detected.package.eslint": "true",
|
||||
"node.js.detected.package.tslint": "true",
|
||||
"node.js.selected.package.eslint": "(autodetect)",
|
||||
"node.js.selected.package.tslint": "(autodetect)",
|
||||
"vue.rearranger.settings.migration": "true"
|
||||
}
|
||||
}]]></component>
|
||||
<component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="application-level" UseSingleDictionary="true" transferred="true" />
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="3addb60f-b39d-430d-91ac-acb76c147edc" name="Changes" comment="" />
|
||||
<created>1700047295160</created>
|
||||
<option name="number" value="Default" />
|
||||
<option name="presentableId" value="Default" />
|
||||
<updated>1700047295160</updated>
|
||||
<workItem from="1700047298386" duration="519000" />
|
||||
<workItem from="1700071102317" duration="599000" />
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
<component name="TypeScriptGeneratedFilesManager">
|
||||
<option name="version" value="3" />
|
||||
</component>
|
||||
</project>
|
||||
21
M2/Beispiele/Test.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<body>
|
||||
<?php
|
||||
$anweisung = 3;
|
||||
switch ($anweisung) {
|
||||
case 1:
|
||||
echo "catch _1_ !";
|
||||
break;
|
||||
case 2:
|
||||
echo "catch _2_ !";
|
||||
break;
|
||||
case 3:
|
||||
echo "catch _3_ !";
|
||||
default:
|
||||
echo "nothing to catch!";
|
||||
break;
|
||||
}
|
||||
?>
|
||||
</body>
|
||||
</html>
|
||||
1
M2/Beispiele/accesslog.txt
Normal file
@@ -0,0 +1 @@
|
||||
07.11.2023 - 13:02 | 127.0.0.1 | Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:109.0) Gecko/20100101 Firefox/119.0
|
||||
4
M2/Beispiele/en.txt
Normal file
@@ -0,0 +1,4 @@
|
||||
Bewertung;Rating
|
||||
Name;Name
|
||||
Begründung;Reason
|
||||
Senden;Send
|
||||
3
M2/Beispiele/erstesphp.php
Normal file
@@ -0,0 +1,3 @@
|
||||
<?php
|
||||
echo "Erstes PHP-Skript <br>";
|
||||
phpinfo();
|
||||
12
M2/Beispiele/m2_5a_standardparameter.php
Normal file
@@ -0,0 +1,12 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
function addieren(int $number1,int $number2=0){
|
||||
return $number1+$number2;
|
||||
}
|
||||
|
||||
?>
|
||||
13
M2/Beispiele/m2_5b_include.php
Normal file
@@ -0,0 +1,13 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
include "m2_5a_standardparameter.php";
|
||||
|
||||
echo addieren(2,3)."<br>";
|
||||
echo addieren(50,10)."<br>";
|
||||
echo addieren(-2,3);
|
||||
?>
|
||||
53
M2/Beispiele/m2_5c_addform.php
Normal file
@@ -0,0 +1,53 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
|
||||
if ($_POST['rechnen'] == 'Addieren') {
|
||||
|
||||
$number1 = $_POST['number1'];
|
||||
$number2 = $_POST['number2'];
|
||||
$ergebnis = $number1 + $number2;
|
||||
|
||||
} elseif ($_POST['rechnen'] == "Multiplizieren") {
|
||||
$number1 = $_POST['number1'];
|
||||
$number2 = $_POST['number2'];
|
||||
$ergebnis = $number1 * $number2;
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="de">
|
||||
<head>
|
||||
<meta charset="UTF-8"/>
|
||||
<title>Addform</title>
|
||||
<style>
|
||||
* {
|
||||
font-family: Arial, serif;
|
||||
}
|
||||
.rating {
|
||||
color: darkgray;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<form action="m2_5c_addform.php" method="post">
|
||||
<label for="number1">Erste Zahl:</label>
|
||||
<input id="number1" type="text" name="number1"/>
|
||||
<label for="number2">Zweite Zahl:</label>
|
||||
<input id="number2" type="text" name="number2"/>
|
||||
|
||||
<input type="Submit" name="rechnen" value="Addieren" />
|
||||
<input type="Submit" name="rechnen" value="Multiplizieren" />
|
||||
|
||||
<?php
|
||||
if(!empty($ergebnis))
|
||||
{
|
||||
echo "<br><br>Ergebnis: ".$ergebnis;
|
||||
}
|
||||
?>
|
||||
</body>
|
||||
</html>
|
||||
67
M2/Beispiele/m2_5d_array.php
Normal file
@@ -0,0 +1,67 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
function missingYear($famousMeals){
|
||||
$years = [];
|
||||
$winneryears = [];
|
||||
$ergebniss = [];
|
||||
for ($i = 0;$i <= 23; $i++){
|
||||
$years[] = 2000+$i;
|
||||
}
|
||||
|
||||
foreach ($famousMeals as $meal){
|
||||
if(gettype($meal["winner"])== "array"){
|
||||
foreach ($meal["winner"]as $year){
|
||||
$winneryears[] = $year;
|
||||
}
|
||||
}else{
|
||||
$winneryears[] = $year;
|
||||
}
|
||||
}
|
||||
|
||||
foreach ($years as $year){
|
||||
$a=0;
|
||||
foreach ($winneryears as $winners){
|
||||
if ($year == $winners){
|
||||
$a = 1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if($a==0){
|
||||
$ergebniss[]=$year;
|
||||
}
|
||||
}
|
||||
echo var_dump($ergebniss);
|
||||
}
|
||||
|
||||
$famousMeals = [
|
||||
1 => ['name' => 'Currywurst mit Pommes',
|
||||
'winner' => [2001, 2003, 2007, 2010, 2020]],
|
||||
2 => ['name' => 'Hähnchencrossies mit Paprikareis',
|
||||
'winner' => [2002, 2004, 2008]],
|
||||
3 => ['name' => 'Spaghetti Bolognese',
|
||||
'winner' => [2011, 2012, 2017]],
|
||||
4 => ['name' => 'Jägerschnitzel mit Pommes',
|
||||
'winner' => 2019]
|
||||
];
|
||||
echo "<ol>";
|
||||
foreach ($famousMeals as $meal){
|
||||
echo "<li>". $meal['name']."<br>";
|
||||
if(gettype($meal["winner"])== "array"){
|
||||
foreach ($meal["winner"]as $year){
|
||||
$dump[] = $year;
|
||||
}
|
||||
}else{
|
||||
$dump[] = $year;
|
||||
}
|
||||
echo implode( ', ', $dump);
|
||||
$dump = null;
|
||||
echo "</li><br>";
|
||||
}
|
||||
echo "</ol>";
|
||||
missingYear($famousMeals);
|
||||
?>
|
||||
16
M2/Beispiele/m2_7a_accesslog.php
Normal file
@@ -0,0 +1,16 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
$ip = $_SERVER['REMOTE_ADDR'];
|
||||
$agent = $_SERVER['HTTP_USER_AGENT'];
|
||||
|
||||
$logFile = fopen("accesslog.txt", "a");
|
||||
$time = time();
|
||||
$datum = date("d.m.Y - H:i", $time);
|
||||
$write = $datum." | ".$ip." | ".$agent."\n";
|
||||
fwrite($logFile, $write);
|
||||
?>
|
||||
46
M2/Beispiele/m2_7b_showtext.php
Normal file
@@ -0,0 +1,46 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
const GET_PARAM_SEARCH_TEXT = 'search_text';
|
||||
|
||||
$searchTerm = "";
|
||||
|
||||
if (!empty($_GET[GET_PARAM_SEARCH_TEXT])) {
|
||||
$searchTerm = $_GET[GET_PARAM_SEARCH_TEXT];
|
||||
|
||||
}
|
||||
|
||||
$enFile = fopen("en.txt", "r");
|
||||
$fileLines = [];
|
||||
while ($line = fgets($enFile)) {
|
||||
$fileLines[] = $line;
|
||||
}
|
||||
|
||||
$found = false;
|
||||
foreach ($fileLines as $line){
|
||||
$lineArray[] = explode(';', $line);
|
||||
$deutsch = $lineArray[0][0];
|
||||
if(strtolower($deutsch)==strtolower($searchTerm)){
|
||||
$found = true;
|
||||
echo $searchTerm." bedeutet ".$lineArray[0][1];
|
||||
}
|
||||
unset($lineArray);
|
||||
}
|
||||
if(!$found){
|
||||
if(!empty($searchTerm)){
|
||||
echo "Das gesuchte Wort ".$searchTerm." ist nicht enthalten";
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
?>
|
||||
|
||||
<form method="get">
|
||||
<label for="search_text">Suche:</label>
|
||||
<input id="search_text" type="text" name="search_text" value=<?php echo $searchTerm?>>
|
||||
<input type="submit" value="Suchen">
|
||||
</form>
|
||||
206
M2/Beispiele/meal.php
Normal file
@@ -0,0 +1,206 @@
|
||||
<?php
|
||||
const GET_PARAM_MIN_STARS = 'search_min_stars';
|
||||
const GET_PARAM_SEARCH_TEXT = 'search_text';
|
||||
const GET_PARAM_SHOW_DESCRIPTION = 'show_description';
|
||||
const GET_PARAM_SPRACHE = 'sprache';
|
||||
const GET_PARAM_TOP_FLOPP = 'top_flopp';
|
||||
/**
|
||||
* List of all allergens.
|
||||
*/
|
||||
$allergens = [
|
||||
11 => 'Gluten',
|
||||
12 => 'Krebstiere',
|
||||
13 => 'Eier',
|
||||
14 => 'Fisch',
|
||||
17 => 'Milch'
|
||||
];
|
||||
|
||||
$meal = [
|
||||
'name' => 'Süßkartoffeltaschen mit Frischkäse und Kräutern gefüllt',
|
||||
'description' => 'Die Süßkartoffeln werden vorsichtig aufgeschnitten und der Frischkäse eingefüllt.',
|
||||
'price_intern' => 2.90,
|
||||
'price_extern' => 3.90,
|
||||
'allergens' => [11, 13],
|
||||
'amount' => 42 // Number of available meals
|
||||
];
|
||||
|
||||
$ratings = [
|
||||
[ 'text' => 'Die Kartoffel ist einfach klasse. Nur die Fischstäbchen schmecken nach Käse. ',
|
||||
'author' => 'Ute U.',
|
||||
'stars' => 2 ],
|
||||
[ 'text' => 'Sehr gut. Immer wieder gerne',
|
||||
'author' => 'Gustav G.',
|
||||
'stars' => 4 ],
|
||||
[ 'text' => 'Der Klassiker für den Wochenstart. Frisch wie immer',
|
||||
'author' => 'Renate R.',
|
||||
'stars' => 4 ],
|
||||
[ 'text' => 'Kartoffel ist gut. Das Grüne ist mir suspekt.',
|
||||
'author' => 'Marta M.',
|
||||
'stars' => 3 ]
|
||||
];
|
||||
|
||||
$dic = [
|
||||
[ "Gericht" => "Gericht",
|
||||
"Allergien" => "Allergien",
|
||||
"Bewertungen" => "Bewertungen (Insgesamt: ",
|
||||
"Text" => "Text",
|
||||
"Sterne" => "Sterne",
|
||||
"Author" => "Author",
|
||||
"Preis" => "Preis",
|
||||
"Gaeste" => "Gäste"
|
||||
],
|
||||
[ "Gericht" => "Meal",
|
||||
"Allergien" => "Allergies",
|
||||
"Bewertungen" => "Review (overall: ",
|
||||
"Text" => "Text",
|
||||
"Sterne" => "Stars",
|
||||
"Author" => "Author",
|
||||
"Preis" => "Price",
|
||||
"Gaeste" => "Guests"
|
||||
]
|
||||
];
|
||||
|
||||
$translation = $dic[0];
|
||||
$language = "de";
|
||||
if (!empty($_GET[GET_PARAM_SPRACHE])){
|
||||
$language = $_GET[GET_PARAM_SPRACHE];
|
||||
}
|
||||
if($language == "en"){$translation = $dic[1];}
|
||||
|
||||
if (empty($_GET[GET_PARAM_SHOW_DESCRIPTION])){
|
||||
$meal['description'] = "";
|
||||
}
|
||||
|
||||
$searchTerm = "";
|
||||
$showRatings = [];
|
||||
if (!empty($_GET[GET_PARAM_SEARCH_TEXT])) {
|
||||
$searchTerm = $_GET[GET_PARAM_SEARCH_TEXT];
|
||||
foreach ($ratings as $rating) {
|
||||
if (strpos(strtolower($rating['text']), strtolower($searchTerm) )!== false) {
|
||||
$showRatings[] = $rating;
|
||||
}
|
||||
}
|
||||
} else if (!empty($_GET[GET_PARAM_MIN_STARS])) {
|
||||
$minStars = $_GET[GET_PARAM_MIN_STARS];
|
||||
foreach ($ratings as $rating) {
|
||||
if ($rating['stars'] >= $minStars) {
|
||||
$showRatings[] = $rating;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
$showRatings = $ratings;
|
||||
}
|
||||
|
||||
if (!empty($_GET[GET_PARAM_TOP_FLOPP])){
|
||||
$flopp = $_GET[GET_PARAM_TOP_FLOPP];
|
||||
if($flopp == "flopp"){
|
||||
unset($showRatings);
|
||||
$showRatings=[];
|
||||
$stars=[];
|
||||
foreach ($ratings as $rating) {
|
||||
$stars[] = $rating["stars"];
|
||||
}
|
||||
$min = min($stars);
|
||||
foreach ($ratings as $rating) {
|
||||
if ($rating['stars'] == $min) {
|
||||
$showRatings[] = $rating;
|
||||
}
|
||||
}
|
||||
}
|
||||
elseif ($flopp == "top"){
|
||||
unset($showRatings);
|
||||
$showRatings=[];
|
||||
$stars=[];
|
||||
foreach ($ratings as $rating) {
|
||||
$stars[] = $rating["stars"];
|
||||
}
|
||||
$min = max($stars);
|
||||
foreach ($ratings as $rating) {
|
||||
if ($rating['stars'] == $min) {
|
||||
$showRatings[] = $rating;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
*:float gibt den return value der Funktion an
|
||||
*/
|
||||
function calcMeanStars (array $ratings) : float {
|
||||
$sum = 0;
|
||||
foreach ($ratings as $rating) {
|
||||
$sum += $rating['stars'] / count($ratings);
|
||||
}
|
||||
return $sum;
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
|
||||
?>
|
||||
<!DOCTYPE html>
|
||||
<html lang="de">
|
||||
<head>
|
||||
<meta charset="UTF-8"/>
|
||||
<title><?php echo $translation["Gericht"].": ". $meal['name']; ?></title>
|
||||
<style>
|
||||
* {
|
||||
font-family: Arial, serif;
|
||||
}
|
||||
.rating {
|
||||
color: darkgray;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<h1><?php echo $translation["Gericht"].": ". $meal['name']; ?></h1>
|
||||
<p><?php echo $meal['description']; ?>
|
||||
</p>
|
||||
|
||||
<h4><?php echo $translation["Preis"].":"?></h4>
|
||||
<p>
|
||||
<?php echo $translation["Preis"]." intern: ".$meal["price_intern"]."€";?> <br>
|
||||
<?php echo $translation["Preis"]." ".$translation["Gaeste"].": ".$meal["price_extern"]."€";?>
|
||||
</p>
|
||||
|
||||
<h4><?php echo $translation["Allergien"].":"?> </h4>
|
||||
<ul>
|
||||
<?php
|
||||
foreach ($meal['allergens'] as $all) {
|
||||
echo "<li>$allergens[$all]</li>";
|
||||
}
|
||||
?>
|
||||
</ul>
|
||||
<h1><?php echo $translation["Bewertungen"].calcMeanStars($ratings); ?>)</h1>
|
||||
<!--Such form in den Bewertungen für den User -->
|
||||
<form method="get">
|
||||
<label for="search_text">Filter:</label>
|
||||
<input id="search_text" type="text" name="search_text" value=<?php echo $searchTerm?>>
|
||||
<input type="submit" value="Suchen">
|
||||
</form>
|
||||
<table class="rating">
|
||||
<thead>
|
||||
<tr>
|
||||
<td><?php echo $translation["Text"]?></td>
|
||||
<td><?php echo $translation["Sterne"]?></td>
|
||||
<td><?php echo $translation["Author"]?></td>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php
|
||||
foreach ($showRatings as $rating) {
|
||||
echo "<tr><td class='rating_text'>{$rating['text']}</td>
|
||||
<td class='rating_stars'>{$rating['stars']}</td>
|
||||
<td class='rating_author'>{$rating['author']}</td>
|
||||
</tr>";
|
||||
}
|
||||
?>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<br>
|
||||
<br>
|
||||
<a href="?sprache=de">Deutsch</a> oder <a href="?sprache=en">English</a>
|
||||
</body>
|
||||
</html>
|
||||
@@ -1,10 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Title</title>
|
||||
</head>
|
||||
<body>
|
||||
Test
|
||||
</body>
|
||||
</html>
|
||||
1
M2/Werbeseite/besucher.txt
Normal file
@@ -0,0 +1 @@
|
||||
64
|
||||
BIN
M2/Werbeseite/fh-logo.jpg
Normal file
|
After Width: | Height: | Size: 64 KiB |
31
M2/Werbeseite/gerichte.php
Normal file
@@ -0,0 +1,31 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
|
||||
$gerichte = [
|
||||
1 => ['name' => 'Rindfleich mit Bambus, Kaiserschoten und roter Paprika, dazu Mie Nudeln',
|
||||
'priceint' => 3.50,
|
||||
"priceex" => 6.20,
|
||||
"img" =>"img/bambus.jpg"
|
||||
],
|
||||
2 => ['name' => 'Spinatrisotto mit kleinen Samosateigecken und gemischter Salat',
|
||||
'priceint' => 2.90,
|
||||
"priceex" => 5.30,
|
||||
"img" =>"img/risotto.jpg"
|
||||
],
|
||||
3 => ['name' => 'Spaghetti Bolognese',
|
||||
'priceint' => 3,
|
||||
"priceex" => 5,
|
||||
"img" =>"img/bolo.jpg"
|
||||
],
|
||||
4 => ['name' => 'Spaghetti Carbonara',
|
||||
'priceint' => 3,
|
||||
"priceex" => 5,
|
||||
"img" =>"img/carbonara.jpg"
|
||||
]
|
||||
]
|
||||
?>
|
||||
BIN
M2/Werbeseite/img/bambus.jpg
Normal file
|
After Width: | Height: | Size: 1.6 MiB |
BIN
M2/Werbeseite/img/bolo.jpg
Normal file
|
After Width: | Height: | Size: 1.1 MiB |
BIN
M2/Werbeseite/img/carbonara.jpg
Normal file
|
After Width: | Height: | Size: 139 KiB |
BIN
M2/Werbeseite/img/risotto.jpg
Normal file
|
After Width: | Height: | Size: 103 KiB |
308
M2/Werbeseite/index.php
Normal file
@@ -0,0 +1,308 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
include "gerichte.php";
|
||||
|
||||
$besucherCount = 0;
|
||||
$newletterCount = 0;
|
||||
|
||||
//Besucher counter
|
||||
if (file_exists("besucher.txt")) {
|
||||
$besucherFile = fopen("besucher.txt", "r");
|
||||
$besucherCount = fgets($besucherFile) + 1;
|
||||
fclose($besucherFile);
|
||||
$besucherFile = fopen("besucher.txt", "w");
|
||||
fwrite($besucherFile, $besucherCount);
|
||||
fclose($besucherFile);
|
||||
} else {
|
||||
$besucherFile = fopen("besucher.txt", "w");
|
||||
fwrite($besucherFile, 1);
|
||||
fclose($besucherFile);
|
||||
}
|
||||
|
||||
//Newletter counter
|
||||
if (file_exists("newletter.txt")) {
|
||||
$newsFile = fopen("newletter.txt", "r");
|
||||
$newletterCount = fgets($newsFile);
|
||||
fclose($newsFile);
|
||||
} else {
|
||||
$newsFile = fopen("newletter.txt", "w");
|
||||
fwrite($newsFile, 0);
|
||||
fclose($newsFile);
|
||||
}
|
||||
|
||||
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
|
||||
$name = $_POST['name'];
|
||||
$email = $_POST['email'];
|
||||
$language = $_POST['language'];
|
||||
$terms = $_POST['terms'];
|
||||
|
||||
$errors = array();
|
||||
|
||||
if (empty(trim($name))) {
|
||||
$errors[] = "Bitte geben Sie einen Namen ein.";
|
||||
}
|
||||
|
||||
if (!isset($terms)) {
|
||||
$errors[] = "Bitte stimmen Sie den Datenschutzbestimmungen zu.";
|
||||
}
|
||||
|
||||
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
|
||||
$errors[] = "Bitte geben Sie eine gültige E-Mail-Adresse ein.";
|
||||
}
|
||||
|
||||
$spam_domains = array("rcpt.at", "damnthespam.at", "wegwerfmail.de", "trashmail");
|
||||
|
||||
foreach ($spam_domains as $domain) {
|
||||
if (str_contains($email, $domain)) {
|
||||
$errors[] = "Bitte geben Sie eine gültige E-Mail-Adresse ein, keine Wegwerf- oder Spam-E-Mail-Adresse.";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (empty($errors)) {
|
||||
$data = array(
|
||||
"name" => $name,
|
||||
"email" => $email,
|
||||
"language" => $language,
|
||||
"terms" => $terms
|
||||
);
|
||||
|
||||
$file = "subscriptions.json";
|
||||
$current_data = file_exists($file) ? json_decode(file_get_contents($file), true) : array();
|
||||
$current_data[] = $data;
|
||||
|
||||
if (file_put_contents($file, json_encode($current_data))) {
|
||||
echo '<script type="text/javascript">';
|
||||
echo 'alert("Vielen Dank für Ihre Anmeldung zum Newsletter.");';
|
||||
echo '</script>';
|
||||
|
||||
//Newsletter counter
|
||||
$newletterCount++;
|
||||
$newsFile = fopen("newletter.txt", "w");
|
||||
fwrite($newsFile, $newletterCount);
|
||||
fclose($newsFile);
|
||||
} else {
|
||||
echo '<script type="text/javascript">';
|
||||
echo 'alert("Es gab einen Fehler bei Ihrer Anmeldung. Bitte versuchen Sie es erneut.");';
|
||||
echo '</script>';
|
||||
}
|
||||
} else {
|
||||
$error_string = "";
|
||||
foreach ($errors as $error) {
|
||||
$error_string .= $error . '\n';
|
||||
}
|
||||
|
||||
echo '<script type="text/javascript">';
|
||||
echo 'alert("' . $error_string . '");';
|
||||
echo '</script>';
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
||||
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="en" xmlns="http://www.w3.org/1999/html">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Ihre E-Mensa</title>
|
||||
<style>
|
||||
* {
|
||||
font-family: Arial;
|
||||
}
|
||||
|
||||
.grid {
|
||||
display: grid;
|
||||
grid-template-columns: 200px auto 200px;
|
||||
}
|
||||
|
||||
img {
|
||||
width: 100%;
|
||||
height: auto;
|
||||
}
|
||||
|
||||
.speisen {
|
||||
border: solid;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
.speisen td {
|
||||
border: solid;
|
||||
border-collapse: collapse;
|
||||
border-radius: 4px;
|
||||
padding: 5px;
|
||||
width: 150px;
|
||||
}
|
||||
|
||||
.speisen td:not(:first-of-type) {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
p {
|
||||
text-align: justify;
|
||||
}
|
||||
|
||||
.zahlen {
|
||||
list-style-type: none;
|
||||
display: grid;
|
||||
grid-template-columns: auto auto auto;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.zahlen p {
|
||||
text-align: center;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.formular {
|
||||
display: grid;
|
||||
grid-template-columns: auto auto auto;
|
||||
justify-content: start;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.wichtig {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.wichtigListe {
|
||||
display: inline-block;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.freude {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
footer {
|
||||
border-top: 1px solid;
|
||||
}
|
||||
|
||||
.fusszeile {
|
||||
padding-top: 20px;
|
||||
padding-bottom: 20px;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
border: none;
|
||||
}
|
||||
|
||||
.fusszeile td:first-child {
|
||||
border-left: none;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
.fusszeile td {
|
||||
border-left: 3px solid;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
</style>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
<div class="grid">
|
||||
<div>
|
||||
<img src="fh-logo.jpg" alt="FH-Logo">
|
||||
</div>
|
||||
<div>
|
||||
<a href="#ankündigung">Ankündigung</a>
|
||||
<a href="#speisen">Speisen</a>
|
||||
<a href="#zahlen">Zahlen</a>
|
||||
<a href="#kontakt">Kontakt</a>
|
||||
<a href="#wichtig">Wichtig für uns</a>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<hr>
|
||||
<div class="grid">
|
||||
<div></div>
|
||||
<div>
|
||||
<img src="mensa21.jpg" alt="Essen">
|
||||
<h1 id="ankündigung">Bald gibt es auch Essen online ;)</h1>
|
||||
<p>Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et
|
||||
dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet
|
||||
clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet,
|
||||
consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat,
|
||||
sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no
|
||||
sea takimata sanctus est Lorem ipsum dolor sit amet.</p>
|
||||
<h1 id="speisen">Köstlichkeiten die Sie erwarten</h1>
|
||||
<table class="speisen">
|
||||
|
||||
<tr class="speisen">
|
||||
<td>Gerichte</td>
|
||||
<td>Preis intern</td>
|
||||
<td>Preis extern</td>
|
||||
<td>Bild</td>
|
||||
</tr>
|
||||
<?php
|
||||
/**
|
||||
* Speisekarte
|
||||
*/
|
||||
foreach ($gerichte as $gericht) {
|
||||
echo "<tr class=\"speisen\"><td>" . $gericht["name"] . "</td><td>" . $gericht["priceint"] . "</td><td>" . $gericht["priceex"] . "</td><td><img src=" . $gericht["img"] . " alt=" . $gericht["name"] . ">";
|
||||
}
|
||||
?>
|
||||
</table>
|
||||
<h1 id="zahlen">E-Mensa in Zahlen</h1>
|
||||
<div class="zahlen">
|
||||
<p><?php echo $besucherCount; ?> Besuche</p>
|
||||
<p><?php echo $newletterCount; ?> Anmeldungen zum Newsletter</p>
|
||||
<p><?php echo count($gerichte); ?> Speisen</p>
|
||||
</div>
|
||||
<h1 id="kontakt">Interesse geweckt? Wir informieren</h1>
|
||||
|
||||
<form method="post">
|
||||
<div class="formular">
|
||||
<div>
|
||||
<label for="name">Name:</label> <br>
|
||||
<input type="text" name="name" id="name" placeholder="Bitte geben Sie Ihren Namen ein">
|
||||
</div>
|
||||
<div>
|
||||
<label for="email">E-Mail:</label> <br>
|
||||
<input type="email" name="email" id="email" placeholder="Bitte geben Sie Ihre E-Mail ein">
|
||||
</div>
|
||||
<div>
|
||||
<label for="language">Newsletter bitte in:</label> <br>
|
||||
<select name="language" id="language">
|
||||
<option value="deutsch">Deutsch</option>
|
||||
<option value="englisch">Englisch</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<br>
|
||||
<input required type="checkbox" name="terms" id="terms">
|
||||
<label for="terms">Den Datenschutzbestimmungen stimme ich zu</label>
|
||||
<button type="submit">Zum Newsletter anmelden</button>
|
||||
</form>
|
||||
|
||||
|
||||
<h1 id="wichtig">Das ist uns wichtig</h1>
|
||||
<div class="wichtig">
|
||||
<ul class="wichtigListe">
|
||||
<li>Beste frische saisonale Zutaten</li>
|
||||
<li>Ausgewogen abwechslungsreiche Gerichte</li>
|
||||
<li>Sauberkeit</li>
|
||||
</ul>
|
||||
</div>
|
||||
<h1 class="freude">Wir freuen uns auf Ihren Besuch!</h1>
|
||||
</div>
|
||||
</div>
|
||||
<footer>
|
||||
<table class="fusszeile">
|
||||
<tr>
|
||||
<td>(c) E-Mensa GmbH</td>
|
||||
<td>Şafak Hazinedar & Robert Joel</td>
|
||||
<td><a href="">Impressum</a></td>
|
||||
</tr>
|
||||
</table>
|
||||
</footer>
|
||||
</body>
|
||||
|
||||
</html>
|
||||
BIN
M2/Werbeseite/mensa21.jpg
Normal file
|
After Width: | Height: | Size: 153 KiB |
1
M2/Werbeseite/newletter.txt
Normal file
@@ -0,0 +1 @@
|
||||
1
|
||||
1
M2/Werbeseite/subscriptions.json
Normal file
@@ -0,0 +1 @@
|
||||
[{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Ro","email":"robert-joel@web.de","language":"deutsch","terms":"on"},{"name":"Robert","email":"robert-joel@web.de","language":"deutsch","terms":"on"}]
|
||||
3
M2/beispiele/erstesphp.php
Normal file
@@ -0,0 +1,3 @@
|
||||
<?php
|
||||
echo "Erstes PHP-Skript <br>";
|
||||
phpinfo();
|
||||
BIN
M2/dossier M2.xlsx
Normal file
0
M1/.idea/.gitignore → M3/.idea/.gitignore
generated
vendored
0
M1/.idea/M1.iml → M3/.idea/M3.iml
generated
12
M3/.idea/dataSources.xml
generated
Normal file
@@ -0,0 +1,12 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="DataSourceManagerImpl" format="xml" multifile-model="true">
|
||||
<data-source source="LOCAL" name="emensawerbeseite" uuid="9b92c113-bfb2-483a-8722-2d670725b7b2">
|
||||
<driver-ref>mariadb</driver-ref>
|
||||
<synchronize>true</synchronize>
|
||||
<jdbc-driver>org.mariadb.jdbc.Driver</jdbc-driver>
|
||||
<jdbc-url>jdbc:mariadb://localhost:3306</jdbc-url>
|
||||
<working-dir>$ProjectFileDir$</working-dir>
|
||||
</data-source>
|
||||
</component>
|
||||
</project>
|
||||
2
M1/.idea/modules.xml → M3/.idea/modules.xml
generated
@@ -2,7 +2,7 @@
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/M1.iml" filepath="$PROJECT_DIR$/.idea/M1.iml" />
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/M3.iml" filepath="$PROJECT_DIR$/.idea/M3.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
1
M1/.idea/php.xml → M3/.idea/php.xml
generated
@@ -10,6 +10,7 @@
|
||||
<option name="highlightLevel" value="WARNING" />
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PhpProjectSharedConfiguration" php_language_level="8.2" />
|
||||
<component name="PhpStanOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
6
M3/.idea/sqldialects.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="SqlDialectMappings">
|
||||
<file url="PROJECT" dialect="MariaDB" />
|
||||
</component>
|
||||
</project>
|
||||
0
M1/.idea/vcs.xml → M3/.idea/vcs.xml
generated
BIN
M3/11b).pdf
Normal file
BIN
M3/DBWT_M3_mysqli.pdf
Normal file
166
M3/Datenbank_erstellen.txt
Normal file
@@ -0,0 +1,166 @@
|
||||
create or replace database emensawerbeseite;
|
||||
|
||||
use emensawerbeseite;
|
||||
|
||||
create table gericht (
|
||||
id int8 primary key auto_increment,
|
||||
name varchar(80) not null unique,
|
||||
beschreibung varchar(80) not null,
|
||||
erfasst_am date not null,
|
||||
vegetarisch boolean not null,
|
||||
vegan boolean not null,
|
||||
preisintern double not null,
|
||||
preisextern double not null
|
||||
);
|
||||
|
||||
|
||||
create table allergen(
|
||||
code char(4) primary key ,
|
||||
name varchar(300) not null,
|
||||
typ varchar(20) not null
|
||||
);
|
||||
|
||||
create table kategorie(
|
||||
id int8 primary key ,
|
||||
name varchar(80) not null,
|
||||
eltern_id int8 ,
|
||||
CONSTRAINT FOREIGN KEY (eltern_id) REFERENCES kategorie(id),
|
||||
bildname varchar(200)
|
||||
);
|
||||
|
||||
create table gericht_hat_allergen(
|
||||
code char(4),
|
||||
CONSTRAINT FOREIGN KEY (code) REFERENCES allergen(code),
|
||||
gericht_id int8 not null,
|
||||
CONSTRAINT FOREIGN KEY (gericht_id) REFERENCES gericht(id)
|
||||
);
|
||||
|
||||
create table gericht_hat_kategorie(
|
||||
gericht_id int8 not null,
|
||||
CONSTRAINT FOREIGN KEY (gericht_id) REFERENCES gericht(id),
|
||||
kategorie_id int8 not null,
|
||||
CONSTRAINT FOREIGN KEY (kategorie_id) REFERENCES kategorie(id)
|
||||
);
|
||||
|
||||
create table besucher_counter(
|
||||
id int primary key,
|
||||
besucher int8
|
||||
);
|
||||
|
||||
|
||||
INSERT INTO `besucher_counter` ()
|
||||
VALUES (1,1);
|
||||
|
||||
|
||||
INSERT INTO `allergen` (`code`, `name`, `typ`) VALUES
|
||||
('a', 'Getreideprodukte', 'Getreide (Gluten)'),
|
||||
('a1', 'Weizen', 'Allergen'),
|
||||
('a2', 'Roggen', 'Allergen'),
|
||||
('a3', 'Gerste', 'Allergen'),
|
||||
('a4', 'Dinkel', 'Allergen'),
|
||||
('a5', 'Hafer', 'Allergen'),
|
||||
('a6', 'Dinkel', 'Allergen'),
|
||||
('b', 'Fisch', 'Allergen'),
|
||||
('c', 'Krebstiere', 'Allergen'),
|
||||
('d', 'Schwefeldioxid/Sulfit', 'Allergen'),
|
||||
('e', 'Sellerie', 'Allergen'),
|
||||
('f', 'Milch und Laktose', 'Allergen'),
|
||||
('f1', 'Butter', 'Allergen'),
|
||||
('f2', 'Käse', 'Allergen'),
|
||||
('f3', 'Margarine', 'Allergen'),
|
||||
('g', 'Sesam', 'Allergen'),
|
||||
('h', 'Nüsse', 'Allergen'),
|
||||
('h1', 'Mandeln', 'Allergen'),
|
||||
('h2', 'Haselnüsse', 'Allergen'),
|
||||
('h3', 'Walnüsse', 'Allergen'),
|
||||
('i', 'Erdnüsse', 'Allergen');
|
||||
|
||||
INSERT INTO `gericht` (`id`, `name`, `beschreibung`, `erfasst_am`, `vegan`, `vegetarisch`, `preisintern`, `preisextern`) VALUES
|
||||
(1, 'Bratkartoffeln mit Speck und Zwiebeln', 'Kartoffeln mit Zwiebeln und gut Speck', '2020-08-25', 0, 0, 2.3, 4),
|
||||
(3, 'Bratkartoffeln mit Zwiebeln', 'Kartoffeln mit Zwiebeln und ohne Speck', '2020-08-25', 1, 1, 2.3, 4),
|
||||
(4, 'Grilltofu', 'Fein gewürzt und mariniert', '2020-08-25', 1, 1, 2.5, 4.5),
|
||||
(5, 'Lasagne', 'Klassisch mit Bolognesesoße und Creme Fraiche', '2020-08-24', 0, 0, 2.5, 4.5),
|
||||
(6, 'Lasagne vegetarisch', 'Klassisch mit Sojagranulatsoße und Creme Fraiche', '2020-08-24', 0, 1, 2.5, 4.5),
|
||||
(7, 'Hackbraten', 'Nicht nur für Hacker', '2020-08-25', 0, 0, 2.5, 4),
|
||||
(8, 'Gemüsepfanne', 'Gesundes aus der Region, deftig angebraten', '2020-08-25', 1, 1, 2.3, 4),
|
||||
(9, 'Hühnersuppe', 'Suppenhuhn trifft Petersilie', '2020-08-25', 0, 0, 2, 3.5),
|
||||
(10, 'Forellenfilet', 'mit Kartoffeln und Dilldip', '2020-08-22', 0, 0, 3.8, 5),
|
||||
(11, 'Kartoffel-Lauch-Suppe', 'der klassische Bauchwärmer mit frischen Kräutern', '2020-08-22', 0, 1, 2, 3),
|
||||
(12, 'Kassler mit Rosmarinkartoffeln', 'dazu Salat und Senf', '2020-08-23', 0, 0, 3.8, 5.2),
|
||||
(13, 'Drei Reibekuchen mit Apfelmus', 'grob geriebene Kartoffeln aus der Region', '2020-08-23', 0, 1, 2.5, 4.5),
|
||||
(14, 'Pilzpfanne', 'die legendäre Pfanne aus Pilzen der Saison', '2020-08-23', 0, 1, 3, 5),
|
||||
(15, 'Pilzpfanne vegan', 'die legendäre Pfanne aus Pilzen der Saison ohne Käse', '2020-08-24', 1, 1, 3, 5),
|
||||
(16, 'Käsebrötchen', 'schmeckt vor und nach dem Essen', '2020-08-24', 0, 1, 1, 1.5),
|
||||
(17, 'Schinkenbrötchen', 'schmeckt auch ohne Hunger', '2020-08-25', 0, 0, 1.25, 1.75),
|
||||
(18, 'Tomatenbrötchen', 'mit Schnittlauch und Zwiebeln', '2020-08-25', 1, 1, 1, 1.5),
|
||||
(19, 'Mousse au Chocolat', 'sahnige schweizer Schokolade rundet jedes Essen ab', '2020-08-26', 0, 1, 1.25, 1.75),
|
||||
(20, 'Suppenkreation á la Chef', 'was verschafft werden muss, gut und günstig', '2020-08-26', 0, 0, 0.5, 0.9);
|
||||
|
||||
INSERT INTO `gericht_hat_allergen` (`code`, `gericht_id`) VALUES
|
||||
('h', 1),
|
||||
('a3', 1),
|
||||
('a4', 1),
|
||||
('f1', 3),
|
||||
('a6', 3),
|
||||
('i', 3),
|
||||
('a3', 4),
|
||||
('f1', 4),
|
||||
('a4', 4),
|
||||
('h3', 4),
|
||||
('d', 6),
|
||||
('h1',7),
|
||||
('a2', 7),
|
||||
('h3', 7),
|
||||
('c', 7),
|
||||
('a3', 8),
|
||||
('h3', 10),
|
||||
('d', 10),
|
||||
('f', 10),
|
||||
('f2', 12),
|
||||
('h1', 12),
|
||||
('a5',12),
|
||||
('c', 1),
|
||||
('a2', 9),
|
||||
('i', 14),
|
||||
('f1', 1),
|
||||
('a1', 15),
|
||||
('a4', 15),
|
||||
('i', 15),
|
||||
('f3', 15),
|
||||
('h3', 15);
|
||||
|
||||
INSERT INTO `kategorie` (`id`, `eltern_id`, `name`, `bildname`) VALUES
|
||||
(1, NULL, 'Aktionen', 'kat_aktionen.png'),
|
||||
(2, NULL, 'Menus', 'kat_menu.gif'),
|
||||
(3, 2, 'Hauptspeisen', 'kat_menu_haupt.bmp'),
|
||||
(4, 2, 'Vorspeisen', 'kat_menu_vor.svg'),
|
||||
(5, 2, 'Desserts', 'kat_menu_dessert.pic'),
|
||||
(6, 1, 'Mensastars', 'kat_stars.tif'),
|
||||
(7, 1, 'Erstiewoche', 'kat_erties.jpg');
|
||||
|
||||
INSERT INTO `gericht_hat_kategorie` (`kategorie_id`, `gericht_id`) VALUES
|
||||
(3, 1), (3, 3), (3, 4), (3, 5), (3, 6), (3, 7), (3, 9), (4, 16), (4, 17), (4, 18), (5, 16), (5, 17), (5, 18);
|
||||
|
||||
|
||||
|
||||
|
||||
SELECT DISTINCT name, GROUP_CONCAT(code) FROM gericht g JOIN gericht_hat_allergen a ON g.id = a.gericht_id GROUP BY name ASC;
|
||||
|
||||
SELECT DISTINCT name, GROUP_CONCAT(code) FROM gericht g LEFT JOIN gericht_hat_allergen a ON g.id = a.gericht_id GROUP BY name ASC
|
||||
;
|
||||
SELECT DISTINCT allergen.code, GROUP_CONCAT(gericht.name) AS gericht FROM allergen
|
||||
LEFT JOIN gericht_hat_allergen on allergen.code = gericht_hat_allergen.code
|
||||
LEFT JOIN gericht ON gericht_hat_allergen.gericht_id = gericht_id
|
||||
GROUP BY allergen.name
|
||||
ORDER BY code ASC;
|
||||
|
||||
|
||||
SELECT kategorie.name, COUNT(kategorie_id) AS anzahl FROM gericht_hat_kategorie, kategorie
|
||||
WHERE kategorie.id = gericht_hat_kategorie.kategorie_id
|
||||
GROUP BY kategorie_id
|
||||
ORDER BY anzahl ASC;
|
||||
|
||||
SELECT kategorie.name, COUNT(kategorie_id) AS anzahl FROM gericht_hat_kategorie, kategorie
|
||||
WHERE kategorie.id = gericht_hat_kategorie.kategorie_id AND kategorie_id > 2
|
||||
GROUP BY kategorie_id
|
||||
ORDER BY anzahl ASC;
|
||||
BIN
M3/Diagram.drawio.png
Normal file
|
After Width: | Height: | Size: 138 KiB |
111
M3/M3.md
Normal file
@@ -0,0 +1,111 @@
|
||||
# Aufgabe 3
|
||||
Übung. Datenbank: Anfragen. Erstellen Sie die folgenden Anfragen in SQL und führen Sie diese auf der angelegten Datenstruktur durch (z.B. in HeidiSQL oder PHPStorm). Geben Sie sowohl das Statement als auch die Ergebnismenge (z.B. als Screenshot) in Ihrem Dossier mit ab.
|
||||
|
||||
## Abfragen
|
||||
|
||||
1) Alle Daten aus gericht
|
||||
``` sql
|
||||
SELECT * FROM gericht
|
||||
```
|
||||
2) Das Erfassungsdatum aller Gerichte.
|
||||
``` sql
|
||||
SELECT erfasst_am FROM gericht
|
||||
```
|
||||
3) Das Erfassungsdatum sowie den Namen (als Attributname Gerichtname) aller Gerichte absteigend sortiert nach Gerichtname.
|
||||
``` sql
|
||||
SELECT name, erfasst_am FROM gericht ORDER BY name DESC
|
||||
```
|
||||
4) Den Namen sowie die Beschreibung der Gerichte aufsteigend sortiert nach Namen, wobei nur 5 Datensätze dargestellt werden sollen.
|
||||
``` sql
|
||||
SELECT name, beschreibung FROM gericht ORDER BY name ASC LIMIT 5
|
||||
```
|
||||
5) Ändern Sie die vorherige Abfrage so ab, so dass 10 Datensätze dargestellt werden, die nach den ersten 5 Datensätzen folgen. (Die ersten 5 Datensätze werden übersprungen)
|
||||
``` sql
|
||||
SELECT name,beschreibung FROM gericht ORDER BY name ASC LIMIT 10 OFFSET 5
|
||||
```
|
||||
6) Zeigen Sie alle möglichen Allergen-Typen (typ), wobei Sie keine doppelten Einträge darstellen.
|
||||
``` sql
|
||||
SELECT DISTINCT typ FROM allergen
|
||||
```
|
||||
7) Namen von Gerichten, deren Name mit einem klein- oder großgeschriebenen „K“ beginnt.
|
||||
``` sql
|
||||
SELECT name FROM gericht WHERE name LIKE 'k%'
|
||||
```
|
||||
8) Ids und Namen von Gerichten, deren Namen ein „suppe“ an beliebiger Stelle enthält.
|
||||
``` sql
|
||||
SELECT id, name FROM gericht WHERE name LIKE '%suppe%'
|
||||
```
|
||||
9) Alle Kategorien, die keine Elterneinträge besitzen.
|
||||
``` sql
|
||||
SELECT * FROM kategorie WHERE eltern_id IS NULL
|
||||
```
|
||||
10) Korrigieren Sie den Wert „Dinkel“ in der Tabelle allergen mit dem code a6 zu „Kamut“.
|
||||
``` sql
|
||||
UPDATE allergen SET name = 'Kamut' WHERE code = 'a6';
|
||||
```
|
||||
11) Fügen Sie das Gericht „Currywurst mit Pommes“ hinzu und tragen Sie es in
|
||||
der Kategorie „Hauptspeise“ ein.
|
||||
``` sql
|
||||
INSERT INTO gericht VALUES (21, 'Currywurst mit Pommes', '', '2023-11-22', 0, 0, 1.0, 2.0);
|
||||
|
||||
INSERT INTO gericht_hat_kategorie VALUES (21, 3);
|
||||
```
|
||||
|
||||
|
||||
# Aufgabe 6
|
||||
|
||||
## Abfragen
|
||||
|
||||
1) Alle Gerichte mit allen zugehörigen Allergenen
|
||||
``` sql
|
||||
SELECT DISTINCT name, GROUP_CONCAT(code) FROM gericht g JOIN gericht_hat_allergen a ON g.id = a.gericht_id GROUP BY name ASC;
|
||||
```
|
||||
2) Ändern Sie die vorherige Abfrage so ab, dass alle existierenden Gerichte dargestellt werden (auch wenn keine Allergene enthalten sind).
|
||||
``` sql
|
||||
SELECT DISTINCT name, GROUP_CONCAT(code) FROM gericht g LEFT JOIN gericht_hat_allergen a ON g.id = a.gericht_id GROUP BY name ASC;
|
||||
```
|
||||
3) Ändern Sie die vorherige Abfrage so ab, so dass im Ergebnis alle existierenden Allergene dargestellt werden (auch wenn diese nicht einem Gericht zugeordnet sind).
|
||||
``` sql
|
||||
SELECT DISTINCT allergen.code, GROUP_CONCAT(gericht.name) AS gericht FROM allergen LEFT JOIN gericht_hat_allergen on allergen.code = gericht_hat_allergen.code LEFT JOIN gericht ON gericht_hat_allergen.gericht_id = gericht_id
|
||||
GROUP BY allergen.name
|
||||
ORDER BY code ASC;
|
||||
```
|
||||
4) Die Anzahl der Gerichte pro Kategorie aufsteigend sortiert nach Anzahl.
|
||||
``` sql
|
||||
SELECT kategorie.name, COUNT(kategorie_id) AS anzahl FROM gericht_hat_kategorie, kategorie
|
||||
WHERE kategorie.id = gericht_hat_kategorie.kategorie_id
|
||||
GROUP BY kategorie_id
|
||||
ORDER BY anzahl ASC;
|
||||
```
|
||||
5) Ändern Sie die vorherige Abfrage so ab, dass dabei nur die Kategorien dargestellt werden, die mehr als 2 Gerichte besitzen.
|
||||
``` sql
|
||||
SELECT kategorie.name, COUNT(kategorie_id) AS anzahl FROM gericht_hat_kategorie, kategorie
|
||||
WHERE kategorie.id = gericht_hat_kategorie.kategorie_id AND kategorie_id > 2
|
||||
GROUP BY kategorie_id
|
||||
ORDER BY anzahl ASC;
|
||||
```
|
||||
|
||||
|
||||
# Aufgabe 7
|
||||
elter_kategorie:
|
||||
``` sql
|
||||
CONSTRAINT FOREIGN KEY (id) REFERENCES kategorie(id),
|
||||
```
|
||||
|
||||
gericht_hat_allergen:
|
||||
``` sql
|
||||
code char(4),
|
||||
CONSTRAINT FOREIGN KEY (code) REFERENCES allergen(code),
|
||||
gericht_id int8 not null,
|
||||
CONSTRAINT FOREIGN KEY (gericht_id) REFERENCES gericht(id)
|
||||
|
||||
```
|
||||
|
||||
gericht_hat_kategorie:
|
||||
``` sql
|
||||
gericht_id int8 not null,
|
||||
CONSTRAINT FOREIGN KEY (gericht_id) REFERENCES gericht(id),
|
||||
kategorie_id int8 not null,
|
||||
CONSTRAINT FOREIGN KEY (kategorie_id) REFERENCES kategorie(id)
|
||||
|
||||
```
|
||||
1
M3/Werbeseite/besucher.txt
Normal file
@@ -0,0 +1 @@
|
||||
218
|
||||
BIN
M3/Werbeseite/fh-logo.jpg
Normal file
|
After Width: | Height: | Size: 64 KiB |
31
M3/Werbeseite/gerichte.php
Normal file
@@ -0,0 +1,31 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
|
||||
$gerichte = [
|
||||
1 => ['name' => 'Rindfleich mit Bambus, Kaiserschoten und roter Paprika, dazu Mie Nudeln',
|
||||
'priceint' => 3.50,
|
||||
"priceex" => 6.20,
|
||||
"img" =>"img/bambus.jpg"
|
||||
],
|
||||
2 => ['name' => 'Spinatrisotto mit kleinen Samosateigecken und gemischter Salat',
|
||||
'priceint' => 2.90,
|
||||
"priceex" => 5.30,
|
||||
"img" =>"img/risotto.jpg"
|
||||
],
|
||||
3 => ['name' => 'Spaghetti Bolognese',
|
||||
'priceint' => 3,
|
||||
"priceex" => 5,
|
||||
"img" =>"img/bolo.jpg"
|
||||
],
|
||||
4 => ['name' => 'Spaghetti Carbonara',
|
||||
'priceint' => 3,
|
||||
"priceex" => 5,
|
||||
"img" =>"img/carbonara.jpg"
|
||||
]
|
||||
]
|
||||
?>
|
||||
BIN
M3/Werbeseite/img/bambus.jpg
Normal file
|
After Width: | Height: | Size: 1.6 MiB |
BIN
M3/Werbeseite/img/bolo.jpg
Normal file
|
After Width: | Height: | Size: 1.1 MiB |
BIN
M3/Werbeseite/img/carbonara.jpg
Normal file
|
After Width: | Height: | Size: 139 KiB |
BIN
M3/Werbeseite/img/risotto.jpg
Normal file
|
After Width: | Height: | Size: 103 KiB |
371
M3/Werbeseite/index.php
Normal file
@@ -0,0 +1,371 @@
|
||||
<?php
|
||||
/**
|
||||
* Praktikum DBWT. Autoren:
|
||||
* Şafak, Hazinedar, 3108590
|
||||
* Robert, Joel, 3672729
|
||||
*/
|
||||
|
||||
include "gerichte.php";
|
||||
|
||||
$besucherCount = 0;
|
||||
$newletterCount = 0;
|
||||
|
||||
// Datenbankanbindung
|
||||
//$link = mysqli_connect(
|
||||
//"127.0.0.1", // Host der Datenbank
|
||||
//"root", // Benutzername zur Anmeldung
|
||||
//"wm#32", // Passwort
|
||||
//"emensawerbeseite" // Auswahl der Datenbanken (bzw. des Schemas)
|
||||
//);
|
||||
|
||||
$link = mysqli_connect(
|
||||
"127.0.0.1", // Host der Datenbank
|
||||
"root", // Benutzername zur Anmeldung
|
||||
"admin", // Passwort
|
||||
"emensawerbeseite" // Auswahl der Datenbanken (bzw. des Schemas)
|
||||
);
|
||||
|
||||
if (!$link) {
|
||||
echo "Verbindung fehlgeschlagen: ", mysqli_connect_error();
|
||||
exit();
|
||||
}
|
||||
|
||||
//Besucher counter
|
||||
|
||||
//Aktuelle Besucher Zahl
|
||||
$sql_besucher = "SELECT besucher FROM besucher_counter WHERE id=1";
|
||||
$result_sql_besucher = mysqli_query($link, $sql_besucher);
|
||||
$besucher = mysqli_fetch_assoc($result_sql_besucher);
|
||||
|
||||
//Updatet Besucher Zahl
|
||||
$besucherCount = $besucher["besucher"] + 1;
|
||||
$sql_besucher = "UPDATE besucher_counter SET besucher =".$besucherCount;
|
||||
$result_sql_besucher = mysqli_query($link, $sql_besucher);
|
||||
|
||||
//Newletter counter
|
||||
if (file_exists("newletter.txt")) {
|
||||
$newsFile = fopen("newletter.txt", "r");
|
||||
$newletterCount = fgets($newsFile);
|
||||
fclose($newsFile);
|
||||
} else {
|
||||
$newsFile = fopen("newletter.txt", "w");
|
||||
fwrite($newsFile, 0);
|
||||
fclose($newsFile);
|
||||
}
|
||||
|
||||
//Newletter Anmeldung
|
||||
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
|
||||
$name = $_POST['name'];
|
||||
$email = $_POST['email'];
|
||||
$language = $_POST['language'];
|
||||
$terms = $_POST['terms'];
|
||||
|
||||
$errors = array();
|
||||
//Error handling
|
||||
if (empty(trim($name))) {
|
||||
$errors[] = "Bitte geben Sie einen Namen ein.";
|
||||
}
|
||||
|
||||
if (!isset($terms)) {
|
||||
$errors[] = "Bitte stimmen Sie den Datenschutzbestimmungen zu.";
|
||||
}
|
||||
|
||||
if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
|
||||
$errors[] = "Bitte geben Sie eine gültige E-Mail-Adresse ein.";
|
||||
}
|
||||
|
||||
$spam_domains = array("rcpt.at", "damnthespam.at", "wegwerfmail.de", "trashmail");
|
||||
|
||||
foreach ($spam_domains as $domain) {
|
||||
if (str_contains($email, $domain)) {
|
||||
$errors[] = "Bitte geben Sie eine gültige E-Mail-Adresse ein, keine Wegwerf- oder Spam-E-Mail-Adresse.";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (empty($errors)) {
|
||||
$data = array(
|
||||
"name" => $name,
|
||||
"email" => $email,
|
||||
"language" => $language,
|
||||
"terms" => $terms
|
||||
);
|
||||
//File writing
|
||||
$file = "subscriptions.json";
|
||||
$current_data = file_exists($file) ? json_decode(file_get_contents($file), true) : array();
|
||||
$current_data[] = $data;
|
||||
|
||||
if (file_put_contents($file, json_encode($current_data))) {
|
||||
echo '<script type="text/javascript">';
|
||||
echo 'alert("Vielen Dank für Ihre Anmeldung zum Newsletter.");';
|
||||
echo '</script>';
|
||||
|
||||
//Newsletter counter
|
||||
$newletterCount++;
|
||||
$newsFile = fopen("newletter.txt", "w");
|
||||
fwrite($newsFile, $newletterCount);
|
||||
fclose($newsFile);
|
||||
} else {
|
||||
echo '<script type="text/javascript">';
|
||||
echo 'alert("Es gab einen Fehler bei Ihrer Anmeldung. Bitte versuchen Sie es erneut.");';
|
||||
echo '</script>';
|
||||
}
|
||||
} else {
|
||||
$error_string = "";
|
||||
foreach ($errors as $error) {
|
||||
$error_string .= $error . '\n';
|
||||
}
|
||||
|
||||
echo '<script type="text/javascript">';
|
||||
echo 'alert("' . $error_string . '");';
|
||||
echo '</script>';
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
||||
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="en" xmlns="http://www.w3.org/1999/html">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Ihre E-Mensa</title>
|
||||
<style>
|
||||
* {
|
||||
font-family: Arial;
|
||||
}
|
||||
|
||||
.grid {
|
||||
display: grid;
|
||||
grid-template-columns: 200px auto 200px;
|
||||
}
|
||||
|
||||
img {
|
||||
width: 100%;
|
||||
height: auto;
|
||||
}
|
||||
|
||||
.speisen {
|
||||
border: solid;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
.speisen td {
|
||||
border: solid;
|
||||
border-collapse: collapse;
|
||||
border-radius: 4px;
|
||||
padding: 5px;
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.speisen td:not(:first-of-type) {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
p {
|
||||
text-align: justify;
|
||||
}
|
||||
|
||||
.zahlen {
|
||||
list-style-type: none;
|
||||
display: grid;
|
||||
grid-template-columns: auto auto auto;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.zahlen p {
|
||||
text-align: center;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
.formular {
|
||||
display: grid;
|
||||
grid-template-columns: auto auto auto;
|
||||
justify-content: start;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.wichtig {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.wichtigListe {
|
||||
display: inline-block;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.freude {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
footer {
|
||||
border-top: 1px solid;
|
||||
}
|
||||
|
||||
.fusszeile {
|
||||
padding-top: 20px;
|
||||
padding-bottom: 20px;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
border: none;
|
||||
}
|
||||
|
||||
.fusszeile td:first-child {
|
||||
border-left: none;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
.fusszeile td {
|
||||
border-left: 3px solid;
|
||||
padding-left: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="grid">
|
||||
<div>
|
||||
<img src="fh-logo.jpg" alt="FH-Logo">
|
||||
</div>
|
||||
<div>
|
||||
<a href="#ankündigung">Ankündigung</a>
|
||||
<a href="#speisen">Speisen</a>
|
||||
<a href="#zahlen">Zahlen</a>
|
||||
<a href="#kontakt">Kontakt</a>
|
||||
<a href="#wichtig">Wichtig für uns</a>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<hr>
|
||||
<div class="grid">
|
||||
<div></div>
|
||||
<div>
|
||||
<img src="mensa21.jpg" alt="Essen">
|
||||
<h1 id="ankündigung">Bald gibt es auch Essen online ;)</h1>
|
||||
<p>Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et
|
||||
dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet
|
||||
clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet,
|
||||
consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat,
|
||||
sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no
|
||||
sea takimata sanctus est Lorem ipsum dolor sit amet.</p>
|
||||
<h1 id="speisen">Köstlichkeiten die Sie erwarten</h1>
|
||||
|
||||
<!-- Speisekarte -->
|
||||
<?php
|
||||
//Gerichte aus Datenbank
|
||||
$sql_gerichte = "SELECT * FROM gericht ORDER BY RAND() LIMIT 5";
|
||||
$result_sql_gerichte = mysqli_query($link, $sql_gerichte);
|
||||
|
||||
$tabelle = "<table class=\"speisen\"><tr class=\"speisen\"> <td>Gerichte</td><td>Preis intern</td><td>Preis extern</td><td>Bild</td></tr>";
|
||||
|
||||
$verwendete_allergene_code = [];
|
||||
$verwendete_allergene_string = "";
|
||||
|
||||
while ($row_gerichte = mysqli_fetch_assoc($result_sql_gerichte)) {
|
||||
|
||||
// Abfrage der vorhandenen Allergene im aktuellen Gericht
|
||||
|
||||
$sql_gericht_hat_allergene = "SELECT * FROM gericht_hat_allergen WHERE gericht_id=" . $row_gerichte['id'];
|
||||
$result_sql_gericht_hat_allergene = mysqli_query($link, $sql_gericht_hat_allergene);
|
||||
$allergene = "";
|
||||
while ($row_allergene = mysqli_fetch_assoc($result_sql_gericht_hat_allergene)) {
|
||||
$allergene .= $row_allergene['code'] . ", ";
|
||||
|
||||
if (!in_array($row_allergene['code'], $verwendete_allergene_code)) {
|
||||
$verwendete_allergene_code[] = $row_allergene['code'];
|
||||
}
|
||||
}
|
||||
|
||||
// Preise in EUR
|
||||
|
||||
$preisintern = number_format($row_gerichte['preisintern'], 2, ',', '.');
|
||||
$preisextern = number_format($row_gerichte['preisextern'], 2, ',', '.');
|
||||
|
||||
// Ausgabe des aktuellen Gerichts
|
||||
|
||||
$tabelle .= "<tr class=\"speisen\"><td>" . $row_gerichte['name'] . " <sup>" . $allergene . "</sup></td><td>" . $preisintern . "€</td><td>" . $preisextern . "€</td><td>Kein Bild in der Datenbank </td></tr>";
|
||||
}
|
||||
$tabelle .= "</table>";
|
||||
echo $tabelle;
|
||||
|
||||
// Abfrage der Allergen Code und Name
|
||||
|
||||
$sql_allergen = "SELECT code, name FROM allergen";
|
||||
$result_sql_allergen = mysqli_query($link, $sql_allergen);
|
||||
|
||||
while ($row_allergen = mysqli_fetch_assoc($result_sql_allergen)){
|
||||
if (in_array($row_allergen['code'], $verwendete_allergene_code)){
|
||||
$verwendete_allergene_string .= "<sup>".$row_allergen['code']."</sup> ". $row_allergen['name']. ", ";
|
||||
}
|
||||
}
|
||||
|
||||
echo $verwendete_allergene_string;
|
||||
?>
|
||||
|
||||
|
||||
<h1 id="zahlen">E-Mensa in Zahlen</h1>
|
||||
<div class="zahlen">
|
||||
<p><?php echo $besucherCount; ?> Besuche</p>
|
||||
<p><?php echo $newletterCount; ?> Anmeldungen zum Newsletter</p>
|
||||
<p>
|
||||
<?php
|
||||
$sql_gerichte = "SELECT COUNT(id) FROM gericht";
|
||||
$result_sql_gerichte = mysqli_query($link, $sql_gerichte);
|
||||
$ausgabe = mysqli_fetch_assoc($result_sql_gerichte);
|
||||
echo $ausgabe["COUNT(id)"];
|
||||
?>
|
||||
Speisen
|
||||
</p>
|
||||
</div>
|
||||
<h1 id="kontakt">Interesse geweckt? Wir informieren</h1>
|
||||
|
||||
<form method="post">
|
||||
<div class="formular">
|
||||
<div>
|
||||
<label for="name">Name:</label> <br>
|
||||
<input type="text" name="name" id="name" placeholder="Bitte geben Sie Ihren Namen ein">
|
||||
</div>
|
||||
<div>
|
||||
<label for="email">E-Mail:</label> <br>
|
||||
<input type="email" name="email" id="email" placeholder="Bitte geben Sie Ihre E-Mail ein">
|
||||
</div>
|
||||
<div>
|
||||
<label for="language">Newsletter bitte in:</label> <br>
|
||||
<select name="language" id="language">
|
||||
<option value="deutsch">Deutsch</option>
|
||||
<option value="englisch">Englisch</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<br>
|
||||
<input required type="checkbox" name="terms" id="terms">
|
||||
<label for="terms">Den Datenschutzbestimmungen stimme ich zu</label>
|
||||
<button type="submit">Zum Newsletter anmelden</button>
|
||||
</form>
|
||||
|
||||
|
||||
<h1 id="wichtig">Das ist uns wichtig</h1>
|
||||
<div class="wichtig">
|
||||
<ul class="wichtigListe">
|
||||
<li>Beste frische saisonale Zutaten</li>
|
||||
<li>Ausgewogen abwechslungsreiche Gerichte</li>
|
||||
<li>Sauberkeit</li>
|
||||
</ul>
|
||||
</div>
|
||||
<h1 class="freude">Wir freuen uns auf Ihren Besuch!</h1>
|
||||
</div>
|
||||
</div>
|
||||
<footer>
|
||||
<table class="fusszeile">
|
||||
<tr>
|
||||
<td>(c) E-Mensa GmbH</td>
|
||||
<td>Şafak Hazinedar & Robert Joel</td>
|
||||
<td><a href="">Impressum</a></td>
|
||||
</tr>
|
||||
</table>
|
||||
</footer>
|
||||
</body>
|
||||
|
||||
</html>
|
||||
BIN
M3/Werbeseite/mensa21.jpg
Normal file
|
After Width: | Height: | Size: 153 KiB |
1
M3/Werbeseite/newletter.txt
Normal file
@@ -0,0 +1 @@
|
||||
2
|
||||
1
M3/Werbeseite/subscriptions.json
Normal file
@@ -0,0 +1 @@
|
||||
[{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"},{"name":"Ro","email":"robert-joel@web.de","language":"deutsch","terms":"on"},{"name":"Robert","email":"robert-joel@web.de","language":"deutsch","terms":"on"},{"name":"Max","email":"max@gmail.com","language":"deutsch","terms":"on"}]
|
||||
28
M3/beispiel/m3_4a_testdatenbank.php
Normal file
@@ -0,0 +1,28 @@
|
||||
<?php
|
||||
$link=mysqli_connect(
|
||||
"127.0.0.1", // Host der Datenbank
|
||||
"root", // Benutzername zur Anmeldung
|
||||
"wm#32", // Passwort
|
||||
"emensawerbeseite" // Auswahl der Datenbanken (bzw. des Schemas)
|
||||
);
|
||||
|
||||
if (!$link) {
|
||||
echo "Verbindung fehlgeschlagen: ", mysqli_connect_error();
|
||||
exit();
|
||||
}
|
||||
|
||||
$sql = "SELECT erfasst_am FROM gericht ";
|
||||
$result = mysqli_query($link, $sql);
|
||||
if (!$result) {
|
||||
echo "Fehler während der Abfrage: ", mysqli_error($link);
|
||||
exit();
|
||||
}
|
||||
|
||||
$tabelle = "<table>";
|
||||
while ($row = mysqli_fetch_assoc($result)) {
|
||||
$tabelle .= "<tr><td>". $row['erfasst_am']. "</td></tr>";
|
||||
}
|
||||
$tabelle .= "</table>";
|
||||
echo $tabelle;
|
||||
mysqli_free_result($result);
|
||||
mysqli_close($link);
|
||||
BIN
M3/connection_example.zip
Normal file
BIN
M3/dossier m3.pdf
Normal file
93
M3/werbeseite_daten.sql
Normal file
@@ -0,0 +1,93 @@
|
||||
|
||||
USE emensawerbeseite;
|
||||
|
||||
INSERT INTO `allergen` (`code`, `name`, `typ`) VALUES
|
||||
('a', 'Getreideprodukte', 'Getreide (Gluten)'),
|
||||
('a1', 'Weizen', 'Allergen'),
|
||||
('a2', 'Roggen', 'Allergen'),
|
||||
('a3', 'Gerste', 'Allergen'),
|
||||
('a4', 'Dinkel', 'Allergen'),
|
||||
('a5', 'Hafer', 'Allergen'),
|
||||
('a6', 'Dinkel', 'Allergen'),
|
||||
('b', 'Fisch', 'Allergen'),
|
||||
('c', 'Krebstiere', 'Allergen'),
|
||||
('d', 'Schwefeldioxid/Sulfit', 'Allergen'),
|
||||
('e', 'Sellerie', 'Allergen'),
|
||||
('f', 'Milch und Laktose', 'Allergen'),
|
||||
('f1', 'Butter', 'Allergen'),
|
||||
('f2', 'Käse', 'Allergen'),
|
||||
('f3', 'Margarine', 'Allergen'),
|
||||
('g', 'Sesam', 'Allergen'),
|
||||
('h', 'Nüsse', 'Allergen'),
|
||||
('h1', 'Mandeln', 'Allergen'),
|
||||
('h2', 'Haselnüsse', 'Allergen'),
|
||||
('h3', 'Walnüsse', 'Allergen'),
|
||||
('i', 'Erdnüsse', 'Allergen');
|
||||
|
||||
INSERT INTO `gericht` (`id`, `name`, `beschreibung`, `erfasst_am`, `vegan`, `vegetarisch`, `preisintern`, `preisextern`) VALUES
|
||||
(1, 'Bratkartoffeln mit Speck und Zwiebeln', 'Kartoffeln mit Zwiebeln und gut Speck', '2020-08-25', 0, 0, 2.3, 4),
|
||||
(3, 'Bratkartoffeln mit Zwiebeln', 'Kartoffeln mit Zwiebeln und ohne Speck', '2020-08-25', 1, 1, 2.3, 4),
|
||||
(4, 'Grilltofu', 'Fein gewürzt und mariniert', '2020-08-25', 1, 1, 2.5, 4.5),
|
||||
(5, 'Lasagne', 'Klassisch mit Bolognesesoße und Creme Fraiche', '2020-08-24', 0, 0, 2.5, 4.5),
|
||||
(6, 'Lasagne vegetarisch', 'Klassisch mit Sojagranulatsoße und Creme Fraiche', '2020-08-24', 0, 1, 2.5, 4.5),
|
||||
(7, 'Hackbraten', 'Nicht nur für Hacker', '2020-08-25', 0, 0, 2.5, 4),
|
||||
(8, 'Gemüsepfanne', 'Gesundes aus der Region, deftig angebraten', '2020-08-25', 1, 1, 2.3, 4),
|
||||
(9, 'Hühnersuppe', 'Suppenhuhn trifft Petersilie', '2020-08-25', 0, 0, 2, 3.5),
|
||||
(10, 'Forellenfilet', 'mit Kartoffeln und Dilldip', '2020-08-22', 0, 0, 3.8, 5),
|
||||
(11, 'Kartoffel-Lauch-Suppe', 'der klassische Bauchwärmer mit frischen Kräutern', '2020-08-22', 0, 1, 2, 3),
|
||||
(12, 'Kassler mit Rosmarinkartoffeln', 'dazu Salat und Senf', '2020-08-23', 0, 0, 3.8, 5.2),
|
||||
(13, 'Drei Reibekuchen mit Apfelmus', 'grob geriebene Kartoffeln aus der Region', '2020-08-23', 0, 1, 2.5, 4.5),
|
||||
(14, 'Pilzpfanne', 'die legendäre Pfanne aus Pilzen der Saison', '2020-08-23', 0, 1, 3, 5),
|
||||
(15, 'Pilzpfanne vegan', 'die legendäre Pfanne aus Pilzen der Saison ohne Käse', '2020-08-24', 1, 1, 3, 5),
|
||||
(16, 'Käsebrötchen', 'schmeckt vor und nach dem Essen', '2020-08-24', 0, 1, 1, 1.5),
|
||||
(17, 'Schinkenbrötchen', 'schmeckt auch ohne Hunger', '2020-08-25', 0, 0, 1.25, 1.75),
|
||||
(18, 'Tomatenbrötchen', 'mit Schnittlauch und Zwiebeln', '2020-08-25', 1, 1, 1, 1.5),
|
||||
(19, 'Mousse au Chocolat', 'sahnige schweizer Schokolade rundet jedes Essen ab', '2020-08-26', 0, 1, 1.25, 1.75),
|
||||
(20, 'Suppenkreation á la Chef', 'was verschafft werden muss, gut und günstig', '2020-08-26', 0, 0, 0.5, 0.9);
|
||||
|
||||
INSERT INTO `gericht_hat_allergen` (`code`, `gericht_id`) VALUES
|
||||
('h', 1),
|
||||
('a3', 1),
|
||||
('a4', 1),
|
||||
('f1', 3),
|
||||
('a6', 3),
|
||||
('i', 3),
|
||||
('a3', 4),
|
||||
('f1', 4),
|
||||
('a4', 4),
|
||||
('h3', 4),
|
||||
('d', 6),
|
||||
('h1',7),
|
||||
('a2', 7),
|
||||
('h3', 7),
|
||||
('c', 7),
|
||||
('a3', 8),
|
||||
('h3', 10),
|
||||
('d', 10),
|
||||
('f', 10),
|
||||
('f2', 12),
|
||||
('h1', 12),
|
||||
('a5',12),
|
||||
('c', 1),
|
||||
('a2', 9),
|
||||
('i', 14),
|
||||
('f1', 1),
|
||||
('a1', 15),
|
||||
('a4', 15),
|
||||
('i', 15),
|
||||
('f3', 15),
|
||||
('h3', 15);
|
||||
|
||||
INSERT INTO `kategorie` (`id`, `eltern_id`, `name`, `bildname`) VALUES
|
||||
(1, NULL, 'Aktionen', 'kat_aktionen.png'),
|
||||
(2, NULL, 'Menus', 'kat_menu.gif'),
|
||||
(3, 2, 'Hauptspeisen', 'kat_menu_haupt.bmp'),
|
||||
(4, 2, 'Vorspeisen', 'kat_menu_vor.svg'),
|
||||
(5, 2, 'Desserts', 'kat_menu_dessert.pic'),
|
||||
(6, 1, 'Mensastars', 'kat_stars.tif'),
|
||||
(7, 1, 'Erstiewoche', 'kat_erties.jpg');
|
||||
|
||||
INSERT INTO `gericht_hat_kategorie` (`kategorie_id`, `gericht_id`) VALUES
|
||||
(3, 1), (3, 3), (3, 4), (3, 5), (3, 6), (3, 7), (3, 9), (4, 16), (4, 17), (4, 18), (5, 16), (5, 17), (5, 18);
|
||||
|
||||
|
||||
0
M2/.idea/.gitignore → M4/.idea/.gitignore
generated
vendored
11
M4/.idea/M4.iml
generated
Normal file
@@ -0,0 +1,11 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<module type="WEB_MODULE" version="4">
|
||||
<component name="NewModuleRootManager">
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<excludeFolder url="file://$MODULE_DIR$/emensa/vendor/composer" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/emensa/vendor/eftec/bladeone" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
<orderEntry type="sourceFolder" forTests="false" />
|
||||
</component>
|
||||
</module>
|
||||
12
M4/.idea/dataSources.xml
generated
Normal file
@@ -0,0 +1,12 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="DataSourceManagerImpl" format="xml" multifile-model="true">
|
||||
<data-source source="LOCAL" name="emensawerbeseite" uuid="0a2c3473-febe-491a-b3f1-82e9ba5b153f">
|
||||
<driver-ref>mariadb</driver-ref>
|
||||
<synchronize>true</synchronize>
|
||||
<jdbc-driver>org.mariadb.jdbc.Driver</jdbc-driver>
|
||||
<jdbc-url>jdbc:mariadb://localhost:3306</jdbc-url>
|
||||
<working-dir>$ProjectFileDir$</working-dir>
|
||||
</data-source>
|
||||
</component>
|
||||
</project>
|
||||
8
M4/.idea/modules.xml
generated
Normal file
@@ -0,0 +1,8 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/.idea/M4.iml" filepath="$PROJECT_DIR$/.idea/M4.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
||||
26
M4/.idea/php.xml
generated
Normal file
@@ -0,0 +1,26 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="MessDetectorOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PHPCSFixerOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PHPCodeSnifferOptionsConfiguration">
|
||||
<option name="highlightLevel" value="WARNING" />
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PhpIncludePathManager">
|
||||
<include_path>
|
||||
<path value="$PROJECT_DIR$/emensa/vendor/composer" />
|
||||
<path value="$PROJECT_DIR$/emensa/vendor/eftec/bladeone" />
|
||||
</include_path>
|
||||
</component>
|
||||
<component name="PhpProjectSharedConfiguration" php_language_level="8.2" />
|
||||
<component name="PhpStanOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
<component name="PsalmOptionsConfiguration">
|
||||
<option name="transferred" value="true" />
|
||||
</component>
|
||||
</project>
|
||||
6
M4/.idea/sqldialects.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="SqlDialectMappings">
|
||||
<file url="PROJECT" dialect="MariaDB" />
|
||||
</component>
|
||||
</project>
|
||||
6
M4/.idea/vcs.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="$PROJECT_DIR$/.." vcs="Git" />
|
||||
</component>
|
||||
</project>
|
||||
19
M4/Dossier/.$Aufgabe1.drawio.bkp
Normal file
@@ -0,0 +1,19 @@
|
||||
<mxfile host="Electron" modified="2023-12-01T15:21:01.688Z" agent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) draw.io/22.1.2 Chrome/114.0.5735.289 Electron/25.9.4 Safari/537.36" etag="78gUQK1TRnweegfurtHK" version="22.1.2" type="device">
|
||||
<diagram name="Seite-1" id="jhCbnHoXzx65MXILfqUJ">
|
||||
<mxGraphModel dx="1050" dy="725" grid="1" gridSize="10" guides="1" tooltips="1" connect="1" arrows="1" fold="1" page="1" pageScale="1" pageWidth="827" pageHeight="1169" math="0" shadow="0">
|
||||
<root>
|
||||
<mxCell id="0" />
|
||||
<mxCell id="1" parent="0" />
|
||||
<mxCell id="8l75yZ3mhxg1qXRySu_G-1" value="" style="rhombus;whiteSpace=wrap;html=1;" vertex="1" parent="1">
|
||||
<mxGeometry x="320" y="240" width="160" height="80" as="geometry" />
|
||||
</mxCell>
|
||||
<mxCell id="8l75yZ3mhxg1qXRySu_G-2" value="" style="rounded=0;whiteSpace=wrap;html=1;" vertex="1" parent="1">
|
||||
<mxGeometry x="80" y="240" width="160" height="80" as="geometry" />
|
||||
</mxCell>
|
||||
<mxCell id="8l75yZ3mhxg1qXRySu_G-3" value="" style="rounded=0;whiteSpace=wrap;html=1;" vertex="1" parent="1">
|
||||
<mxGeometry x="560" y="240" width="160" height="80" as="geometry" />
|
||||
</mxCell>
|
||||
</root>
|
||||
</mxGraphModel>
|
||||
</diagram>
|
||||
</mxfile>
|
||||